Swagger生成的接口需要权限验证的处理方法

本文介绍如何在Swagger中配置权限验证,以解决直接调用需要权限验证接口时出现的当前用户没有登录的问题。通过添加安全定义配置,使得可以在Swagger UI界面中手动输入token进行授权。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

通常开发API的时候需要对接口进行权限验证,而我们在使用Swagger生成接口文档界面的时候,直接调用需要权限验证的接口会提示"当前用户没有登陆"

为了解决此问题,我们需要更改一下Swagger的配置,

找到Startup文件,我们看到Swagger的配置如下:

services.AddSwaggerGen(options =>
            {
                options.SwaggerDoc("v1", new Info { Title = "YjJob API", Version = "v1" });
                options.DocInclusionPredicate((docName, description) => true);

            });

现在我们添加一下配置配置:

services.AddSwaggerGen(options =>
            {
                options.SwaggerDoc("v1", new Info { Title = "YjJob API", Version = "v1" });
                options.DocInclusionPredicate((docName, description) => true);
                options.AddSecurityDefinition("Bearer", new ApiKeyScheme
                {
                    Description = "Authorization format : Bearer {token}",
                    Name = "Authorization",
                    In = "header",
                    Type = "apiKey"
                });//api界面新增authorize按钮
            });

  修改后我们可以看到生成的Swagger UI界面新增了一个“Authorize”按钮:

点击“Authorize”按钮弹出以下界面

在value文本框中输入"Bearer "+token(登陆接口返回的access_token),然后点击“Authorize”按钮。之后再调用需要权限验证的接口就可以正常调用了

 

 

转载于:https://www.cnblogs.com/adawoo/p/8349598.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值