// Admin.NET 项目的版æƒã€å•†æ ‡ã€ä¸“利和其他相关æƒåˆ©å‡å—ç›¸åº”æ³•å¾‹æ³•è§„çš„ä¿æŠ¤ã€‚ä½¿ç”¨æœ¬é¡¹ç›®åº”éµå®ˆç›¸å…³æ³•律法规和许å¯è¯çš„è¦æ±‚。 // // 本项目主è¦éµå¾ª MIT 许å¯è¯å’Œ Apache 许å¯è¯ï¼ˆç‰ˆæœ¬ 2.0)进行分å‘和使用。许å¯è¯ä½äºŽæºä»£ç æ ‘æ ¹ç›®å½•ä¸çš„ LICENSE-MIT å’Œ LICENSE-APACHE 文件。 // // ä¸å¾—利用本项目从事å±å®³å›½å®¶å®‰å…¨ã€æ‰°ä¹±ç¤¾ä¼šç§©åºã€ä¾µçŠ¯ä»–äººåˆæ³•æƒç›Šç‰æ³•å¾‹æ³•è§„ç¦æ¢çš„æ´»åЍï¼ä»»ä½•基于本项目二次开å‘è€Œäº§ç”Ÿçš„ä¸€åˆ‡æ³•å¾‹çº çº·å’Œè´£ä»»ï¼Œæˆ‘ä»¬ä¸æ‰¿æ‹…ä»»ä½•è´£ä»»ï¼ using Admin.NET.Core; using Furion.ClayObject; using Furion.DataEncryption; using Furion.FriendlyException; using Furion.JsonSerialization; using Microsoft.AspNetCore.Authentication; using Microsoft.AspNetCore.Authentication.JwtBearer; using Microsoft.AspNetCore.Http; using Microsoft.Extensions.Logging; using ReZero.SuperAPI; namespace Admin.NET.Plugin.ReZero.Service; /// <summary> /// 超级APIæŽ¥å£æ‹¦æˆªå™¨ /// </summary> public class SuperApiAop : DefaultSuperApiAop { public override async Task OnExecutingAsync(InterfaceContext aopContext) { //if (aopContext.InterfaceType == InterfaceType.DynamicApi) //{ var authenticateResult = await aopContext.HttpContext.AuthenticateAsync(JwtBearerDefaults.AuthenticationScheme); if (!authenticateResult.Succeeded) throw Oops.Oh("没æƒé™ Unauthorized"); //} var accessToken = aopContext.HttpContext.Request.Headers["Authorization"].ToString(); var (isValid, tokenData, validationResult) = JWTEncryption.Validate(accessToken.Replace("Bearer ", "")); if (!isValid) throw Oops.Oh("Token æ— æ•ˆ"); await base.OnExecutingAsync(aopContext); } public override async Task OnExecutedAsync(InterfaceContext aopContext) { InitLogContext(aopContext, LogLevel.Information); await base.OnExecutedAsync(aopContext); } public override async Task OnErrorAsync(InterfaceContext aopContext) { InitLogContext(aopContext, LogLevel.Error); await base.OnErrorAsync(aopContext); } /// <summary> /// ä¿å˜è¶…级APIæŽ¥å£æ—¥å¿— /// </summary> /// <param name="aopContext"></param> /// <param name="logLevel"></param> private void InitLogContext(InterfaceContext aopContext, LogLevel logLevel) { var api = aopContext.InterfaceInfo; var context = aopContext.HttpContext; var accessToken = context.Request.Headers["Authorization"].ToString(); if (!string.IsNullOrWhiteSpace(accessToken) && accessToken.StartsWith("Bearer ")) accessToken = accessToken.Replace("Bearer ", ""); var claims = JWTEncryption.ReadJwtToken(accessToken)?.Claims; var userName = claims?.FirstOrDefault(u => u.Type == ClaimConst.Account)?.Value; var realName = claims?.FirstOrDefault(u => u.Type == ClaimConst.RealName)?.Value; var paths = api.Url.Split('/'); var actionName = paths[paths.Length - 1]; var apiInfo = Clay.Object(new { requestUrl = api.Url, httpMethod = api.HttpMethod, displayTitle = api.Name, actionTypeName = actionName, controllerName = aopContext.InterfaceType == InterfaceType.DynamicApi ? $"ReZero动æ€-{api.GroupName}" : $"ReZero系统-{api.GroupName}", remoteIPv4 = context.GetRemoteIpAddressToIPv4(), userAgent = context.Request.Headers["User-Agent"], returnInformation = new { httpStatusCode = context.Response.StatusCode, }, authorizationClaims = new[] { new { type = ClaimConst.Account, value = userName }, new { type = ClaimConst.RealName, value = realName }, }, exception = aopContext.Exception == null ? null : JSON.Serialize(aopContext.Exception) }); var logger = App.GetRequiredService<ILoggerFactory>().CreateLogger(CommonConst.SysLogCategoryName); using var scope = logger.ScopeContext(new Dictionary<object, object> { { "loggingMonitor", apiInfo.ToString() } }); logger.Log(logLevel, "ReZero超级APIæŽ¥å£æ—¥å¿—"); } }