本文主要是详解一下在ASP.NET Core中,采用替换后的Autofac来实现AOP拦截
觉得有帮助的朋友~可以左上角点个关注,右下角点个推荐
这里就不详细的赘述IOC是什么 以及DI是什么了.. emm..不懂的可以自行百度.
目录
ASP.NET Core中使用IOC三部曲(一.使用ASP.NET Core自带的IOC容器)
ASP.NET Core中使用IOC三部曲(二.采用Autofac来替换IOC容器,并实现属性注入)
ASP.NET Core中使用IOC三部曲(三.采用替换后的Autofac来实现AOP拦截)
上一篇我们讲了如何将默认的容器替换为Autofac,并使用属性注入.
那么这一篇我们就来讲讲如何利用Autofac实现我们的AOP(面向切面编程) .
1.引用正确的库来实现AOP
既然是跨平台,那么在asp.net core因为采用了.net core来作为基础库(当然,其实你可以换成.NET4.6.).
新的.NET Core是基于.NET Standard的..所以我们在引用库的时候特别要注意相关的兼容问题.
在传统的ASP.NET中,使用过Autofac来进行AOP操作的,应该都知道这个库.
Autofac.Extras.DynamicProxy
那么我们来看看它的依赖项.如图:

在.NET Standard的情况下,他需要Autofac4.0+,这个就不多说了.关键在下面这个,他需要Castle.Core4.0+.
所以,当我们直接安装这个库的时候,Nuget会自动关联并安装最新的Castle.Core4.2.1版本..
那么问题就出现了..在项目的依赖项中,会发现很多警告:

我们进入警告会发现..都是提示缺少兼容的最新的类型转换类.如图:

而且Castle.Core是属于AutoFac下面的..如图:

我们直接通过Nuget查找Castle.Core.
可以发现,它需要System.ComponentModel.TypeConverter4.3..

我们直接安装它,Nuget则会直接帮我们把System.ComponentModel.TypeConverter更新到4.3的版本..
然后重新通过Nuget安装Autofac.Extras.DynamicProxy..就可以了.如图:

其实这应该算一个Nuget的BUG..它会帮你引用库的相关依赖..但是当依赖还有依赖需要更新的时候..它就不会更新..
这个时候我们换一种思维..返回来 一步步引用.就可以了..
2.采用Autofac来实现AOP
首先,我们创建一个拦截类,代码如下:
public class AOPTest : IInterceptor
{
public void Intercept(IInvocation invocation)
{
System.Diagnostics.Debug.WriteLine("你正在调用方法 \"{0}\" 参数是 {1}... ",
invocation.Method.Name,
string.Join(", ", invocation.Arguments.Select(a => (a ?? "").ToString()).ToArray()));
//在被拦截的方法执行完毕后 继续执行
invocation.Proceed();
System.Diagnostics.Debug.WriteLine(</span><span style="color: #800000;">"</span><span style="color: #800000;">方法执行完毕,返回结果:{0}</span><span style="color: #800000;">"</span><span style="color: #000000;">, invocation.ReturnValue);
}
}</span></pre>
本文详细介绍在ASP.NET Core中采用替换后的Autofac实现AOP拦截。先阐述引用正确的库实现AOP时需注意的.NET Standard兼容问题及解决办法,后说明创建拦截类、设置拦截特性、注入AOP拦截类等实现AOP拦截的步骤。



被折叠的 条评论
为什么被折叠?



