龙空技术网

基于.net core Autowired注入,不用构造函数

IT点滴 1502

前言:

现在我们对“netcore读取配置文件”大概比较重视,同学们都想要知道一些“netcore读取配置文件”的相关内容。那么小编同时在网上网罗了一些有关“netcore读取配置文件””的相关内容,希望看官们能喜欢,朋友们一起来学习一下吧!

最近.NET 5出来了,虽然最近没有使用但是还是一直关注着.NET的发展动态和相关生态。最近经常看到关于FreeSql轮子的介绍,所以想动手体验下说不定以后有项目用得着。然后在搭建框架的过程中发现一个问题,.NET CORE的依赖注入个人感觉太繁琐了,需要在构造函数里面传递感觉很不爽,准备自己手动定义Attribute,实现像java spring @Autowired注解那样实现自动装配。

.NET Cloud Native

当然动手之前手动搜索了下,发现相关问题已经有人提出来了,并且github上有一个类似的开源类库NAutowired,我看了下觉得还不错(^-^哈哈,挺开心又可以偷懒了)。

NAutowired 介绍

NAutowired是一个基于.NET Core 的属性注入依赖类库,通过在需要注入的实现类上标记[Service],便可以在使用的地方通过[Autowired]自动注入,不需要通过构造函数传递。

其开源主页介绍NAutowired的理念与定位如下:

我们不做容器,我们只是NET Core Container的搬运工(在默认容器的基础上增加了一些功能)。

不要在构造函数中使用NAutowired。

由于我们与那些妖艳的第三方IoC Container有些不同,我们没有替换NetCore默认的Container,这意味着您依然可以在Startup里使用IServiceCollection将服务加入到Container并使用NAutowired还原这些依赖。

虽然有人觉得Spring风格的DI有点反模式(显式依赖),但是写起来爽。

NAutowired 使用

正好要测试下FreeSql,我们打开VS2019选择asp.net core web应用程序模板,搭建一个.NET 5的Web API工程测试一下。

.net 5 template

一路点击下一步项目新建完毕运行,发现web api 模板默认集成了Swagger简直太方便了。

.net 5 Swagger ui

然后我们通过NuGet引入FreeSql和NAutowired,引入的包如下:NAutowired、NAutowired.Core、FreeSql、FreeSql.Repository、FreeSql.Provider.MySql。

相关包安装完毕后我们在Startup.cs 初始化FreeSql并且注册为单例模式,然后通过NAutowired的AutoRegisterDependency功能,设置我们要自动注册命名空间。注册完毕后该命名空间下标记为[Service]、 [Repository]、 [Component]、 [ServiceFilter]等特性标记的类将在AutoRegisterDependency执行时被加入到容器

服务注册

接下来我们定义一个FreeSql的Repository类,用来实现用户管理的通用增删改查功能,示例代码如下(注意该Repository我们打上了[Repository]标签):

    [Repository]    public class SysUserRepository : BaseRepository<SysUser, long>    {        public SysUserRepository(IFreeSql fsql) : base(fsql,null,null){ }    }

然后我们定义业务services,示例代码如下:

    [Service]    public class SysUserService : ISysUserService    {        [Autowired]        private SysUserRepository sysUserRepository { get; set; }        public async Task<IResponseOutput> PageAsync()        {            var list = await sysUserRepository.Select           .Count(out var total)           .OrderByDescending(true, a => a.UserId)           .ToListAsync();            var data = new PageOutput<SysUser>()            {                List = list,                Total = total            };            return ResponseOutput.Ok(data);        }    }

上面代码我们可以看到,我们通过[Autowired]自动注入了SysUserRepository,不需要在构造函数中传递,是不是简洁很多(如果有很多要注入的话,构造函数参数太多太长看着不爽)

最后我们在控制层调用测试一下,示例代码如下:

        [Autowired]        private ISysUserService _sysUserService { get; set; }        [HttpGet("list")]        public async Task<object> GetUserList()        {            return await _sysUserService.PageAsync();        }

同样的我们通过[Autowired]注入ISysUserService服务,然后直接调用services里面的方法,我们通过Swagger测试下接口,数据正常返回。

接口测试结果

NAutowired 其他特性

[Service]标签可以设置服务的生命周期,默认Lifetime值为作用域 Scope,我们也可以根据自己的需要指定为特定的类型,

  //默认Lifetime值为Scoped  [Service]  //Lifetime可供选择依赖注入的生命周期  //注册为单例模式  [Service(Lifetime.Singleton)]  public class FooService {  }  [Service(implementInterface: typeof(IService))]  //注入特定的实现类到容器。这将执行services.AddScoped(typeof(IService), typeof(FooService));  public class FooService: IService {  }    //注入特定的实例    [Autowired(typeof(FooService))]    private readonly IService service;

在Filter中使用NAutowired:

1. 将Filter加到容器 :  services.AddScoped<xxxxFilter>()2. 使用 ServiceFilterAttribute注入Filter[NAutowired.Attributes.ServiceFilter(typeof(xxxxFilter))]  public class YourController : ControllerBase {    }

使用NAutowired 读取配置文件

1. 将配置文件添加到ioc容器   services.Configure<xxxxxConfig>(Configuration.GetSection("xxxNode"));//xxxNode定义在appsettings.json内2.使用时用[autowired]注入对象  [Autowired]  private IOptions<SnowflakeConfig> options { get; set; }

更多特性请查看NAutowired文档,今天的介绍就到这里,貌似文章字数有点多了,如果您觉得有用,可以点赞收藏加关注,谢谢您的支持。

标签: #netcore读取配置文件