前言:
现在我们对“netcore读取配置文件”大概比较重视,同学们都想要知道一些“netcore读取配置文件”的相关内容。那么小编同时在网上网罗了一些有关“netcore读取配置文件””的相关内容,希望看官们能喜欢,朋友们一起来学习一下吧!最近.NET 5出来了,虽然最近没有使用但是还是一直关注着.NET的发展动态和相关生态。最近经常看到关于FreeSql轮子的介绍,所以想动手体验下说不定以后有项目用得着。然后在搭建框架的过程中发现一个问题,.NET CORE的依赖注入个人感觉太繁琐了,需要在构造函数里面传递感觉很不爽,准备自己手动定义Attribute,实现像java spring @Autowired注解那样实现自动装配。
当然动手之前手动搜索了下,发现相关问题已经有人提出来了,并且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工程测试一下。
一路点击下一步项目新建完毕运行,发现web api 模板默认集成了Swagger简直太方便了。
然后我们通过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读取配置文件