WebApi 后台获取token值

前台传递一个token,后台不知道怎么获取那么不是很悲剧吗。

复制代码
 $(function () {

        $.ajax({
            url: "/api/TokensTest/FirstCode",
            data: {},
            type: "Get",
            dataType: "json",
            beforeSend: function (request) {
                request.setRequestHeader("Test", "woshiyanzhengma");
            },
            success: function (data) {
                console.log(JSON.stringify(data));
            },
            error: function (err) {
                alert(err);
            }

        });

    });
复制代码

至于token 作用就不必说了,大家都知道,要不你也不会看到这篇文章。

重点来了。我们使用 AuthorizeAttribute 这个过滤器来处理。

复制代码
public class BautA : AuthorizeAttribute
    {
         
        public override void OnAuthorization(HttpActionContext actionContext)
        {
            var authorization = actionContext.Request.Headers.Authorization;


            var content = actionContext.Request.Properties["MS_HttpContext"] as HttpContextBase;
            var token = content.Request.Headers["Test"];   //这里是拿到了token 的值 也就是  “woshiyanzhengma

if (actionContext.ActionDescriptor.GetCustomAttributes<AllowAnonymousAttribute>(true).Count != 0 || actionContext.ActionDescriptor.ControllerDescriptor.GetCustomAttributes<AllowAnonymousAttribute>(true).Count != 0) { base.OnAuthorization(actionContext);//正确的访问方法 } } }
复制代码

下面是如何使用

复制代码
  [BautA]
    public class TokensTestController : ApiController
    {

        [HttpGet]
       
        public List<Company> FirstCode()
        {
            
            

            List<Company> list = new List<Company> {
                new Company{id=1,Name="探路者",Address="江苏南京",Phone="15996413689" },
                new Company{id=2,Name="探索者",Address="江苏南京",Phone="15996413689" },
                new Company{id=3,Name="开拓者",Address="江苏南京",Phone="15996413689" },
                new Company{id=4,Name="探路者",Address="江苏南京",Phone="15996413689" },
                new Company{id=5,Name="探路者",Address="江苏南京",Phone="15996413689" },
            };
             
            return list;
        }
复制代码

 

posted @   幽冥狂_七  阅读(4667)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
历史上的今天:
2016-11-11 数据库SQL优化大总结之 百万级数据库优化方案
点击右上角即可分享
微信分享提示