解决:net8使用swagger的时候,调用接口401,Error: Unauthorized,无法通过验证,其实是因为没有Authorization头

1. 背景

上一篇文章讲了用net8+JWT+Swagger,尝试做一个demo,然后掉坑里,jwt能生成token,但是解析不正确,地址,这个demo还遇到一个奇怪的问题,一个demo遇到2个奇怪的问题,这运气也是没谁了。

第二个问题就更奇怪了,swagger成功添加了,也成功生成了api文档,能打开了,但是用登录接口获取到的token,添加进Authorize,调用其他接口,一直报401,Error: Unauthorized,打开开发者工具,看详细接口参数,发现根本没有加上Authorization头,为啥呢?

2. 解决方案

  • 找到net8里添加swagger里的代码,AddSecurityRequirement这个方法
            c.AddSecurityRequirement(new OpenApiSecurityRequirement
            {
                { securityScheme, new string[] { } }
            });
  • 上面有问题,对应到swagger界面,如图
    在这里插入图片描述
  • 把代码改成如下
            c.AddSecurityRequirement(new OpenApiSecurityRequirement
            {
                {
                    new OpenApiSecurityScheme
                    {
                        Reference = new OpenApiReference
                        {
                            Type = ReferenceType.SecurityScheme,
                            Id = "Bearer"
                        }
                    },
                    new string[] { }
                }
            });
  • 新代码对应的swagger界面
    在这里插入图片描述
  • 发现不一样地方了,每个接口多了个锁,这种情况,设置了Authorize,才会把Authorization头带上
  • 说到Authorization头,swagger这个Authorize里的设置,不用添加Bearer前缀,也是有点怪,可能默认添加了,这个问题不大,尝试调用一次,看看带的header的内容就知道用不用加了
    在这里插入图片描述
  • 代码我没附上全部,因为现在gpt4o太牛逼了,告诉gpt4o要修改什么方法,改成什么样,它就会帮你自动生成符合你代码风格的,不限于net8,任何语言都可以

over,enjoy!

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值