What is AspectCore Project?
AspectCore Project is a lightweight Aop (Aspect-oriented programming) solution suitable for the Asp.Net Core platform. It better follows the modularization of Asp.Net Core Development concept, using AspectCore makes it easier to build low-coupling and easily scalable web applications. AspectCore uses Emit to implement efficient dynamic proxy without relying on any third-party Aop library.
Start using AspectCore
Start Visual Studio. From the File menu, choose New > Project. Select the ASP.NET Core Web Application project template and create a new ASP.NET Core Web Application project.
-
Install from Nuget
AspectCore.Extensions.DependencyInjection
package:PM> Install-Package AspectCore.Extensions.DependencyInjection
-
In general, you can use the abstract
InterceptorAttribute
Custom attribute class, which implements theIInterceptor
interface. AspectCore implements interceptor configuration based onAttribute
by default. Our custom interceptor looks like this:public class CustomInterceptorAttribute : InterceptorAttribute { public async override Task Invoke(IAspectContext context, AspectDelegate next) { try { Console.WriteLine("Before service call"); await next(context); } catch (Exception) { Console.WriteLine("Service threw an exception!"); throw; } finally { Console.WriteLine("After service call"); } } }
-
Definition
ICustomService
interface and its implementation classCustomService
:public interface ICustomService { [CustomInterceptor] void Call(); } public class CustomService : ICustomService { public void Call() { Console.WriteLine("service calling..."); } }
-
Inject
ICustomService
inHomeController
:public class HomeController : Controller { private readonly ICustomService _service; public HomeController(ICustomService service) { _service = service; } public IActionResult Index() { _service.Call(); return View(); } }
-
Register
ICustomService
, Next, configure the container to create the proxy type inConfigureServices
:public IServiceProvider ConfigureServices(IServiceCollection services) { services.AddTransient<icustomservice>(); services.AddMvc(); services.AddAspectCore(); return services.BuildAspectCoreServiceProvider(); }</icustomservice>
-
Interceptor configuration. First install the
AspectCore.Extensions.Configuration
package:PM> Install-Package AspectCore.Extensions.Configuration
global interceptor. Use the overloaded method of
AddAspectCore(Action<aspectcoreoptions>)</aspectcoreoptions>
, whereAspectCoreOptions
providesInterceptorFactories
to register a global interceptor:services.AddAspectCore(config => { config.InterceptorFactories.AddTyped<custominterceptorattribute>(); });</custominterceptorattribute>
with constructor For the global interceptor of parameters, add a constructor with parameters in
CustomInterceptorAttribute
:public class CustomInterceptorAttribute : InterceptorAttribute { private readonly string _name; public CustomInterceptorAttribute(string name) { _name = name; } public async override Task Invoke(AspectContext context, AspectDelegate next) { try { Console.WriteLine("Before service call"); await next(context); } catch (Exception) { Console.WriteLine("Service threw an exception!"); throw; } finally { Console.WriteLine("After service call"); } } }
Modify the global interceptor registration:
services.AddAspectCore(config => { config.InterceptorFactories.AddTyped<custominterceptorattribute>(args: new object[] { "custom" }); });</custominterceptorattribute>
as the global interceptor of the service. Add in
ConfigureServices
:services.AddTransient<custominterceptorattribute>(provider => new CustomInterceptorAttribute("service"));</custominterceptorattribute>
Modify the global interceptor registration:
services.AddAspectCore(config => { config.InterceptorFactories.AddServiced<custominterceptorattribute>(); });</custominterceptorattribute>
Acts on a specific
Service
orMethod
Global interceptor, the following code demonstrates a global interceptor acting on a class with theService
suffix:services.AddAspectCore(config => { config.InterceptorFactories.AddTyped<custominterceptorattribute>(method => method.DeclaringType.Name.EndsWith("Service")); });</custominterceptorattribute>
Specific global interceptor using wildcards:
services.AddAspectCore(config => { config.InterceptorFactories.AddTyped<custominterceptorattribute>(PredicateFactory.ForService("*Service")); });</custominterceptorattribute>
-
Provide
NonAspectAttribute
in AspectCore to preventService
orMethod
from being proxied:[NonAspect] public interface ICustomService { void Call(); }
also supports global ignore configuration , also supports wildcards:
services.AddAspectCore(config => { //App1命名空间下的Service不会被代理 config.NonAspectOptions.AddNamespace("App1"); //最后一级为App1的命名空间下的Service不会被代理 config.NonAspectOptions.AddNamespace("*.App1"); //ICustomService接口不会被代理 config.NonAspectOptions.AddService("ICustomService"); //后缀为Service的接口和类不会被代理 config.NonAspectOptions.AddService("*Service"); //命名为Query的方法不会被代理 config.NonAspectOptions.AddMethod("Query"); //后缀为Query的方法不会被代理 config.NonAspectOptions.AddMethod("*Query"); });
-
Dependency injection in interceptors. Supports property injection, constructor injection and service locator patterns in interceptors.
Property injection, property tags withpublic get and set
permissions in the interceptor[AspectCore.Abstractions.FromServices]
(different fromMicrosoft.AspNetCore.Mvc. FromServices
) feature, you can automatically inject this property, such as:public class CustomInterceptorAttribute : InterceptorAttribute { [AspectCore.Abstractions.FromServices] public ILogger<custominterceptorattribute> Logger { get; set; } public override Task Invoke(AspectContext context, AspectDelegate next) { Logger.LogInformation("call interceptor"); return next(context); } }</custominterceptorattribute>
Constructor injection needs to make the interceptor as
Service
, in addition to the global interceptor, you can still useServiceInterceptor
Make the interceptor active from DI:public interface ICustomService { [ServiceInterceptor(typeof(CustomInterceptorAttribute))] void Call(); }
Service locator mode. The interceptor context
AspectContext
can obtain the current Scoped'sServiceProvider
:public class CustomInterceptorAttribute : InterceptorAttribute { public override Task Invoke(AspectContext context, AspectDelegate next) { var logger = context.ServiceProvider.GetService<ilogger>>(); logger.LogInformation("call interceptor"); return next(context); } }</ilogger>
-
using
Autofac
andAspectCore
. AspectCore natively supports integrating Autofac. We need to install the following two nuget packages:PM> Install-Package Autofac.Extensions.DependencyInjection PM> Install-Package AspectCore.Extensions.Autofac
AspectCore provides the
RegisterAspectCore
extension method to register the services required by the dynamic proxy in Autofac'sContainer
, and provideAsInterfacesProxy
andAsClassProxy
extension methods to enable the proxy of interface and class. Modify theConfigureServices
method to:public IServiceProvider ConfigureServices(IServiceCollection services) { services.AddMvc(); var container = new ContainerBuilder(); container.RegisterAspectCore(); container.Populate(services); container.RegisterType<customservice>().As<icustomservice>().InstancePerDependency().AsInterfacesProxy(); return new AutofacServiceProvider(container.Build()); }</icustomservice></customservice>
Feedback on issues
If you have any questions, please submit an Issue to us.
AspectCore Project project address:
Finally. . .
Looking for a job, welcome to recommend .NET/.NET Core back-end development positions, located in Shanghai, please send a private message or email.
The above is the detailed content of What is the AspectCore Project?. For more information, please follow other related articles on the PHP Chinese website!

Sysprep问题可能出现在Windows11、10和8平台上。出现该问题时,Sysprep命令不会按预期运行和验证安装。如果您需要修复Sysprep问题,请查看下面的Windows11/10解决方案。Sysprep错误是如何在Windows中出现的?Sysprep无法验证您的Windows安装错误自Windows8以来一直存在。该问题通常是由于用户安装的UWP应用程序而出现的。许多用户已确认他们通过卸载从MSStore安装的某些UWP应用程序解决了此问题。如果缺少应该与Windows一起预安装

您将找到多个用户报告,确认NETHELPMSG2221错误代码。当您的帐户不再是管理员时,就会显示此信息。根据用户的说法,他们的帐户自动被撤销了管理员权限。如果您也遇到此问题,我们建议您应用指南中的解决方案并修复NETHELPMSG2221错误。您可以通过多种方式将管理员权限恢复到您的帐户。让我们直接进入它们。什么是NETHELPMSG2221错误?当您不是PC的管理员时,无法使用提升的程序。因此,例如,你将无法在电脑上运行命令提示符、WindowsPowerShell或任

什么原因导致WindowsUpdate错误0x8024800c?导致WindowsUpdate错误的原因0x8024800c尚不完全清楚。但是,此问题可能与其他更新错误具有类似的原因。以下是一些潜在的0x8024800c错误原因:损坏的系统文件–某些系统文件需要修复。不同步的软件分发缓存–软件分发数据存储不同步,这意味着此错误是超时问题(它有一个WU_E_DS_LOCKTIMEOUTEXPIRED结果字符串)。损坏的WindowsUpdate组件-错误0x8024800c是由错误的Win

MSOffice产品是任何Windows系统上用于创建Word、Excel表格等文档的应用程序的绝佳选择。但是您需要从Microsoft购买Office产品的有效许可证,并且必须激活它才能使其有效工作.最近,许多Windows用户报告说,每当他们启动任何Office产品(如Word、Excel等)时,他们都会收到一条警告消息,上面写着“您的Office许可证存在问题,并要求用户获取正版Office许可证”。一些用户不假思索,就去微软购买了Office产品的许可证

许多用户在系统变慢时报告任务管理器中存在WWAHost.exe进程。WWAHost.exe进程会占用大量系统资源,例如内存、CPU或磁盘,进而降低PC的速度。因此,每当您发现您的系统与以前相比变得缓慢时,请打开任务管理器,您会在那里找到这个WWAHost.exe进程。通常,已观察到启动任何应用程序(如Mail应用程序)会启动WWAHost.exe进程,或者它可能会自行开始执行,而无需在您的WindowsPC上进行任何外部输入。此进程是安全有效的Microsoft程序,是Wi
![如何修复iPhone上的闹钟不响[已解决]](https://img.php.cn/upload/article/000/465/014/168385668827544.png)
闹钟是当今大多数智能手机附带的良好功能之一。它不仅有助于让用户从睡眠中醒来,还可以用作在设定时间响铃的提醒。如今,许多iPhone用户抱怨iPhone上的闹钟无法正常响起,这给他们带来了问题。闹钟不响的潜在原因有很多,可能是因为iPhone处于静音模式,对闹钟设置进行了更改,选择低音调作为闹钟铃声,蓝牙设备已连接到iPhone等。在研究了此问题的各种原因后,我们在下面的帖子中编制了一组解决方案。初步解决方案确保iPhone未处于静音模式–当iPhone处于静音模式时,它只会使来自应用程序,通话和

你有一个紧迫的截止日期,你即将提交你的工作,那时你注意到你的Excel工作表不整洁。行和列的高度和宽度不同,大部分数据是重叠的,无法完美查看数据。根据内容手动调整行和列的高度和宽度确实会花费大量时间,当然不建议这样做。顺便说一句,当你可以通过一些简单的点击或按键来自动化整个事情时,你为什么还要考虑手动做呢?在本文中,我们详细解释了如何通过以下3种不同的解决方案轻松地在Excel工作表中自动调整行高或列宽。从现在开始,您可以选择自己喜欢的解决方案并成为Excel任务的高手!解决方案1:通过

大多数人作为备份实践将他们的文件从iPhone传输到PC/Mac,以防由于某些明显的原因而丢失。为此,他们必须通过避雷线将iPhone连接到PC/Mac。许多iPhone用户在尝试将iPhone连接到计算机以在它们之间同步文件时遇到错误1667。此错误背后有相当潜在的原因,可能是计算机或iPhone中的内部故障,闪电电缆损坏或损坏,用于同步文件的过时的iTunes应用程序,防病毒软件产生问题,不更新计算机的操作系统等。在这篇文章中,我们将向您解释如何使用以下给定的解决方案轻松有效地解决此错误。初


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Notepad++7.3.1
Easy-to-use and free code editor

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

SublimeText3 Mac version
God-level code editing software (SublimeText3)
