搭建自己的框架WedeNet(三)
WedeNet2018.BussinessLogic-业务逻辑层:
结构如下:
基类:
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using WedeNet2018.Infrastructure;
- using WedeNet2018.Infrastructure.Components;
- namespace WedeNet2018.BussinessLogic
- {
- /// <summary>
- /// 业务逻辑层父类
- /// </summary>
- public abstract class AbsBussinessLogic
- {
- public AbsBussinessLogic()
- {
- }
- /// <summary>
- /// 接受一个实现了IUnitOfWorks接口的工作单元实例
- /// </summary>
- protected IUnitOfWorks _works { get; set; }
- /// <summary>
- /// 当前工作单元的提交方法,可在子类中重写。
- /// </summary>
- /// <returns></returns>
- public virtual int Commit()
- {
- return _works.Commit();
- }
- }
- }
这个基类的目的主要是实现UnitOfWorks的事务性提交,对于具体业务性的操作放在派生类中。当应用层调用不同的BussinessLogic进行对应的业务处理完毕后,可调用该数据上下文对应的UnitOfWorks实例的Commit()方法统一提交。
实现类如下:
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using WedeNet2018.Infrastructure;
- using WedeNet2018.Infrastructure.Components;
- namespace WedeNet2018.BussinessLogic
- {
- public class OrdersBussinessLogic : AbsBussinessLogic
- {
- public OrdersBussinessLogic(IWedeUnitOfWorks works)
- {
- _works = works;
- }
- public IQueryable<Orders> GetOrders(int orderType){
- IQueryable<Orders> ret = null;
- ret = _works.All<Orders>().Where(r=>r.OrderType.Equals(orderType));
- return ret;
- }
- public void Add(Orders order) {
- _works.Add<Orders>(order);
- }
- public Orders Find(int id) {
- Orders order = _works.Find<Orders>(id);
- return order;
- }
- public void Update(Orders order)
- {
- _works.Update<Orders>(order);
- }
- public void Delete(int id)
- {
- Orders order = _works.Find<Orders>(id);
- _works.Delete<Orders>(order);
- }
- }
- }
异常处理
系统异常(不论是预期的或非预期的)都要抛至业务逻辑层为止,业务层对捕获的异常进行处理。
规则为:
1、使用RealProxy动态织入业务层指定的方法;
2、自定义异常类和Attribute;
3、业务逻辑层以下发生的异常层层上抛至业务逻辑层,并且要日志记录异常发生具体信息;
4、业务逻辑层捕获到下层抛出的异常后可以区分是预期异常还是非预期异常;
5、如果全局异常处理器捕获到了非预期的异常,则统一抛出“未知错误”;
6、可以对捕获的异常再次处理返给客户端;
业务层实现代码:
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using WedeNet2018.Common;
- using WedeNet2018.Common.Attributes;
- using WedeNet2018.Common.Exceptions;
- using WedeNet2018.Infrastructure;
- using WedeNet2018.Infrastructure.Components;
- using WedeNet2018.Infrastructure.Components.aop;
- namespace WedeNet2018.BussinessLogic
- {
- public class OrdersBussinessLogic : AbsBussinessLogic
- {
- public OrdersBussinessLogic(IWedeUnitOfWorks works)
- {
- log = LoggerHelper.WedeNetLogger;
- //_works = works;
- #region AOP动态织入
- var dynamicProxy = new DynamicProxy<IWedeUnitOfWorks>(works);
- dynamicProxy.BeforeExecute += (s, e) =>
- {
- log.Info(e.MethodName + "方法执行前");
- };
- dynamicProxy.AfterExecute += (s, e) =>
- {
- log.Info(e.MethodName + "方法执行后");
- };
- dynamicProxy.ErrorExecuting += (s, e) =>
- {
- log.Info(e.MethodName + "方法执行异常");
- Type t = works.GetType();
- //标注了[CustomFilter]注解的IUnitOfWorks类全局异常处理才生效
- if (t.IsDefined(typeof(CustomFilterAttribute), false))
- {
- throw new CustomException(dynamicProxy.MyException.Message,
- dynamicProxy.MyException.InnerException);
- }
- };
- //过滤不需要织入的方法
- dynamicProxy.Filter = m => (!m.Name.StartsWith("Get") || !m.Name.StartsWith("Find"));
- _works = dynamicProxy.GetTransparentProxy() as IWedeUnitOfWorks;
- #endregion
- }
- public IQueryable<Orders> GetOrders(int orderType){
- IQueryable<Orders> ret = null;
- try
- {
- ret = _works.All<Orders>().Where(r => r.OrderType.Equals(orderType));
- }
- catch (Exception ex)
- {
- #region 异常处理
- if (ex is CustomException)
- {
- log.Info("自定义异常:" + ex.Message);
- if (ex.InnerException != null)
- {
- log.Info(ex.InnerException.Message + "发生于" + ex.InnerException.TargetSite.ReflectedType + "类的" + ex.InnerException.TargetSite.Name + "方法。");
- }
- }
- else
- {
- log.Info("未知异常:" + ex.Message);
- if (ex.InnerException != null)
- {
- log.Info(ex.InnerException.Message + "发生于" + ex.InnerException.TargetSite.ReflectedType + "类的" + ex.InnerException.TargetSite.Name + "方法。");
- }
- }
- #endregion
- }
- return ret;
- }
- public bool Add(Orders order) {
- try
- {
- _works.Add<Orders>(order);
- return true;
- }
- catch (Exception ex) {
- #region 异常处理
- if (ex is CustomException)
- {
- log.Info("自定义异常:" + ex.Message);
- if (ex.InnerException != null)
- {
- log.Info(ex.InnerException.Message + "发生于" + ex.InnerException.TargetSite.ReflectedType + "类的" + ex.InnerException.TargetSite.Name + "方法。");
- }
- }
- else
- {
- log.Info("未知异常:" + ex.Message);
- if (ex.InnerException != null)
- {
- log.Info(ex.InnerException.Message + "发生于" + ex.InnerException.TargetSite.ReflectedType + "类的" + ex.InnerException.TargetSite.Name + "方法。");
- }
- }
- #endregion
- return false;
- }
- }
- public Orders Find(int id) {
- Orders order = _works.Find<Orders>(id);
- return order;
- }
- public bool Update(Orders order)
- {
- try
- {
- _works.Update<Orders>(order);
- return true;
- }
- catch (Exception ex)
- {
- #region 异常处理
- if (ex is CustomException)
- {
- log.Info("自定义异常:" + ex.Message);
- if (ex.InnerException != null)
- {
- log.Info(ex.InnerException.Message + "发生于" + ex.InnerException.TargetSite.ReflectedType + "类的" + ex.InnerException.TargetSite.Name + "方法。");
- }
- }
- else
- {
- log.Info("未知异常:" + ex.Message);
- if (ex.InnerException != null)
- {
- log.Info(ex.InnerException.Message + "发生于" + ex.InnerException.TargetSite.ReflectedType + "类的" + ex.InnerException.TargetSite.Name + "方法。");
- }
- }
- #endregion
- return false;
- }
- }
- public bool Delete(int id)
- {
- Orders order = _works.Find<Orders>(id);
- try
- {
- _works.Delete<Orders>(order);
- return true;
- }
- catch (Exception ex)
- {
- #region 异常处理
- if (ex is CustomException)
- {
- log.Info("自定义异常:" + ex.Message);
- if (ex.InnerException != null)
- {
- log.Info(ex.InnerException.Message + "发生于" + ex.InnerException.TargetSite.ReflectedType + "类的" + ex.InnerException.TargetSite.Name + "方法。");
- }
- }
- else
- {
- log.Info("未知异常:" + ex.Message);
- if (ex.InnerException != null)
- {
- log.Info(ex.InnerException.Message + "发生于" + ex.InnerException.TargetSite.ReflectedType + "类的" + ex.InnerException.TargetSite.Name + "方法。");
- }
- }
- #endregion
- return false;
- }
- }
- }
- }
动态代理代码:
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Reflection;
- using System.Runtime.Remoting.Messaging;
- using System.Runtime.Remoting.Proxies;
- using System.Text;
- using System.Threading.Tasks;
- namespace WedeNet2018.Infrastructure.Components.aop
- {
- public class DynamicProxy<T> : RealProxy
- {
- private readonly T _decorated;
- private Predicate<MethodInfo> _filter;
- public event EventHandler<IMethodCallMessage> BeforeExecute;
- public event EventHandler<IMethodCallMessage> AfterExecute;
- public event EventHandler<IMethodCallMessage> ErrorExecuting;
- public DynamicProxy(T decorated)
- : base(typeof(T))
- {
- _decorated = decorated;
- Filter = m => true;
- }
- public Predicate<MethodInfo> Filter
- {
- get { return _filter; }
- set
- {
- if (value == null)
- _filter = m => true;
- else
- _filter = value;
- }
- }
- private void OnBeforeExecute(IMethodCallMessage methodCall)
- {
- if (BeforeExecute != null)
- {
- var methodInfo = methodCall.MethodBase as MethodInfo;
- if (_filter(methodInfo))
- BeforeExecute(this, methodCall);
- }
- }
- private void OnAfterExecute(IMethodCallMessage methodCall)
- {
- if (AfterExecute != null)
- {
- var methodInfo = methodCall.MethodBase as MethodInfo;
- if (_filter(methodInfo))
- AfterExecute(this, methodCall);
- }
- }
- private void OnErrorExecuting(IMethodCallMessage methodCall, Exception ex)
- {
- if (ErrorExecuting != null)
- {
- this.MyException = ex;
- var methodInfo = methodCall.MethodBase as MethodInfo;
- if (_filter(methodInfo))
- ErrorExecuting(this, methodCall);
- }
- }
- public Exception MyException
- {
- get;
- set;
- }
- public override IMessage Invoke(IMessage msg)
- {
- var methodCall = msg as IMethodCallMessage;
- var methodInfo = methodCall.MethodBase as MethodInfo;
- OnBeforeExecute(methodCall);
- try
- {
- var result = methodInfo.Invoke(_decorated, methodCall.InArgs);
- OnAfterExecute(methodCall);
- return new ReturnMessage(
- result, null, 0, methodCall.LogicalCallContext, methodCall);
- }
- catch (Exception e)
- {
- //CustomException customException = null; Exception ex = null;
- //if (typeof(T).IsDefined(typeof(CustomFilterAttribute), true)) {
- // customException = new CustomException(e.Message, e.InnerException);
- //}
- //if (customException != null)
- // ex = customException;
- //else
- // ex = e;
- OnErrorExecuting(methodCall, e);
- return new ReturnMessage(e, methodCall);
- }
- }
- }
- }
搭建自己的框架WedeNet(三)的更多相关文章
- 搭建自己的框架WedeNet(五)
WedeNet2018.WedeWcfServices-WCF服务层:结构如下: 就是定义了服务契约接口和服务类,以OrderServices为例,如下: using System; using Sy ...
- 搭建自己的框架WedeNet(四)
WedeNet2018.Web-UI层:结构如下: 首先,在Controller中定义BaseController,以便加入统一处理逻辑,如下: using log4net; using System ...
- 搭建自己的框架WedeNet(一)
框架用到的技术: EF.UnitOfWork+Repository.Ninject.log4net.WCF.MVC.T4.windows服务.AOP前端技术:Bootstrap.layer.jQuer ...
- 搭建自己的框架WedeNet(二)
WedeNet2018.Infrastructure-基础设施层:结构如下: Tools结构如下: 考虑到系统可能会有多个数据上下文(暂时以两个为例),所以根据需要定义两个T4模板用来生成对应的ent ...
- 如何搭建MVC + EF 框架
1.搭建MVC框架 1.1 VS2010:需要安装WPI 安装 ASP.NET MVC 4 和Visual Studio 2010 系统必备组件 如果上述链接无法打开,请访问:http://www.a ...
- Xvfb+YSlow+ShowSlow搭建前端性能测试框架 - 前端技术 | TaoBaoUED
Xvfb+YSlow+ShowSlow搭建前端性能测试框架 - 前端技术 | TaoBaoUED Xvfb+YSlow+ShowSlow搭建前端性能测试框架 作者:黑三 | 时间:2010-07-07 ...
- Windows环境搭建Web自动化测试框架Watir
Windows环境搭建Web自动化测试框架Watir 一.前言 Web自动化测试一直是一个比较迫切的问题,对于现在web开发的敏捷开发,却没有相对应的敏捷测试,故开此主题,一边研究,一边将We ...
- 搭建App主流框架_纯代码搭建(OC)
转载自:http://my.oschina.net/hejunbinlan/blog/529778?fromerr=EmSuX7PR 搭建主流框架界面 源码地址在文章末尾 达成效果 效果图 注:本文部 ...
- 【微服务】使用spring cloud搭建微服务框架,整理学习资料
写在前面 使用spring cloud搭建微服务框架,是我最近最主要的工作之一,一开始我使用bubbo加zookeeper制作了一个基于dubbo的微服务框架,然后被架构师否了,架构师曰:此物过时.随 ...
随机推荐
- moogdb操作
本文转载自 https://my.oschina.net/kakakaka/blog/347954 首先,下载mongdb对JAVA的支持,点击这里下载驱动包,这里博主下载的是2.10.1版. mon ...
- shiro中接入单点登录功能
最近新建的系统中使用了shiro,而shiro框架中包含登录认证和鉴权的功能,因为我们系统要统一接入公司内部的单点登录(isso)系统,所以通过isso的登录用户,需要在shiro中置为已认证,一下提 ...
- C语言中函数strcpy ,strncpy ,strlcpy的用法
strcpy ,strncpy ,strlcpy的用法 好多人已经知道利用strncpy替代strcpy来防止缓冲区越界. 但是如果还要考虑运行效率的话,也许strlcpy是一个更好的方式. 1. s ...
- python之NLP数据清洗
1.知识点 """ 安装模块:bs4 nltk gensim nltk:处理英文 1.安装 2.nltk.download() 下载相应的模块 英文数据处理: 1.去掉h ...
- 堡垒机直接调用RUN
两个脚本 Run.vbe 参考https://blog.csdn.net/skypeGNU/article/details/12708221 set ws=wscript.createobject ...
- curl指令的坑
今天使用curl指令构造一个docker api访问,一直得不到预期的结果.调试了半天,发现是网址没加引号. token=$(curl -v -XGET -H >& 由于网址跟了一串参数 ...
- 计蒜客 —— 字符串p型编码
给定一个完全由数字字符('0','1','2',…,'9')构成的字符串 strstr,请写出 strstr 的 pp 型编码串. 例如:字符串122344111可被描述为“1个 1.2 个 2.1 ...
- 日常小节----unity小坑记(静态后不可移动和旋转)
当物体被置为静态时,模型网格是无法移动和旋转的,只有碰撞器可以. 也就是会出现当父物体不为静态,子物体为静态时,运行后旋转移动父物体,子物体模型网格不会跟随旋转移动,但子物体碰撞器会跟随旋转移动. 或 ...
- 酷Q插件_SDK———入门与使用
1.这里使用的是易语言的SDK,所以请看不惯的人自行离开.{wymbf.} 1.2 这里不会直接给你工程,请用动手打代码,动脑思考. 1.3 不知道.不了解酷Q是干嘛的,请访问:https://cqp ...
- MySQL知识篇-SQL2
1 数据库基本操作? (1) 查看数据库 show databases; (2)切换到指定的数据库 use dbname; (3)创建数据库 create database 库名 charset=ut ...