前言
在之前鼓捣过一次底子工程April.WebApi后,就思量把常用的类库打包做成一个公共类库,如许既方便维护也方便后续做快速开辟使用,堆栈地点:April.Util_github,April.Util_gitee,后续会继承推出基于Util的底子工程(包罗权限干系)以及假如代码天生器以为可以了也会推出,先mark不错过。
April.Util
起首,我们创建一个类库工程,固然新建之后就是删掉默认的类,我这里的版本是netstandard 2.0。
然后我们先缕下之前我做底子工程时间须要用到的通用型类库(固然后续会不绝跟进增补)。
- 通用设置 AprilConfig,AprilEnums
- 缓存干系 CacheUtil,CookieUtil,SessionUtil,RedisUtil
- 日志干系 LogUtil
- 路径哀求干系 UriUtil
- 回调干系 ResponseUtil
- 时间处置惩罚干系 DateUtil
- 验证码干系 CodeUtil
- 管理员干系 TokenUtil 整理中
- 加密干系 EncrypUtil
- Aop干系 AprilLogAttribute
- 其他扩展类
- 未完待续
我们所须要引入的NuGet包,尽大概的节省新工程须要引入的类库,如许同一类库环境,方便多工程简单摆设题目,固然也可以只引入dll文件,自己在工程中引入须要的环境类库,引入类库列表。
- log4net
- Microsoft.AspNetCore.Http.Abstractions
- Microsoft.AspNetCore.Http.Extensions
- Microsoft.AspNetCore.Mvc.Abstractions
- Microsoft.AspNetCore.Session
- Microsoft.Extensions.Caching.Memory
- Microsoft.Extensions.Configuration
- Newtonsoft.Json
- QRCoder
- StackExchange.Redis
- System.Drawing.Common
- 未完待续
固然此中大概大多在WebApi工程中已经存在或是须要引用,这里存在重复引入的大概,以是须要关注版本题目,但是现在是会根据新版本的稳固版来同一版本题目。
代码可直接从堆栈拉取,地点也在开头给出,天生工程之后我们可以得到一个dll文件,就如我前面所说,你可以引入dll文件然后在自己工程打入须要的环境包,也可以发布一个NuGet包,直接引入April.Util。
打包带走
起首,右键Util选择属性,切换到打包界面。
之后我们来发布当前类库工程,发布的过程这里就不再多说了,之后我们根据路径来找到我们发布的类库。
本地使用
假如只是本地自己用的话,也不想发布为公开,可以通过设置NuGet包的地点来获取我们自己的NuGet包。
之后,我们就可以获取我们自己的NuGet了。
发布NuGet
固然你可以选择发布到NuGet堆栈,登录NuGet官网,假如没有账号须要注册个google账号。
登录之后,在我们头像下选择上传包。
选择文件,拉到最下面(固然你可以一起看看干系的参数),然后终极的Submit,之后我们就可以看到已经上传乐成,但是检索须要等候个把小时,上传的包应该是没法删除,以是这点儿须要注意。
示例
在代码堆栈中我连带有个Simple的WebApi,内里引入了Util,包罗一些其他的通例使用方法,特别注意下入口文件Startup,固然这个工程后续也是会不绝的完满的,至于更新的力度以及代码规范度,emm,个人的气力照旧有限,渴望也能有更多的人可以一起探究。
Startup - <code> public Startup(IConfiguration configuration)
- {
- Configuration = configuration;
- AprilConfig.Configuration = configuration;
- LogUtil.InitLog();
- RedisUtil.InitRedis();
- }
-
- public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
- {
- AprilConfig.ServiceProvider = app.ApplicationServices;
-
- }</code>
复制代码
- <code>/// <summary>
- /// 示例获取
- /// </summary>
- /// <returns></returns>
- [HttpGet]
- [AprilLog]
- public ResponseDataEntity Get()
- {
- var rng = new Random();
- var data = Enumerable.Range(1, 2).Select(index => new WeatherForecast
- {
- Date = DateTime.Now.AddDays(index),
- TemperatureC = rng.Next(-20, 55),
- Summary = Summaries[rng.Next(Summaries.Length)],
- Timestamp = (int)DateUtil.ConvertToUnixTimestamp(DateTime.Now.AddDays(index))
- })
- .ToList();
- return ResponseUtil.Success("", data);
- }
- /// <summary>
- /// 验证码
- /// </summary>
- /// <param name="type">是否画线</param>
- /// <returns></returns>
- [HttpGet]
- [Route("Code")]
- public FileContentResult Code(int type)
- {
- string code = CodeUtil.GetSingleObj().CreateVerifyCode(CodeUtil.VerifyCodeType.MixVerifyCode, 6);
- //LogUtil.Info($"天生6位验证码:{code}");
- bool isAddLines = false;
- if (type == 1)
- {
- isAddLines = true;
- }
- var bitmap = CodeUtil.GetSingleObj().CreateBitmapByImgVerifyCode(code, 100, 40, isAddLines);
- code = EncryptUtil.EncryptDES(code, AprilConfig.SecurityKey);
- CookieUtil.AddString("code", code, 5);
- MemoryStream stream = new MemoryStream();
- bitmap.Save(stream, ImageFormat.Gif);
- return File(stream.ToArray(), "image/gif");
- }</code>
复制代码小结
路漫漫,小半天的整理,但是前前后后的底子工程的路淌了好几版,从netframework到net core,想做一套通用的底子工程以淘汰开辟工作量,但是这种确实没有完美无缺的,根据业务来设计才是最符合的,但是规范化这点儿不可缺失,就先从Util开始,一点点的领出来,组件化的来开辟,信任以后会越来越好,假如有哪些地方不符合,也渴望能有大佬给出指点,一人探索过河,也请包涵。 |