(资料图片)
引子最近不知怎么的,自从学了WebAPI(为什么是这个,而不是MVC,还不是因为MVC的Razor语法比较难学,生态不如现有的Vue等框架,webapi很好的结合了前端生态)以后,使用别人的组件一帆风顺,但是不知其意,突然很想自己实现一个基于的JWT认证服务,来好好了解一下这个内容。
起步自从Session-Cookie方案逐渐用的越来越少,JWT的使用也变得成为主流的安全方案之一,但是在.NET Core的文档(这里的.NET Core指代原来的.Net Core以及之后的版本,文档是微软的开发者文档)并没有对JWT做详细的介绍(可能是在微软看来太简单了,不值得细说),仅仅略带一提而已,实例代码更是少得可怜,根本没有什么建设性的帮助作用,更像文档工程师在水任务(但不得不说微软的Indentity框架是真的强大,Spring Security的功能基本都实现了)。纵然是费尽心机找资料,钻研文档,还是所获甚少。但是在不断的努力之下还是找到很多方案的,其中比较有用的就拿几个,我仔细研究实践后得到了这几篇文章,不求它有多大帮助,之希望它能帮更多人少走弯路。然而这几个方案大概可以分成两类:
非对称加密的JWT(常用于外部网络认证)对称加密的JWT (通常是内部系统)对比之下,非对称的JWT更安全,更符号系统的安全需求,虽然增加了解密时间,但利大于弊。可是关于非对称的JWT的文章却很少,大部分都是关于对称加密的JWT资料。对于这种情况,我自己也没有什么好的办法,直到我在看一篇文章时,在Nuget上无意找到的一个包改变了我的认知————JWT(名字粗暴直接)。当然,你直接使用.NET的扩展库也可以,这里面有一个System.IdentityModel.Tokens.Jwt可以同样使我们更快乐的创建JWT。关于这部分的内容,我也会在之后的时间单独写一篇文章来实验。另外,对于API验证测试工具,一般都是默认的Swagger,如果你喜欢更好用的工具,我推荐使用ApiFox
或者EOLink
。实施首先创建一个WebAPI项目,至于是否在启动后使用HTTPS,根据自己的需要,一般都是需要的。然后用Nuget或者Dotnet安装JWT
这个Nuget包即可开始,如果是ASP.NET Core这样需要依赖注入环境的,推荐JWT.Extensions.AspNetCore
这个包(强力推荐),可以更好的让你开始,仅仅需要基本功能的只用JWT即可。由于我这里使用的是RSA1024bit,所以需要一个HTTPS的PEM或者CRT证书做CA,各位可以自己生成一个。首先,我们需要为服务注入这个包的依赖,即使用builder.Services.AddAuthentication().AddJwt()
来添加相关依赖。那为什么是要使用这个方法呢?如果你通过对象浏览器
查看API会发现一个AddJwtDecoder
的方法,同样可以添加依赖,并且更灵活,如果反编译就发现——AddJwt
方法是对AddJwtDecoder
的某个重载的调用,后面可以调用其他方法达成同样的效果,所以推荐使用这个方法注入。
builder.Services.AddAuthentication(options =>{ options.DefaultAuthenticateScheme = JwtAuthenticationDefaults.AuthenticationScheme; options.DefaultChallengeScheme = JwtAuthenticationDefaults.AuthenticationScheme;}).AddJwt();
然后在应用认证中间件即可。
app.UseAuthentication();
完成这些工作以后,还需要创建一个用来根据用户信息生成JWT的控制器,为了防止使用HTTPGet被攻击,我这里采用了HTTPPost。根据这个包的文档,生成一个JWT字符串非常容易,只需要创建一个x509对象或者两个RSA对象作为公钥和私钥即可,我推荐使用这个包里面提供的FluentApi方式,写起来非常舒服,最后编码生成JWT,完成。
var token = JwtBuilder.Create() .WithAlgorithm(algorithm) // 加密算法 .AddClaim("Account", accountName) //添加用户信息 .AddClaim("Passwd", passwdContext) //添加用户密码 .Encode(); //编码生成jwt
[Route("api/[controller]")][ApiController]public class JwtController : ControllerBase{ private RSA publicKey = RSA.Create(); private RSA privateKey = RSA.Create(); private RS2048Algorithm? algorithm { get; set; } public JwtController() { algorithm = new RS2048Algorithm(publicKey, privateKey); } [HttpPost] public async Task CreateJwt(string accountName, string passwdContext) { return await Task.Run(() => { var token = JwtBuilder.Create() .WithAlgorithm(algorithm) .AddClaim("Account", accountName) .AddClaim("Passwd", passwdContext) .Encode(); return token; }); }}
JWT.Extensions.AspNetCore
这个包是一个集成了常用jwt操作的包,可以让你不必关心JWT的创建过程,这大大化简了我们使用JWT的过程,在一定程度上提高了生产力。如果您喜欢这个库,可以到项目主页上添加一颗星。
经过本人的亲身经历,x509在.NET6之后的类库X509Certificate2
不能直接生成私钥,需要使用该类的成员方法:public System.Security.Cryptography.X509Certificates.X509Certificate2 CopyWithPrivateKey (System.Security.Cryptography.ECDiffieHellman privateKey);
创建一个带有私钥的副本,否则会出现私钥在对象构造成功后出现NULL
的情况。如果没有特殊必要,建议直接使用Rsa
的成员方法直接生成一个Rsa对象来操作比较简便,目前这个办法还可以改进,欢迎各位留言。
标签:
引子最近不知怎么的,自从学了WebAPI(为什么是这个,而不是MVC,还不是因为MVC的Razor语法比较难学,生...
新栽的月季僵苗怎么办月季的生命力顽强,种植简单,成活率高。月季可以地栽,也可以盆栽,地栽的话要选...
[养老金最新消息]2023年养老金调整即将启动,调剂金额公布,东北三省受益更多社保网小编为您整理了最...
今天我们为大家推荐,两款胡桃木元素的家具单品,分别是曲美家居「自在」躺椅和「南轩」茶几,品味那些...
通讯员王卓王冉冉报道本报济南讯记者从济南市社会保险事业中心获悉,为着力提升群众社保服务体验,该中...
今天来聊聊关于火影忍者qq头像佐助,火影忍者qq头像的文章,现在就为大家来简单介绍下火影忍者qq头像佐...
第76届戛纳国际电影节公布入围影片名单,耿子涵导演的长片处女作《小白船》入围第76届戛纳电影节导演双...
4月18日晚,甘孜州稻城县各卡乡百合村境内发生一起森林火情,起火区域位于海拔4000余米的无人区,火场周...
中新社武汉4月19日电(记者梁婷)戴德梁行近日发布《数字经济产业集群发展白皮书》,报告显示,中国数字经...
昆山哪家医院看男科最好想做个检查,但是不知道哪家医院好,纠结,有见识。谢谢大家!很多人还不知道,...
一季度我国外贸进出口开局稳中向好如何稳中求进?---一季度的中国经济交出了可圈可点的成绩单。成绩的背...
欧洲冠军联赛1 4决赛第二回合,英超的切尔西在斯坦福桥球场主场迎战卫冕冠军皇家马德里。下半场罗德里...
今日螺纹钢HRB400E20mm现货价格为4087元 吨,较上一交易日下跌4元 吨。10合约收3927元 吨,较上一交...
1、《春》诗:莺啼岸柳弄春晴夜月明《夏》诗:香莲碧水动风凉日月长《秋》诗:秋江楚雁宿沙洲浅水流《冬...
恒生指数收跌1 37%,恒生科技指数跌2 39%;小鹏汽车跌超6%,蔚来跌超5%,理想汽车、快手、小米集团跌超4%
中国航空新闻网讯:随着民航市场的稳步恢复,叠加五一假期即将来临、旅客出行意愿激增,中国东航的国际...
为全力救治伤病员,市卫生健康委抽调精干力量,统筹全市医疗资源,紧急成立现场医疗救治指挥部,迅速组...
根据清迈动物园通报,旅泰大熊猫林惠于泰国当地时间2023年4月19日凌晨1时10分不幸去世。18日,林惠身体...
深圳燃气:深圳燃气2023年度第四期超短期融资券发行结果公告
今年以来,各项稳增长、稳就业、稳物价政策举措靠前发力,积极因素累积增多,有力助推经济高质量发展。...
X 关闭
X 关闭