应无所住,而生其心
排名
1
文章
860
粉丝
112
评论
163
net core webapi post传递参数
庸人 : 确实坑哈,我也是下班好了好几次,发现后台传递对象是可以的,但...
百度编辑器自定义模板
庸人 : 我建议换个编辑器,因为现在百度富文本已经停止维护了,用tinymec...
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术

net core使用jwt 三: 使用过滤器实现通用token验证,Token验证工具类

12151人阅读 2019/11/18 12:00 总访问:5179627 评论:0 收藏:0 手机
分类: .NET Core

net core使用jwt二 : 验证前台传递的token

http://www.tnblog.net/aojiancc2/article/details/2845


过滤器实现通用token验证

创建一个过滤器:CheckTokenFilter

  1. public class CheckTokenFilter : AttributeIActionFilter
  2. {
  3.     private ITokenHelper tokenHelper;
  4.     public CheckTokenFilter(ITokenHelper _tokenHelper//通过依赖注入得到数据访问层实例
  5.     {
  6.         tokenHelper = _tokenHelper;
  7.     }
  8.     public void OnActionExecuted(ActionExecutedContext context)
  9.     {
  10.     }
  11.     public void OnActionExecuting(ActionExecutingContext context)
  12.     {
  13.         ReturnModel returnModel = new ReturnModel();
  14.         //string token = context.HttpContext.Request.Query["token"];
  15.         //获取地址中的token(默认取最长的一个)
  16.         //string path = context.HttpContext.Request.Path;
  17.         //string[] strArray = path.Split('/');
  18.         //string token = strArray.OrderByDescending(a => a.Length).First();
  19.         //获取token
  20.         object tokenobj = context.ActionArguments["token"];
  21.         if (tokenobj == null)
  22.         {
  23.             returnModel.Code = 201;
  24.             returnModel.Msg = "token不能为空";
  25.             context.Result = new MyJsonResult(returnModel);
  26.             return;
  27.         }
  28.         string token = tokenobj.ToString();
  29.         string userId = "";
  30.         //验证jwt,同时取出来jwt里边的用户ID
  31.         TokenType tokenType = tokenHelper.ValidatePlus(token, a => a["iss"] == "TNBLOG" && a["aud"] == "AXJ", action => { userId = action["userId"]; });
  32.         if (tokenType == TokenType.Fail)
  33.         {
  34.             returnModel.Code = 202;
  35.             returnModel.Msg = "token验证失败";
  36.             context.Result = new MyJsonResult(returnModel);
  37.             return;
  38.         }
  39.         if (tokenType == TokenType.Expired)
  40.         {
  41.             returnModel.Code = 205;
  42.             returnModel.Msg = "token已经过期";
  43.             context.Result = new MyJsonResult(returnModel);
  44.         }
  45.         if (!string.IsNullOrEmpty(userId))
  46.         {
  47.             //给控制器传递参数(需要什么参数其实可以做成可以配置的,在过滤器里边加字段即可)
  48.             context.ActionArguments.Add("userId", Convert.ToInt32(userId));
  49.         }
  50.     }
  51. }

这里说一下context.ActionArguments,是一个键值对,可以拿到路由参数,开始不知道的时候还通过地址栏拆分去获取token,它不仅可以获取数据,还可以设置数据,然后可以在控制器里边获取,也就是说可以在过滤器中把参数传递到控制器的方法中。

我估计微软实现的就是一个中间件通过路由规则解析路由然后通过context.ActionArguments.Add这个方法设置的,所以方法上面能够直接拿到参数!


把过滤器在startup中注入一下:

  1. //注册一个
  2. ServiceFilterservices.AddScoped<CheckTokenFilter>();


需要验证token的地方,直接加上这个过滤器即可

这样的注入方式是为了方便使用依赖注入(也就是说这个过滤器里边本身也使用了依赖注入的,就是这个CheckTokenFilter),具体请参数:

http://www.tnblog.net/aojiancc2/article/details/2515


当然有些时候用过滤器验证还不是太科学,比如我们webapi中的post,delete等请求方式的时候,所以我们就可以单独封装一个工具类

代码如下:

  1. public class CheckToken
  2. {
  3.     public static ReturnModel Check(string token, ITokenHelper tokenHelper, out string userId)
  4.     {
  5.         userId = "";
  6.         ReturnModel returnModel = new ReturnModel();
  7.         if (string.IsNullOrEmpty(token))
  8.         {
  9.             returnModel.Code = 401;
  10.             returnModel.Msg = "token不能为空";
  11.             return returnModel;
  12.         }
  13.         //从依赖注入容器获取token帮助类
  14.         //ITokenHelper tokenHelper = EngineContext.Current.Resolve<ITokenHelper>();
  15.         string ruserId = "";
  16.         //验证jwt,同时取出来jwt里边的用户ID
  17.         TokenType tokenType = tokenHelper.ValidatePlus(token, a => a["iss"] == "TNBLOG" && a["aud"] == "AXJ", action => { ruserId = action["userId"]; });
  18.         if (tokenType == TokenType.Fail)
  19.         {
  20.             returnModel.Code = 402;
  21.             returnModel.Msg = "token验证失败";
  22.             return returnModel;
  23.         }
  24.         if (tokenType == TokenType.Expired)
  25.         {
  26.             returnModel.Code = 405;
  27.             returnModel.Msg = "token已经过期";
  28.             return returnModel;
  29.         }
  30.         userId = ruserId;
  31.         returnModel.Code = 200;
  32.         returnModel.Msg = "成功";
  33.         return returnModel;
  34.     }
  35. }

使用:

当然这里的参数和返回值都是我项目中比较适用的,大家可以根据实际情况进行封装




欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739。有需要软件开发,或者学习软件技术的朋友可以和我联系~(Q:815170684)

评价

net core 使用 EF Code First

下面这些内容很老了看这篇:https://www.tnblog.net/aojiancc2/article/details/5365 项目使用多层,把数据库访问...

.net mvc分部页,.net core分部页

.net分部页的三种方式第一种:@Html.Partial(&quot;_分部页&quot;)第二种:@{ Html.RenderPartial(&quot;分部页&quot;);}...

StackExchange.Redis操作redis(net core支持)

官方git开源地址https://github.com/StackExchange/StackExchange.Redis官方文档在docs里边都是官方的文档通过nuget命令下...

.net core 使用session

tip:net core 2.2后可以直接启用session了,不用在自己添加一次session依赖,本身就添加了使用nuget添加引用Microsoft.AspN...

通俗易懂,什么是.net?什么是.net Framework?什么是.net core?

朋友圈@蓝羽 看到一篇文章写的太详细太通俗了,搬过来细细看完,保证你对.NET有个新的认识理解原文地址:https://www.cnblo...

asp.net core2.0 依赖注入 AddTransient与AddScoped的区别

asp.net core主要提供了三种依赖注入的方式其中AddTransient与AddSingleton比较好区别AddTransient瞬时模式:每次都获取一...

.net core 使用 Kestrel

Kestrel介绍 Kestrel是一个基于libuv的跨平台web服务器 在.net core项目中就可以不一定要发布在iis下面了Kestrel体验可以使...

net core使用cookie

net core中可以使用传统的cookie也可以使用加密的cookieNET CORE中使用传统cookie设置:HttpContext.Response.Cookies.Appe...

net core项目结构简单分析

一:wwwrootwwwroot用于存放网站的静态资源,例如css,js,图片与相关的前端插件等lib主要是第三方的插件,例如微软默认引用...

net core使用EF之DB First

一.新建一个.net core的MVC项目新建好项目后,不能像以前一样直接在新建项中添加ef了,需要用命令在添加ef的依赖二.使用Nug...

.net core使用requestresponse下载文件下载excel等

使用request获取内容net core中request没有直接的索引方法,需要点里边的Query,或者formstringbase64=Request.Form[&quot;f...

iframe自适应高度与配合net core使用

去掉iframe边框frameborder=&quot;0&quot;去掉滚动条scrolling=&quot;no&quot;iframe 自适应高度如果内容是固定的,那么就...

net core启动报错Unable to configure HTTPS endpoint. No server certificate was specified

这是因为net core2.1默认使用的https,如果使用Kestrel web服务器的话没有安装证书就会报这个错其实仔细看他的错误提示,其...

net core使用url编码与解码操作

net core中暂时还没有以前asp.net与mvc中的server对象。获取url的编码与解码操作不能使用以前的server对象来获取。使用的是...

下载net core

官方下载地址:https://dotnet.microsoft.com/download 进来之后就可以看到最新的下载版本可以直接点击下载,也可以下载其...

net core使用依赖注入来装载EF的上下文对象

妹子情人节快乐~.net core中用了不少的依赖注入,官方文档中也推荐使用。这样使用依赖注入来管理ef对象,还是比较科学,比如...