1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- using Microsoft.AspNetCore.Mvc.Filters;
- using System;
- using System.Collections.Generic;
- using System.IdentityModel.Tokens.Jwt;
- using System.Linq;
- using System.Security.Claims;
- using System.Threading.Tasks;
- namespace Ropin.Inspection.Api.Filters
- {
- public class AuthorExistFilterAttribute : ActionFilterAttribute
- {
- public override void OnActionExecuting(ActionExecutingContext context)
- {
- var test = context.HttpContext.Request.Path;
- string bearer = context.HttpContext.Request.Headers["Authorization"].FirstOrDefault();
- if (string.IsNullOrEmpty(bearer) || !bearer.Contains("Bearer")) return;
- string[] jwt = bearer.Split(' ');
- var tokenObj = new JwtSecurityToken(jwt[1]);
- var claimsIdentity = new ClaimsIdentity(tokenObj.Claims);
- var claimsPrincipal = new ClaimsPrincipal(claimsIdentity);
- context.HttpContext.User = claimsPrincipal;
- }
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- }
- }
|