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.Environmentally.AlarmService.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;
- }
- //public static Guid GetUserId(this ClaimsPrincipal claimsPrincipal)
- //{
- // try
- // {
- // var claim = claimsPrincipal?.Claims.FirstOrDefault(c => c.Type == ClaimTypes.NameIdentifier);
- // if (claim == null || string.IsNullOrEmpty(claim.Value))
- // {
- // return Guid.Empty;
- // }
- // return Guid.Parse(claim.Value);
- // }
- // catch
- // {
- // return Guid.Empty;
- // }
- //}
- //public override async Task OnActionExecutionAsync(ActionExecutingContext context, ActionExecutionDelegate next)
- //{
- // var authorIdParameter = context.ActionArguments.Single(m => m.Key == "authorId");
- // Guid authorId = (Guid)authorIdParameter.Value;
- // //var isExist = await RepositoryWrapper.Author.IsExistAsync(authorId);
- // //if (!isExist)
- // //{
- // // context.Result = new NotFoundResult();
- // //}
- // await base.OnActionExecutionAsync(context, next);
- //}
- ////_httpContextAccessor为IHttpContextAccessor通过构造函数注入
- //[HttpGet("get1")]
- //[AuthorExistFilterAttribute]
- //public async Task<int> Get1()
- //{
- // var id = _httpContextAccessor.HttpContext.User.GetUserId();
- // return id;
- //}
- }
- }
|