LogRequestParam.java 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. package me.zhengjie.aspect;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.serializer.SerializerFeature;
  4. import lombok.extern.slf4j.Slf4j;
  5. import org.apache.commons.lang3.StringUtils;
  6. import org.aspectj.lang.JoinPoint;
  7. import org.aspectj.lang.Signature;
  8. import org.aspectj.lang.annotation.AfterReturning;
  9. import org.aspectj.lang.annotation.Aspect;
  10. import org.aspectj.lang.annotation.Before;
  11. import org.aspectj.lang.annotation.Pointcut;
  12. import org.aspectj.lang.reflect.CodeSignature;
  13. import org.slf4j.MDC;
  14. import org.springframework.stereotype.Component;
  15. import org.springframework.web.context.request.RequestContextHolder;
  16. import org.springframework.web.context.request.ServletRequestAttributes;
  17. import org.springframework.web.multipart.MultipartFile;
  18. import javax.servlet.http.HttpServletRequest;
  19. import javax.servlet.http.HttpServletResponse;
  20. import java.util.HashMap;
  21. import java.util.Map;
  22. import java.util.Objects;
  23. import java.util.UUID;
  24. @Slf4j
  25. @Aspect
  26. @Component
  27. public class LogRequestParam {
  28. @Pointcut("execution(* me.zhengjie.application.*.controller..*.*(..))")
  29. public void pointCut() {
  30. }
  31. @Before(value = "pointCut()")
  32. public void doBefore(JoinPoint joinPoint) {
  33. try {
  34. ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) RequestContextHolder
  35. .getRequestAttributes();
  36. if (Objects.isNull(servletRequestAttributes)) {
  37. return;
  38. }
  39. HttpServletRequest request = servletRequestAttributes.getRequest();
  40. String ip = request.getRemoteAddr();
  41. String uri = request.getRequestURI();
  42. Object[] parameterValues = joinPoint.getArgs();
  43. int parameterValuesLength = parameterValues.length;
  44. if (parameterValuesLength == 0) {
  45. log.debug("[请求参数] - 无");
  46. return;
  47. }
  48. Signature signature = joinPoint.getSignature();
  49. if (Objects.isNull(signature)) {
  50. return;
  51. }
  52. String[] parameterNames = ((CodeSignature) signature).getParameterNames();
  53. if (Objects.isNull(parameterNames) || parameterNames.length != parameterValuesLength) {
  54. return;
  55. }
  56. Map<String, Object> params = new HashMap<>(4);
  57. for (int i = 0; i < parameterNames.length; i++) {
  58. Object o = parameterNames[i];
  59. if (o instanceof MultipartFile || o instanceof MultipartFile[] || o instanceof HttpServletRequest
  60. || o instanceof HttpServletResponse) {
  61. continue;
  62. }
  63. params.put(parameterNames[i], parameterValues[i]);
  64. }
  65. Object[] obj = { ip, uri, JSON.toJSONString(params, SerializerFeature.WriteMapNullValue) };
  66. log.info("[request] - ip: {} , requestUrl: {} ,param: {} ", obj);
  67. } catch (Exception e) {
  68. e.printStackTrace();
  69. }
  70. }
  71. @AfterReturning(returning = "result", pointcut = "pointCut() ")
  72. public void doAfterReturning(Object result) {
  73. try {
  74. ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) RequestContextHolder
  75. .getRequestAttributes();
  76. if (Objects.isNull(servletRequestAttributes)) {
  77. return;
  78. }
  79. HttpServletResponse response = servletRequestAttributes.getResponse();
  80. if (Objects.isNull(response)) {
  81. return;
  82. }
  83. int status = response.getStatus();
  84. HttpServletRequest request = servletRequestAttributes.getRequest();
  85. String uri = request.getRequestURI();
  86. Object obj[] = { status, uri, JSON.toJSONString(result, SerializerFeature.WriteMapNullValue) };
  87. log.info("[reponse] - status: {} , url:{} ,result:{}", obj);
  88. } catch (Exception e) {
  89. e.printStackTrace();
  90. }
  91. }
  92. }