ASP NET如何返回401而非302


前言

ASP NET MVC项目在鉴权时, 对于未登录请求会触发challenge重定向至登录界面.
然而, 在前后端分离项目中, 往往需要后端返回401而非302, 这个简单的功能实现起来却相当麻烦.
因为ASP NET MVC项目默认使用的是一个叫CookieAuthentication的中间件来实现身份认证的功能的,该中间件中会将401响应码进行特殊处理,所以导致我们无法手动返回401响应码。
我总结了两种比较简单的方法供大家参考:


1.重定向后再返回401

修改302重定向地址, 在新地址方法中直接返回401.
代码如下:

// programe.cs(Net5以下为startup.cs文件)-------------------------------
builder.Services.ConfigureApplicationCookie(options =>
{
   
    // Cookie settings
    options.Cookie
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值