webapi之权限验证

webapi之权限验证

一.概念:

二.demo:

1.登录时生成token:

  FormsAuthenticationTicket token = new FormsAuthenticationTicket(0, account, DateTime.Now,
                  DateTime.Now.AddHours(1), true, account,
                  FormsAuthentication.FormsCookiePath);
                loginRltViewModel.TokenStr = FormsAuthentication.Encrypt(token);

2.global文件中配置:

 GlobalConfiguration.Configure(WebApiConfig.Register);

3.WebApiConfig文件中添加到过滤器中:

  config.Filters.Add(new RequestAuthorizeAttribute());//校验token

4.创建一个类文件用来校验token,此文件必须继承ActionFilterAttribute类:

复制代码
    public class RequestAuthorizeAttribute : ActionFilterAttribute
    {

        //重写基类的验证方式,加入我们自定义的Ticket验证  前端 XHR.setRequestHeader('Authorization', 'BasicAuth ' + Ticket);
        public override void OnActionExecuting(System.Web.Http.Controllers.HttpActionContext context)
        {
            base.OnActionExecuting(context);
            if (context.ActionDescriptor.ActionName != "CheckLogin")
            {
                bool checkRlt = false;
                var authorization = context.Request.Headers.Authorization;
                if ((authorization != null) && (authorization.Parameter != null))
                {
                    checkRlt = CheckToken(authorization.Parameter);
                }
                if (!checkRlt)
                {
                    context.Response = context.Request.CreateResponse(HttpStatusCode.OK, "Err:9001");       
                }
            }
        }

        public static bool CheckToken(string token)
        {
            if (HttpRuntime.Cache[token] != null)
            {
                return true;
            }
            return false;
        }
}
复制代码

跳过验证的方法:  

比如登陆不需要验证,就可以在登陆的操作上增加[AllowAnonymous]特性

前提是需要如下代码

复制代码
var customAttributes = actionContext.ActionDescriptor.GetCustomAttributes<AllowAnonymousAttribute>().OfType<AllowAnonymousAttribute>();
            var isAllow = customAttributes.Any(x => x is AllowAnonymousAttribute);
if(isAllow)
{
//跳过
}else
{
//验证
}
复制代码

 

posted @   土豆哥  阅读(406)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
历史上的今天:
2016-08-03 VS vs2012制作安装包
点击右上角即可分享
微信分享提示