首先DALFactory,需要增加一个类DALFactory2.cs

//*--------------------------------------
//*  Create By Yesun .Net Tool V1.1
//*  CopyRight (C) yesun
//*  Email:edzh@tom.com QQ:363980
//*  Msn:dyesur@hotmail.com
//*  Web http://edzh.com
//*  DateTime 2006-6-2
//*--------------------------------------
using System;
using System.Reflection;
using System.Collections.Specialized;
using System.Configuration;
using Yesun.Edzh.IDAL;
namespace Yesun.Edzh.DALFactory
{
    /// <summary>
    /// 工厂类Admin 的摘要说明。
    /// web.config 需要加入配置:(利用工厂模式+反射机制+缓存机制,实现动态创建不同的数据层对象接口)
    /// DataCache类在导出代码的文件夹里
    /// 可以把所有DAL类的创建放在这个DataAccess类里
    /// <appSettings>
    /// <add key="DAL" value="CMS.DAL" /> DAL路径,(这里的命名空间根据实际情况更改为自己项目的命名空间)
    /// </appSettings>
    /// </summary>
    public sealed class DataAccess2<T>
    {
        private static readonly string path = ConfigurationManager.AppSettings["DAL"];

/// <summary>
        /// 创建对象或从缓存获取
        /// </summary>
        public static object CreateObject(string path, string CacheKey)
        {
            System.Web.Caching.Cache objCache = System.Web.HttpRuntime.Cache;
            object objType = objCache[CacheKey];
            if (objType == null)
            {
                try
                {
                    objType = Assembly.Load(path).CreateInstance(CacheKey);
                    objCache.Insert(CacheKey, objType);// 写入缓存
                }
                catch (Exception ex)
                {
                    throw ex;
                }
            }
            return objType;
        }
        /// <summary>
        /// 创建数据层接口
        /// </summary>
        public static IDAL<T> CreateDAL()
        {
            string className = typeof(T).ToString();
            className = className.Substring(className.LastIndexOf(".") + 1);
            string CacheKey = path + "." + className;
            object objType = CreateObject(path, CacheKey);
            return (IDAL<T>)objType;
        }
    }
}

 然后再BLL层,需要增加一个基类BaseBLL.cs

using System;
using System.Collections.Generic;
using System.Text;

namespace Yesun.Edzh.BLL
{
    /// <summary>
    /// 业务层常用方法
    /// </summary>
    public class BaseBLL<T>
    {
        private static readonly Yesun.Edzh.IDAL.IDAL<T> dal = Yesun.Edzh.DALFactory.DataAccess2<T>.CreateDAL();

/// <summary>
        /// 增加一条数据
        /// </summary>
        public bool Save(T t)
        {
            return dal.Save(t);
        }

/// <summary>
        /// 修改一条数据
        /// </summary>
        public bool Update(T t)
        {
            return dal.Update(t);
        }

/// <summary>
        /// 取得对象实体
        /// </summary>
        public T GetModel(Guid id)
        {
            return dal.GetModel(id);
        }

/// <summary>
        /// 取得对象实体
        /// </summary>
        public T GetModel(string id)
        {
            return dal.GetModel(new Guid(id));
        }

/// <summary>
        /// 取得数据列表
        /// </summary>
        public Yesun.Edzh.Model.SqlPage<T> GetList()
        {
            return this.GetList(1, -1);
        }

/// <summary>
        /// 取得数据列表
        /// </summary>
        public Yesun.Edzh.Model.SqlPage<T> GetList(int pageid, int pagesize)
        {
            return this.GetList(pageid, pagesize, "");
        }

/// <summary>
        /// 取得数据列表
        /// </summary>
        public Yesun.Edzh.Model.SqlPage<T> GetList(int pageid, int pagesize, string where)
        {
            return this.GetList(pageid, pagesize, where, "");
        }

/// <summary>
        /// 取得数据列表
        /// </summary>
        public Yesun.Edzh.Model.SqlPage<T> GetList(int pageid, int pagesize, string where, string sort)
        {
            return this.GetList(pageid, pagesize, where, sort, "");
        }

/// <summary>
        /// 取得数据列表
        /// </summary>
        public Yesun.Edzh.Model.SqlPage<T> GetList(int pageid, int pagesize, string where, string sort, string fields)
        {
            return this.GetList(pageid, pagesize, where, sort, fields, "");
        }

/// <summary>
        /// 取得数据列表
        /// </summary>
        public Yesun.Edzh.Model.SqlPage<T> GetList(int pageid, int pagesize, string where, string sort, string fields, string pk)
        {
            return dal.GetList(pk, fields, sort, where, pageid, pagesize);
        }

/// <summary>
        /// 删除N条数据
        /// </summary>
        public bool Delete(string delid)
        {
            return dal.Delete(delid);
        }

/// <summary>
        /// 按条件统计
        /// </summary>
        public long GetCount(string where)
        {
            return dal.GetCount(where);
        }

/// <summary>
        /// 按条件判断是否重复
        /// </summary>
        public bool IsExsit(string where)
        {
            return dal.IsExsit(where);
        }

}
}

接下来BLL层的普通类只需要基层BaseBLL即可,支持扩充方法

//*--------------------------------------
//*  Create By Yesun .Net Tool V1.1
//*  CopyRight (C) yesun
//*  Email:edzh@tom.com QQ:363980
//*  Msn:dyesur@hotmail.com
//*  Web http://edzh.com
//*  DateTime 2006-10-11
//*--------------------------------------
using System;
using System.Data;
using System.Collections;
using System.Text;
using System.Data.SqlClient;
using Yesun.Edzh.Model;
using Yesun.Edzh.IDAL;
using Yesun.Edzh.DALFactory;

namespace Yesun.Edzh.BLL
{
 /// <summary>
 /// 逻辑业务层 Admin
 /// </summary>
 public class AdminService : BaseBLL<Yesun.Edzh.Model.Admin>
 {
        private static readonly IAdmin dal = DataAccess.CreateAdmin();

#region 业务层扩充方法

/// <summary>
        /// 得到一个对象实体
        /// </summary>
        /// <param name="username"></param>
        /// <returns></returns>
        public Yesun.Edzh.Model.Admin GetModelByUserName(string username)
        {
            return dal.GetModelByUserName(username);
        }

/// <summary>
        /// 通过用户id取得属于该用户的权限
        /// </summary>
        /// <param name="userid"></param>
        /// <returns></returns>
        public Hashtable GetPermissionByUserId(Guid userid)
        {
            Hashtable htPermisstion = new Hashtable();
            SqlPage<Yesun.Edzh.Model.Permission> sqlpage = new PermissionService().GetList(1,-1,"id IN(select permissionid from cms_role_permission where roleid IN(select roleid from cms_user_role where userid='" + userid + "'))");
            foreach (Yesun.Edzh.Model.Permission permission in sqlpage)
            {
                if(permission == null) continue;
                if (permission.PermissionName != "")
                {
                    htPermisstion.Add((object)(permission.PermissionName + "" + permission.Operate), (object)(permission.PermissionName + "" + permission.Operate));
                }
            }
            return htPermisstion;
        }

#endregion
    }
}

思路基本上和上次DAL,IDAL这两个层差不多,稍作变化而已!

精简BLL业务层,使用范型复用常用方法相关推荐

  1. 走向.NET架构设计—第四章—业务层分层架构(后篇)

    走向.NET架构设计-第四章-业务层分层架构(后篇) 前言: 在上一篇文章中,我们讨论了组织业务逻辑的模式:Transaction Script和Active Record,Domain Model. ...

  2. SSH三种框架及表示层、业务层和持久层的理解

    SSH:Struts(表示层)+Spring(业务层)+Hibernate(持久层) 在项目开发的过程中,有时把整个项目分为三层架构,其中包括: 1.表示层(UI). 2.业务逻辑层(BLL) 3.数 ...

  3. 【JAVA】范型的理解

    什么是范型? 所谓范型,故名思意:"广泛类型"的意思.它是Java SE1.5的新特性,它可以接受任意类型的数据.除了基本数据类型,但是我们可以使用基本数据类型的包装类. 范型可以 ...

  4. 浅谈网页三层结构:表现层、业务层和数据层

    转自:微点阅读  https://www.weidianyuedu.com 网页设计 三层结构 表现层.业务层和数据层 1. 表现层(Presentation Layer): 表现层用于用户接口的展示 ...

  5. Generic Data Access Objects -范型DAO类设计模式

    Generic Data Access Objects 普通数据访问对象,这个是Hibernate官方网站上面的一个DAO类的设计模式,基于JDK5.0范型支持,文章地址如下: http://www. ...

  6. J2EE业务层模式:服务门面,应用服务,以及业务委托,服务定位器

    现在J2EE领域无论是表现层,业务层还是持久层,框架满天飞,虽然说框架为我们省了很大的力气,但是我们还是需要掌握J2EE里面经常用到的一些模式,下面对J2EE领域业务层的几个模式做一个小的总结: 服务 ...

  7. 走向.NET架构设计—第五章—业务层模式,原则,实践(中篇)

    走向.NET架构设计-第五章-业务层模式,原则,实践(中篇) 前言:设计模式并不是什么很高深的东西,至少不是那么"神乎其神".说到底,设计模式就是一些设计思想.下面我们就走进项目, ...

  8. 《设计模式解析》第1章 面向对象范型

    第1章 面向对象范型 概述 本章通过和另外一种你熟悉的范型--标准结构化编程相对比,来向你介绍面向对象范型. 面向对象范型的产生是因为使用标准化结构编程,过去的实践面临着挑战.通过清楚地了解这些挑战, ...

  9. 编译原理(一)编译程序、解释程序、程序设计语言范型

    编译原理的地位 是软件技术的基础 是计算机专业的基础课程,是专业必修课 编译原理的作用 编译原理是介绍如何将高级语言程序变换成低级语言程序的方法. 其理论基础坚实,其形式化系统不仅用于编译程序,还大量 ...

最新文章

  1. ant design pro (十六)advanced 权限管理
  2. android app 历史版本,怎么找到App的所有历史版本,以及每次改版的变更点呢?
  3. VTK:Utilities之ColorTransferFunction
  4. Avalonia跨平台入门第十五篇之ListBox聊天窗口
  5. Android 自定义焦点框,Android给自定义按键添加广播和通过广播给当前焦点输入框赋值...
  6. Qt creator5.7 OpenCV249之pyrUp函数(含源码下载)
  7. mongo04---基本查询
  8. 网络蚂蚁的最基本原理nbsp;-nbsp;httpnbsp;1.1
  9. uni-app(vue小程序)学习笔记
  10. item在python中什么意思_Python中使用item()方法遍历字典的例子
  11. Android多语言支持二
  12. Java学习lesson 10
  13. 面对对象之差异化的网络数据交互方式--单机游戏开发之无缝切换到C/S模式
  14. ubuntu20.04安装小鹤双拼输入法挂接音形改简体中文Rime
  15. python控制苹果手机触摸,Appium+python自动化(二十九)- 模拟手指在手机上多线多点作战...
  16. 计算机组成与系统结构——MIPS多周期处理器-7指令
  17. [Unity]摄像机动态人物头像amp;截图amp;TargetTexture问题
  18. 二进制文件漏洞挖掘 IDA插件VulFi安装使用
  19. 【每日一个GitHub项目】GitHub中文排行榜
  20. win10更改固定IP出现意外无法更改

热门文章

  1. 【uni-app框架介绍及环境配置】
  2. java毕业设计—— 基于java+JPA+jsp的进销存管理系统设计与实现(毕业论文+程序源码)——进销存管理系统
  3. linux-CentOS6.4安装Memcached+memcached扩展+安装memcache扩展+Memcache+mecached同步SESSION的几种方法
  4. C3D:视频动作分类demo实现
  5. “复制”马斯克(三):我们要为他的“反智事业”买单吗?
  6. 西安电子科技大学网络与信息安全学院专硕951考研回顾
  7. java 读取dwg_Java 读取 dwg 转换 dxf
  8. 开源软件的各大开源协议是什么含义,你知道嘛?
  9. Vue里面使用el-cascader 级联选择器 children为空 和获取value和label问题
  10. 2021- css-doodle