YD_SmartSports.Api/VOL.Core/Extensions/AuthorizationResponse.cs
2025-06-06 16:00:39 +08:00

45 lines
1.8 KiB
C#
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Filters;
using System.IdentityModel.Tokens.Jwt;
using System.Net;
using System.Security.Claims;
using VOL.Core.Configuration;
using VOL.Core.Enums;
using VOL.Core.Services;
using VOL.Core.Utilities;
namespace VOL.Core.Extensions
{
public static class AuthorizationResponse
{
public static AuthorizationFilterContext FilterResult(
this AuthorizationFilterContext context,
HttpStatusCode statusCode,
string message = null)
{
context.Result = new ContentResult()
{
Content = new { message, status = false, code = (int)statusCode }.Serialize(),
ContentType = "application/json",
StatusCode = (int)statusCode
};
Logger.Info(LoggerType.ApiAuthorize, message);
return context;
}
public static AuthorizationFilterContext Unauthorized(this AuthorizationFilterContext context, string message = null)
{
return context.FilterResult(HttpStatusCode.Unauthorized, message);
}
//不通过JWT验证的直接将用户信息缓存起来
public static void AddIdentity(this AuthorizationFilterContext context, int? userId = null)
{
int _userId = userId ?? JwtHelper.GetUserId(context.HttpContext.Request.Headers[AppSetting.TokenHeaderName]);
if (_userId <= 0) return;
//将用户Id缓存到上下文(或者自定一个对象通过DI以AddScoped方式注入上下文来管理用户信息)
var claims = new Claim[] { new Claim(JwtRegisteredClaimNames.Jti, _userId.ToString()) };
context.HttpContext.User.AddIdentity(new ClaimsIdentity(claims));
}
}
}