sunpengfei
2025-08-01 dade4ec44ae9a42d6447589d34124a38f264100a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc.Controllers;
using Microsoft.AspNetCore.Mvc.Filters;
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Security.Claims;
using System.Text;
using System.Threading.Tasks;
 
namespace FlexJobApi.Core
{
    public class HttpActionFilter : IAsyncActionFilter
    {
        public async Task OnActionExecutionAsync(ActionExecutingContext context, ActionExecutionDelegate next)
        {
            //============== 这里是执行方法之前获取数据 ====================
            // 获取控制器、路由信息
            var actionDescriptor = context.ActionDescriptor as ControllerActionDescriptor;
 
            // 获取请求的方法
            var method = actionDescriptor!.MethodInfo;
 
            // 获取 HttpContext 和 HttpRequest 对象
            var httpContext = context.HttpContext;
            var httpRequest = httpContext.Request;
 
            // 获取客户端 Ipv4 地址
            var remoteIPv4 = httpContext.GetRemoteIpAddressToIPv4();
 
            // 获取请求的 Url 地址
            var requestUrl = httpRequest.GetRequestUrlAddress();
 
            // 获取来源 Url 地址
            var refererUrl = httpRequest.GetRefererUrlAddress();
 
            // 获取请求参数(写入日志,需序列化成字符串后存储),可以自由篡改!!!!!!
            var parameters = context.ActionArguments;
 
            // 获取操作人(必须授权访问才有值)"userId" 为你存储的 claims type,jwt 授权对应的是 payload 中存储的键名
            var userId = httpContext.User?.FindFirstValue("userId");
 
            // 请求时间
            var requestedTime = DateTimeOffset.Now;
 
            //============== 这里是执行方法之后获取数据 ====================
            var actionContext = await next();
 
            // 获取返回的结果
            var returnResult = actionContext.Result;
 
            // 判断是否请求成功,没有异常就是请求成功
            var isRequestSucceed = actionContext.Exception == null;
 
            // 获取调用堆栈信息,提供更加简单明了的调用和异常堆栈
            var stackTrace = EnhancedStackTrace.Current();
        }
    }
}