using Microsoft.AspNetCore.Http; namespace DS.Module.Core.Middleware; /// /// 中间件 /// 原做为自定义授权中间件 /// 先做检查 header token的使用 /// public class JwtTokenAuthMiddleware { /// /// /// private readonly RequestDelegate _next; /// /// /// /// public JwtTokenAuthMiddleware(RequestDelegate next) { _next = next; } private void PreProceed(HttpContext next) { //Console.WriteLine($"{DateTime.Now} middleware invoke preproceed"); //... } private void PostProceed(HttpContext next) { //Console.WriteLine($"{DateTime.Now} middleware invoke postproceed"); //.... } /// /// /// /// /// public Task Invoke(HttpContext httpContext) { PreProceed(httpContext); //检测是否包含'Authorization'请求头 if (httpContext.Request.Headers.ContainsKey("Authorization-Client")) { httpContext.Request.Headers["Authorization"] = httpContext.Request.Headers["Authorization-Client"]; PostProceed(httpContext); return _next(httpContext); } // //检测是否包含'Authorization'请求头 // if (!httpContext.Request.Headers.ContainsKey("Authorization")) // { // PostProceed(httpContext); // // return _next(httpContext); // } //var tokenHeader = httpContext.Request.Headers["Authorization"].ToString(); var tokenHeader = httpContext.Request.Headers["Authorization"].ToString().Replace("Bearer ", ""); try { if (tokenHeader.Length >= 128) { //Console.WriteLine($"{DateTime.Now} token :{tokenHeader}"); // TokenModelJwt tm = JwtHelper.SerializeJwt(tokenHeader); //授权 //var claimList = new List(); //var claim = new Claim(ClaimTypes.Role, tm.Role); //claimList.Add(claim); //var identity = new ClaimsIdentity(claimList); //var principal = new ClaimsPrincipal(identity); //httpContext.User = principal; } } catch (Exception e) { Console.WriteLine($"{DateTime.Now} middleware wrong:{e.Message}"); } PostProceed(httpContext); return _next(httpContext); } }