LogRequestParam.java 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  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 me.zhengjie.utils.IpAddressUtil;
  6. import org.apache.commons.lang3.StringUtils;
  7. import org.aspectj.lang.JoinPoint;
  8. import org.aspectj.lang.Signature;
  9. import org.aspectj.lang.annotation.AfterReturning;
  10. import org.aspectj.lang.annotation.Aspect;
  11. import org.aspectj.lang.annotation.Before;
  12. import org.aspectj.lang.annotation.Pointcut;
  13. import org.aspectj.lang.reflect.CodeSignature;
  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. @Slf4j
  24. @Aspect
  25. @Component
  26. public class LogRequestParam {
  27. @Pointcut("execution(* me.zhengjie.application.*.controller..*.*(..))")
  28. public void pointCut() {
  29. }
  30. @Before(value = "pointCut()")
  31. public void doBefore(JoinPoint joinPoint) {
  32. try {
  33. ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) RequestContextHolder
  34. .getRequestAttributes();
  35. if (Objects.isNull(servletRequestAttributes)) {
  36. return;
  37. }
  38. HttpServletRequest request = servletRequestAttributes.getRequest();
  39. //得到请求的ip地址
  40. String ip = IpAddressUtil.getIpAddress(request);
  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 json = JSON.toJSONString(result, SerializerFeature.WriteMapNullValue);
  86. // 打印输出的值
  87. if (StringUtils.isNotBlank(json) && json.length() < 1500) {
  88. String uri = request.getRequestURI();
  89. Object obj[] = { status, uri, json };
  90. log.info("[reponse] - status: {} , url:{} ,result:{}", obj);
  91. }
  92. } catch (Exception e) {
  93. e.printStackTrace();
  94. }
  95. }
  96. }