{"id":4408,"date":"2018-09-27T19:52:11","date_gmt":"2018-09-27T11:52:11","guid":{"rendered":"https:\/\/xinchewhd.com.cn\/index.php\/spring-boot\/spring-boot%e5%85%a5%e9%97%a8%ef%bc%9a%e4%bd%bf%e7%94%a8aop%e5%ae%9e%e7%8e%b0%e6%8b%a6%e6%88%aa%e5%99%a8\/"},"modified":"2018-09-27T19:52:11","modified_gmt":"2018-09-27T11:52:11","slug":"spring-boot%e5%85%a5%e9%97%a8%ef%bc%9a%e4%bd%bf%e7%94%a8aop%e5%ae%9e%e7%8e%b0%e6%8b%a6%e6%88%aa%e5%99%a8","status":"publish","type":"post","link":"https:\/\/xinchewhd.com.cn\/index.php\/spring-boot\/spring-boot%e5%85%a5%e9%97%a8%ef%bc%9a%e4%bd%bf%e7%94%a8aop%e5%ae%9e%e7%8e%b0%e6%8b%a6%e6%88%aa%e5%99%a8\/","title":{"rendered":"Spring Boot\u5165\u95e8\uff1a\u4f7f\u7528AOP\u5b9e\u73b0\u62e6\u622a\u5668"},"content":{"rendered":"<div class='wxsyncmain'>\n<p style=\"text-indent:28px;\"><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u5f53\u6211\u4eec\u4f7f\u7528<\/span><span style=\"font-size:19px;\">Spring Boot<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u53d1\u5e03\u540e\u53f0\u63a5\u53e3\u65f6\uff0c\u5982\u679c\u591a\u4e2a\u63a5\u53e3\u5b58\u5728\u76f8\u540c\u7684\u64cd\u4f5c\uff0c\u6bd4\u5982\u5bf9\u53c2\u6570\u8fdb\u884c\u975e\u7a7a\u6821\u9a8c\u6216\u9a8c\u7b7e\u3002\u8fd9\u4e9b\u64cd\u4f5c\u90fd\u662f\u5728\u5177\u4f53\u4e1a\u52a1\u4ee3\u7801\u4e4b\u524d\uff0c\u5982\u679c\u6211\u4eec\u6bcf\u4e2a\u63a5\u53e3\u90fd\u8fdb\u884c\u72ec\u7acb\u7f16\u7801\uff0c\u5373\u4f7f\u6211\u4eec\u5c06\u9a8c\u7b7e\u64cd\u4f5c\u5c01\u88c5\u6210\u65b9\u6cd5\uff0c\u4e5f\u4f1a\u6709\u5927\u91cf\u91cd\u590d\u4ee3\u7801\u3002\u8fd9\u65f6\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528<\/span><span style=\"font-size:19px;\">AOP<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u5b9e\u73b0\u62e6\u622a\u5668\uff0c\u5bf9\u53c2\u6570\u8fdb\u884c\u975e\u7a7a\u6821\u9a8c\u6216\u9a8c\u7b7e\u3002<\/span><\/p>\n<h1><span style=\"font-size:32px;line-height:240%;\">1<\/span><span style=\"font-size:32px;line-height:240%;font-family:\u5b8b\u4f53;\">\u3001\u5f15\u5305<\/span><\/h1>\n<p style=\"text-indent:28px;\"><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u9996\u5148\u5f15\u5305\u3002<\/span><\/p>\n<p style=\"text-align:left;background:#2B2B2B;\"><span style=\"font-size:15px;color:#E8BF6A;\">&lt;dependency&gt; &lt;groupId&gt;<\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.aspectj<\/span><span style=\"font-size:15px;color:#E8BF6A;\">&lt;\/groupId&gt; &lt;artifactId&gt;<\/span><span style=\"font-size:15px;color:#A9B7C6;\">aspectjweaver<\/span><span style=\"font-size:15px;color:#E8BF6A;\">&lt;\/artifactId&gt; &lt;version&gt;<\/span><span style=\"font-size:15px;color:#A9B7C6;\">1.9.1<\/span><span style=\"font-size:15px;color:#E8BF6A;\">&lt;\/version&gt;&lt;\/dependency&gt;<\/span><\/p>\n<p style=\"text-indent:28px;\"><span style=\"font-size:19px;\">aspectjweaver<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u7528\u4e8e\u5f15\u5165<\/span><span style=\"font-size:19px;\">AOP<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u7684\u76f8\u5173\u7684\u6ce8\u89e3\uff0c\u5982<\/span><span style=\"font-size:19px;\">@Aspect<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u3001<\/span><span style=\"font-size:19px;\">@Pointcut<\/span><\/p>\n<h1><span style=\"font-size:32px;line-height:240%;\">2<\/span><span style=\"font-size:32px;line-height:240%;font-family:\u5b8b\u4f53;\">\u3001\u81ea\u5b9a\u4e49\u5f02\u5e38\u7c7b<\/span><\/h1>\n<p><span style=\"font-size:15px;\"> <\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u65b0\u5efa<\/span><span style=\"font-size:19px;\">GlobalException<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u5f02\u5e38\u7c7b\uff0c\u7528\u4e8e\u6355\u6349\u5168\u5c40\u5f02\u5e38\u3002<\/span><\/p>\n<p style=\"text-align:left;background:#2B2B2B;\"><span style=\"font-size:15px;color:#CC7832;\">public class <\/span><span style=\"font-size:15px;color:#A9B7C6;\">GlobalException <\/span><span style=\"font-size:15px;color:#CC7832;\">extends <\/span><span style=\"font-size:15px;color:#A9B7C6;\">Exception { <\/span><span style=\"font-size:15px;color:#CC7832;\">private static final long <\/span><em><span style=\"font-size:15px;color:#9876AA;\">serialVersionUID <\/span><\/em><span style=\"font-size:15px;color:#A9B7C6;\">= -<\/span><span style=\"font-size:15px;color:#6897BB;\">238091758285157331L<\/span><span style=\"font-size:15px;color:#CC7832;\">; private <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String <\/span><span style=\"font-size:15px;color:#9876AA;\">code<\/span><span style=\"font-size:15px;color:#CC7832;\">; private <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String <\/span><span style=\"font-size:15px;color:#9876AA;\">message<\/span><span style=\"font-size:15px;color:#CC7832;\">; public <\/span><span style=\"font-size:15px;color:#FFC66D;\">GlobalException<\/span><span style=\"font-size:15px;color:#A9B7C6;\">() { <\/span><span style=\"font-size:15px;color:#CC7832;\">super<\/span><span style=\"font-size:15px;color:#A9B7C6;\">()<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">} <\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#FFC66D;\">GlobalException<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(String message) { <\/span><span style=\"font-size:15px;color:#CC7832;\">super<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(message)<\/span><span style=\"font-size:15px;color:#CC7832;\">; this<\/span><span style=\"font-size:15px;color:#A9B7C6;\">.<\/span><span style=\"font-size:15px;color:#9876AA;\">message <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= message<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">} <\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#FFC66D;\">GlobalException<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(String code<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String message) { <\/span><span style=\"font-size:15px;color:#CC7832;\">super<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(code + <\/span><span style=\"font-size:15px;color:#6A8759;\">\": \" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ message)<\/span><span style=\"font-size:15px;color:#CC7832;\">; this<\/span><span style=\"font-size:15px;color:#A9B7C6;\">.<\/span><span style=\"font-size:15px;color:#9876AA;\">code <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= code<\/span><span style=\"font-size:15px;color:#CC7832;\">; this<\/span><span style=\"font-size:15px;color:#A9B7C6;\">.<\/span><span style=\"font-size:15px;color:#9876AA;\">message <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= message<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">} <\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#FFC66D;\">GlobalException<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(String message<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#A9B7C6;\">Throwable throwable) { <\/span><span style=\"font-size:15px;color:#CC7832;\">super<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(message<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#A9B7C6;\">throwable)<\/span><span style=\"font-size:15px;color:#CC7832;\">; this<\/span><span style=\"font-size:15px;color:#A9B7C6;\">.<\/span><span style=\"font-size:15px;color:#9876AA;\">message <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= message<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">} <\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#FFC66D;\">GlobalException<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(Throwable throwable) { <\/span><span style=\"font-size:15px;color:#CC7832;\">super<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(throwable)<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">} <\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String <\/span><span style=\"font-size:15px;color:#FFC66D;\">getCode<\/span><span style=\"font-size:15px;color:#A9B7C6;\">() { <\/span><span style=\"font-size:15px;color:#CC7832;\">return <\/span><span style=\"font-size:15px;color:#9876AA;\">code<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">} <\/span><span style=\"font-size:15px;color:#BBB529;\">@Override <\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String <\/span><span style=\"font-size:15px;color:#FFC66D;\">getMessage<\/span><span style=\"font-size:15px;color:#A9B7C6;\">() { <\/span><span style=\"font-size:15px;color:#CC7832;\">return <\/span><span style=\"font-size:15px;color:#9876AA;\">message<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">} <\/span><span style=\"font-size:15px;color:#BBB529;\">@Override <\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String <\/span><span style=\"font-size:15px;color:#FFC66D;\">toString<\/span><span style=\"font-size:15px;color:#A9B7C6;\">() { <\/span><span style=\"font-size:15px;color:#CC7832;\">return <\/span><span style=\"font-size:15px;color:#9876AA;\">code <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ <\/span><span style=\"font-size:15px;color:#6A8759;\">\": \" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ <\/span><span style=\"font-size:15px;color:#9876AA;\">message<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">}}<\/span><\/p>\n<h1><span style=\"font-size:32px;line-height:240%;\">3<\/span><span style=\"font-size:32px;line-height:240%;font-family:\u5b8b\u4f53;\">\u3001\u5168\u5c40\u5f02\u5e38\u5904\u7406\u5668<\/span><\/h1>\n<p><span style=\"font-size:15px;\"> <\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u65b0\u5efa\u5168\u5c40\u5f02\u5e38\u5904\u7406\u5668\uff0c\u7528\u6237\u5904\u7406\u6355\u6349\u5230\u7684\u5f02\u5e38\u3002<\/span><\/p>\n<p style=\"text-align:left;background:#2B2B2B;\"><span style=\"font-size:15px;color:#CC7832;\">import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">com.alibaba.fastjson.JSONObject<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.springframework.web.bind.annotation.<\/span><span style=\"font-size:15px;color:#BBB529;\">ExceptionHandler<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.springframework.web.bind.annotation.<\/span><span style=\"font-size:15px;color:#BBB529;\">ResponseBody<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.springframework.web.bind.annotation.<\/span><span style=\"font-size:15px;color:#BBB529;\">RestControllerAdvice<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">javax.servlet.http.HttpServletRequest<\/span><span style=\"font-size:15px;color:#CC7832;\">;<\/span><em><span style=\"font-size:15px;color:#629755;\"><\/span><\/em><span style=\"font-size:15px;color:#BBB529;\">@RestControllerAdvice<\/span><span style=\"font-size:15px;color:#CC7832;\">public class <\/span><span style=\"font-size:15px;color:#A9B7C6;\">GlobalExceptionHandler { <\/span><span style=\"font-size:15px;color:#BBB529;\">@ExceptionHandler<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><span style=\"font-size:15px;color:#D0D0FF;\">value <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= Exception.<\/span><span style=\"font-size:15px;color:#CC7832;\">class<\/span><span style=\"font-size:15px;color:#A9B7C6;\">) <\/span><span style=\"font-size:15px;color:#BBB529;\">@ResponseBody <\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#A9B7C6;\">JSONObject <\/span><span style=\"font-size:15px;color:#FFC66D;\">exceptionHandler<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(HttpServletRequestrequest<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#A9B7C6;\">Exception e) { <\/span><span style=\"font-size:15px;color:#CC7832;\">return <\/span><span style=\"font-size:15px;color:#A9B7C6;\">ReturnMessage.<em>createReturnMessage<\/em>(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"4000\"<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#A9B7C6;\">e.getMessage())<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">}}<\/span><\/p>\n<h1><span style=\"font-size:32px;line-height:240%;\">4<\/span><span style=\"font-size:32px;line-height:240%;font-family:\u5b8b\u4f53;\">\u3001\u81ea\u5b9a\u4e49<\/span><span style=\"font-size:32px;line-height:240%;\">AOP<\/span><\/h1>\n<p><span style=\"font-size:15px;\"> <\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u81ea\u5b9a\u4e49<\/span><span style=\"font-size:19px;\">AOP<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff0c\u5bf9\u63a5\u53e3\u5165\u53c2\u8fdb\u884c\u975e\u7a7a\u6821\u9a8c\u548c\u9a8c\u7b7e\uff1b\u5e76\u5bf9\u63a5\u53e3\u8fd4\u56de\u53c2\u6570\u8fdb\u884c\u7b7e\u540d\u3002<\/span><\/p>\n<p style=\"text-align:left;background:#2B2B2B;\"><span style=\"font-size:15px;color:#CC7832;\">import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">cn.wbnull.springbootdemo.boot.GlobalException<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">cn.wbnull.springbootdemo.constant.DemoConstants<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">cn.wbnull.springbootdemo.util.JSONUtils<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">cn.wbnull.springbootdemo.util.StringUtils<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">com.alibaba.fastjson.JSONObject<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.apache.commons.codec.digest.DigestUtils<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.aspectj.lang.JoinPoint<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.aspectj.lang.annotation.<\/span><span style=\"font-size:15px;color:#BBB529;\">AfterReturning<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.aspectj.lang.annotation.<\/span><span style=\"font-size:15px;color:#BBB529;\">Aspect<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.aspectj.lang.annotation.<\/span><span style=\"font-size:15px;color:#BBB529;\">Before<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.aspectj.lang.annotation.<\/span><span style=\"font-size:15px;color:#BBB529;\">Pointcut<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.springframework.stereotype.<\/span><span style=\"font-size:15px;color:#BBB529;\">Component<\/span><span style=\"font-size:15px;color:#CC7832;\">;<\/span><em><span style=\"font-size:15px;color:#629755;\"><\/span><\/em><span style=\"font-size:15px;color:#BBB529;\">@Aspect@Component<\/span><span style=\"font-size:15px;color:#CC7832;\">public class <\/span><span style=\"font-size:15px;color:#A9B7C6;\">SignAop { <\/span><em><span style=\"font-size:15px;color:#629755;\">\/** * <\/span><\/em><em><span style=\"font-size:15px;font-family:\u5b8b\u4f53;color:#629755;\">\u58f0\u660e\u4e00\u4e2a\u5207\u5165\u70b9\uff0c\u8303\u56f4\u4e3a<\/span><\/em><em><span style=\"font-size:15px;color:#629755;\">controller<\/span><\/em><em><span style=\"font-size:15px;font-family:\u5b8b\u4f53;color:#629755;\">\u5305\u4e0b\u6240\u6709\u7684\u7c7b<\/span><\/em><em><span style=\"font-size:15px;color:#629755;\"> <\/span><\/em><em><span style=\"font-size:15px;color:#629755;\">* <\/span><\/em><em><span style=\"font-size:15px;font-family:\u5b8b\u4f53;color:#629755;\">\u6ce8\uff1a\u4f5c\u4e3a\u5207\u5165\u70b9\u7b7e\u540d\u7684\u65b9\u6cd5\u5fc5\u987b\u8fd4\u56de<\/span><\/em><em><span style=\"font-size:15px;color:#629755;\">void<\/span><\/em><em><span style=\"font-size:15px;font-family:\u5b8b\u4f53;color:#629755;\">\u7c7b\u578b<\/span><\/em><em><span style=\"font-size:15px;color:#629755;\"> <\/span><\/em><em><span style=\"font-size:15px;color:#629755;\">*\/ <\/span><\/em><span style=\"font-size:15px;color:#BBB529;\">@Pointcut<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"execution(public *cn.wbnull.springbootdemo.controller.*.*(..))\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">) <\/span><span style=\"font-size:15px;color:#CC7832;\">private void <\/span><span style=\"font-size:15px;color:#FFC66D;\">signAop<\/span><span style=\"font-size:15px;color:#A9B7C6;\">() { } <\/span><em><span style=\"font-size:15px;color:#629755;\">\/** * <\/span><\/em><em><span style=\"font-size:15px;font-family:\u5b8b\u4f53;color:#629755;\">\u524d\u7f6e\u901a\u77e5\uff1a\u5728\u67d0\u8fde\u63a5\u70b9\u4e4b\u524d\u6267\u884c\u7684\u901a\u77e5\uff0c\u4f46\u8fd9\u4e2a\u901a\u77e5\u4e0d\u80fd\u963b\u6b62\u8fde\u63a5\u70b9\u4e4b\u524d\u7684\u6267\u884c\u6d41\u7a0b\uff08\u9664\u975e\u5b83\u629b\u51fa\u4e00\u4e2a\u5f02\u5e38\uff09<\/span><\/em><em><span style=\"font-size:15px;color:#629755;\"> <\/span><\/em><em><span style=\"font-size:15px;color:#629755;\">* * <strong>@param <\/strong><\/span><\/em><em><span style=\"font-size:15px;color:#8A653B;\">joinPoint <\/span><\/em><em><span style=\"font-size:15px;color:#629755;\">* <strong>@throws <\/strong>Exception *\/ <\/span><\/em><span style=\"font-size:15px;color:#BBB529;\">@Before<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"signAop()\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">) <\/span><span style=\"font-size:15px;color:#CC7832;\">public void <\/span><span style=\"font-size:15px;color:#FFC66D;\">doBefore<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(JoinPoint joinPoint) <\/span><span style=\"font-size:15px;color:#CC7832;\">throws <\/span><span style=\"font-size:15px;color:#A9B7C6;\">Exception { Object[] objects =joinPoint.getArgs()<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String sign = objects[<\/span><span style=\"font-size:15px;color:#6897BB;\">0<\/span><span style=\"font-size:15px;color:#A9B7C6;\">].toString()<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String timestamp = objects[<\/span><span style=\"font-size:15px;color:#6897BB;\">1<\/span><span style=\"font-size:15px;color:#A9B7C6;\">].toString()<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String data = objects[<\/span><span style=\"font-size:15px;color:#6897BB;\">2<\/span><span style=\"font-size:15px;color:#A9B7C6;\">].toString()<\/span><span style=\"font-size:15px;color:#CC7832;\">; if <\/span><span style=\"font-size:15px;color:#A9B7C6;\">(StringUtils.<em>isEmpty<\/em>(sign) || StringUtils.<em>isEmpty<\/em>(timestamp)|| StringUtils.<em>isEmpty<\/em>(data)){ <\/span><span style=\"font-size:15px;color:#CC7832;\">throw new <\/span><span style=\"font-size:15px;color:#A9B7C6;\">GlobalException(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"sign or timestamp or data is null\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">} String md5String = <\/span><span style=\"font-size:15px;color:#6A8759;\">\"data=\" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ data + <\/span><span style=\"font-size:15px;color:#6A8759;\">\"&amp;key=1234567890&amp;timestamp=\" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ timestamp<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String signNow = DigestUtils.<em>md5Hex<\/em>(md5String)<\/span><span style=\"font-size:15px;color:#CC7832;\">; if <\/span><span style=\"font-size:15px;color:#A9B7C6;\">(!sign.equalsIgnoreCase(signNow)) { <\/span><span style=\"font-size:15px;color:#CC7832;\">throw new <\/span><span style=\"font-size:15px;color:#A9B7C6;\">GlobalException(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"sign is error\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">} } <\/span><em><span style=\"font-size:15px;color:#629755;\">\/** * <\/span><\/em><em><span style=\"font-size:15px;font-family:\u5b8b\u4f53;color:#629755;\">\u540e\u7f6e\u901a\u77e5\uff1a\u5728\u67d0\u8fde\u63a5\u70b9\u6b63\u5e38\u5b8c\u6210\u540e\u6267\u884c\u7684\u901a\u77e5\uff0c\u901a\u5e38\u5728\u4e00\u4e2a\u5339\u914d\u7684\u65b9\u6cd5\u8fd4\u56de\u7684\u65f6\u5019\u6267\u884c<\/span><\/em><em><span style=\"font-size:15px;color:#629755;\"> <\/span><\/em><em><span style=\"font-size:15px;color:#629755;\">* * <strong>@param <\/strong><\/span><\/em><em><span style=\"font-size:15px;color:#8A653B;\">joinPoint <\/span><\/em><em><span style=\"font-size:15px;color:#629755;\">* <strong>@param <\/strong><\/span><\/em><em><span style=\"font-size:15px;color:#8A653B;\">params <\/span><\/em><em><span style=\"font-size:15px;color:#629755;\">* <strong>@return <\/strong>*\/ <\/span><\/em><span style=\"font-size:15px;color:#BBB529;\">@AfterReturning<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><span style=\"font-size:15px;color:#D0D0FF;\">value <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= <\/span><span style=\"font-size:15px;color:#6A8759;\">\"signAop()\"<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#D0D0FF;\">returning <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= <\/span><span style=\"font-size:15px;color:#6A8759;\">\"params\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">) <\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#A9B7C6;\">JSONObject <\/span><span style=\"font-size:15px;color:#FFC66D;\">doAfterReturning<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(JoinPointjoinPoint<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#A9B7C6;\">JSONObject params) { String data = JSONUtils.<em>getJSONString<\/em>(params<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#A9B7C6;\">DemoConstants.<\/span><em><span style=\"font-size:15px;color:#9876AA;\">DATA<\/span><\/em><span style=\"font-size:15px;color:#A9B7C6;\">)<\/span><span style=\"font-size:15px;color:#CC7832;\">; long <\/span><span style=\"font-size:15px;color:#A9B7C6;\">timestamp = System.<em>currentTimeMillis<\/em>() \/ <\/span><span style=\"font-size:15px;color:#6897BB;\">1000<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String md5String = <\/span><span style=\"font-size:15px;color:#6A8759;\">\"data=\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ data + <\/span><span style=\"font-size:15px;color:#6A8759;\">\"&amp;key=1234567890&amp;timestamp=\" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ timestamp<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String sign = DigestUtils.<em>md5Hex<\/em>(md5String)<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">params.put(DemoConstants.<\/span><em><span style=\"font-size:15px;color:#9876AA;\">TIMESTAMP<\/span><\/em><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#A9B7C6;\">timestamp)<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">params.put(DemoConstants.<\/span><em><span style=\"font-size:15px;color:#9876AA;\">SIGN<\/span><\/em><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#A9B7C6;\">sign)<\/span><span style=\"font-size:15px;color:#CC7832;\">; return <\/span><span style=\"font-size:15px;color:#A9B7C6;\">params<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">}}<\/span><\/p>\n<h1><span style=\"font-size:32px;line-height:240%;\">5<\/span><span style=\"font-size:32px;line-height:240%;font-family:\u5b8b\u4f53;\">\u3001\u63a7\u5236\u5668<\/span><\/h1>\n<p><span style=\"font-size:15px;\"> <\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u65b0\u5efa\u767b\u5f55\u63a5\u53e3\u63a7\u5236\u5668<\/span><span style=\"font-size:19px;\">LoginController<\/span><\/p>\n<p style=\"text-align:left;background:#2B2B2B;\"><span style=\"font-size:15px;color:#CC7832;\">import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">com.alibaba.fastjson.JSONObject<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.springframework.context.annotation.<\/span><span style=\"font-size:15px;color:#BBB529;\">Scope<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.springframework.web.bind.annotation.<\/span><span style=\"font-size:15px;color:#BBB529;\">PostMapping<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.springframework.web.bind.annotation.<\/span><span style=\"font-size:15px;color:#BBB529;\">RequestParam<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.springframework.web.bind.annotation.<\/span><span style=\"font-size:15px;color:#BBB529;\">RestController<\/span><span style=\"font-size:15px;color:#CC7832;\">;<\/span><em><span style=\"font-size:15px;color:#629755;\"><\/span><\/em><span style=\"font-size:15px;color:#BBB529;\">@RestController@Scope<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"prototype\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)<\/span><span style=\"font-size:15px;color:#CC7832;\">public class <\/span><span style=\"font-size:15px;color:#A9B7C6;\">LoginController <\/span><span style=\"font-size:15px;color:#CC7832;\">extends <\/span><span style=\"font-size:15px;color:#A9B7C6;\">BaseController { <\/span><span style=\"font-size:15px;color:#BBB529;\">@PostMapping<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><span style=\"font-size:15px;color:#D0D0FF;\">value <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= <\/span><span style=\"font-size:15px;color:#6A8759;\">\"\/login\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">) <\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#A9B7C6;\">JSONObject <\/span><span style=\"font-size:15px;color:#FFC66D;\">login<\/span><span style=\"font-size:15px;color:#A9B7C6;\">( <\/span><span style=\"font-size:15px;color:#BBB529;\">@RequestParam<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><span style=\"font-size:15px;color:#D0D0FF;\">value <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= <\/span><span style=\"font-size:15px;color:#6A8759;\">\"sign\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">) String sign<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#BBB529;\">@RequestParam<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><span style=\"font-size:15px;color:#D0D0FF;\">value <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= <\/span><span style=\"font-size:15px;color:#6A8759;\">\"timestamp\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">) Stringtimestamp<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#BBB529;\">@RequestParam<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><span style=\"font-size:15px;color:#D0D0FF;\">value <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= <\/span><span style=\"font-size:15px;color:#6A8759;\">\"data\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">) String data ) <\/span><span style=\"font-size:15px;color:#CC7832;\">throws <\/span><span style=\"font-size:15px;color:#A9B7C6;\">Exception { <\/span><span style=\"font-size:15px;color:#CC7832;\">return <\/span><span style=\"font-size:15px;color:#9876AA;\">baseService<\/span><span style=\"font-size:15px;color:#A9B7C6;\">.login(data)<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">}}<\/span><\/p>\n<h1><span style=\"font-size:32px;line-height:240%;\">6<\/span><span style=\"font-size:32px;line-height:240%;font-family:\u5b8b\u4f53;\">\u3001\u670d\u52a1\u7c7b<\/span><\/h1>\n<p><span style=\"font-size:19px;\"> <\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u65b0\u5efa\u767b\u5f55\u63a5\u53e3\u670d\u52a1\u7c7b<\/span><span style=\"font-size:19px;\">LoginService<\/span><\/p>\n<pre style=\"background:#2B2B2B;\"><span style=\"font-size:15px;color:#CC7832;\">import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">cn.wbnull.springbootdemo.util.JSONUtils<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">cn.wbnull.springbootdemo.util.LoggerUtils<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">com.alibaba.fastjson.JSONObject<\/span><span style=\"font-size:15px;color:#CC7832;\">;import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.springframework.stereotype.<\/span><span style=\"font-size:15px;color:#BBB529;\">Service<\/span><span style=\"font-size:15px;color:#CC7832;\">;<\/span><em><span style=\"font-size:15px;color:#629755;\"><\/span><\/em><span style=\"font-size:15px;color:#BBB529;\">@Service<\/span><span style=\"font-size:15px;color:#CC7832;\">public class <\/span><span style=\"font-size:15px;color:#A9B7C6;\">LoginService { <\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#A9B7C6;\">JSONObject <\/span><span style=\"font-size:15px;color:#FFC66D;\">login<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(Object data) <\/span><span style=\"font-size:15px;color:#CC7832;\">throws <\/span><span style=\"font-size:15px;color:#A9B7C6;\">Exception { JSONObject responseParams = <\/span><span style=\"font-size:15px;color:#CC7832;\">new <\/span><span style=\"font-size:15px;color:#A9B7C6;\">JSONObject()<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">JSONObject requestParams = JSONObject.<em>parseObject<\/em>(data.toString())<\/span><span style=\"font-size:15px;color:#CC7832;\">; if <\/span><span style=\"font-size:15px;color:#A9B7C6;\">(JSONUtils.<span style=\"background:#344134;\">getJSONString<\/span>(requestParams<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#6A8759;\">\"username\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">).equalsIgnoreCase( JSONUtils.<span style=\"background:#344134;\">getJSONString<\/span>(requestParams<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#6A8759;\">\"password\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">))) { responseParams.put(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"code\"<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#6A8759;\">\"1000\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">responseParams.put(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"message\"<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#6A8759;\">\"SUCCESS\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">} <\/span><span style=\"font-size:15px;color:#CC7832;\">else <\/span><span style=\"font-size:15px;color:#A9B7C6;\">{ responseParams.put(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"code\"<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#6A8759;\">\"2000\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">responseParams.put(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"message\"<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#6A8759;\">\"FAIL\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">}<\/span><span style=\"font-size:15px;color:#CC7832;\"> return <\/span><span style=\"font-size:15px;color:#A9B7C6;\">responseParams<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">}}<\/span><\/pre>\n<h1><span style=\"font-size:32px;line-height:240%;\">7<\/span><span style=\"font-size:32px;line-height:240%;font-family:\u5b8b\u4f53;\">\u3001\u6d4b\u8bd5<\/span><\/h1>\n<p style=\"text-indent:28px;\"><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff08<\/span><span style=\"font-size:19px;\">1<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff09\u3001\u5f53\u4f20\u5165\u53c2\u6570\u7f3a\u5c11\u65f6\uff0c\u63a5\u53e3\u81ea\u52a8\u63d0\u793a\uff08\u672a\u8fdb\u5165<\/span><span style=\"font-size:19px;\">AOP<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff09\uff1a<\/span><\/p>\n<p style=\"text-align: center;\"><img decoding=\"async\" class=\"lazyload\"class=\"\" data-copyright=\"0\" data-ratio=\"0.575812274368231\" data-s=\"300,640\"  data-type=\"png\" data-w=\"554\" style=\"\" data-src=\"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153501460.jpg\" src=\"https:\/\/s.nmxc.ltd\/sakurairo_vision\/@2.6\/load_svg\/inload.svg\" onerror=\"imgError(this)\"  \/><noscript><img decoding=\"async\" class=\"\" data-copyright=\"0\" data-ratio=\"0.575812274368231\" data-s=\"300,640\"  data-type=\"png\" data-w=\"554\" style=\"\" src=\"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153501460.jpg\"  \/><\/noscript><\/p>\n<p><span style=\"font-size:15px;\"><\/span><\/p>\n<p style=\"text-indent:28px;\"><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff08<\/span><span style=\"font-size:19px;\">2<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff09\u3001\u5f53\u4f20\u5165\u53c2\u6570\u6b63\u5e38\uff0c\u4f46\u5b58\u5728\u67d0\u53c2\u6570\u4e3a\u7a7a\u65f6\uff0c<\/span><span style=\"font-size:19px;\">AOP<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u6821\u9a8c\u53c2\u6570\u662f\u5426\u4e3a\u7a7a\uff1a<\/span><\/p>\n<p style=\"text-align: center;\"><img decoding=\"async\" class=\"lazyload\"class=\"\" data-copyright=\"0\" data-ratio=\"0.4963898916967509\" data-s=\"300,640\"  data-type=\"png\" data-w=\"554\" style=\"\" data-src=\"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153502701.jpg\" src=\"https:\/\/s.nmxc.ltd\/sakurairo_vision\/@2.6\/load_svg\/inload.svg\" onerror=\"imgError(this)\"  \/><noscript><img decoding=\"async\" class=\"\" data-copyright=\"0\" data-ratio=\"0.4963898916967509\" data-s=\"300,640\"  data-type=\"png\" data-w=\"554\" style=\"\" src=\"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153502701.jpg\"  \/><\/noscript><\/p>\n<p><span style=\"font-size:15px;\"><\/span><\/p>\n<p><span style=\"font-size:19px;\"> <\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff08<\/span><span style=\"font-size:19px;\">3<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff09\u3001\u5f53\u4f20\u5165\u53c2\u6570\u6b63\u5e38\u4e14\u90fd\u4e0d\u4e3a\u7a7a\u65f6\uff0c<\/span><span style=\"font-size:19px;\">AOP<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u6267\u884c<\/span><span style=\"font-size:19px;\">@Before<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u6ce8\u91ca\u7684\u65b9\u6cd5\u8fdb\u884c\u9a8c\u7b7e\u64cd\u4f5c\uff1a<\/span><\/p>\n<p style=\"text-align: center;\"><img decoding=\"async\" class=\"lazyload\"class=\"\" data-copyright=\"0\" data-ratio=\"0.4963898916967509\" data-s=\"300,640\"  data-type=\"png\" data-w=\"554\" style=\"\" data-src=\"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153504978.jpg\" src=\"https:\/\/s.nmxc.ltd\/sakurairo_vision\/@2.6\/load_svg\/inload.svg\" onerror=\"imgError(this)\"  \/><noscript><img decoding=\"async\" class=\"\" data-copyright=\"0\" data-ratio=\"0.4963898916967509\" data-s=\"300,640\"  data-type=\"png\" data-w=\"554\" style=\"\" src=\"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153504978.jpg\"  \/><\/noscript><\/p>\n<p><span style=\"font-size:15px;\"><\/span><\/p>\n<p><span style=\"font-size:19px;\"> <\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff08<\/span><span style=\"font-size:19px;\">4<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff09\u3001\u82e5\u7b7e\u540d\u6821\u9a8c\u901a\u8fc7\uff0c\u5219\u6267\u884c\u5177\u4f53\u4e1a\u52a1\u4ee3\u7801\uff0c\u5e76\u5728\u63a5\u53e3\u8fd4\u56de\u65f6\u8fdb\u5165\u5230<\/span><span style=\"font-size:19px;\">@AfterReturning<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u6ce8\u91ca\u7684\u65b9\u6cd5\u8fdb\u884c\u7b7e\u540d\u8fd4\u56de\uff1a<\/span><\/p>\n<p style=\"text-align: center;\"><img decoding=\"async\" class=\"lazyload\"class=\"\" data-copyright=\"0\" data-ratio=\"0.5361010830324909\" data-s=\"300,640\"  data-type=\"png\" data-w=\"554\" style=\"\" data-src=\"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153505811.jpg\" src=\"https:\/\/s.nmxc.ltd\/sakurairo_vision\/@2.6\/load_svg\/inload.svg\" onerror=\"imgError(this)\"  \/><noscript><img decoding=\"async\" class=\"\" data-copyright=\"0\" data-ratio=\"0.5361010830324909\" data-s=\"300,640\"  data-type=\"png\" data-w=\"554\" style=\"\" src=\"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153505811.jpg\"  \/><\/noscript><\/p>\n<p><span style=\"font-size:15px;\"><\/span><\/p>\n<h1><span style=\"font-size:32px;line-height:240%;\">8<\/span><span style=\"font-size:32px;line-height:240%;font-family:\u5b8b\u4f53;\">\u3001\u65e5\u5fd7\u8bb0\u5f55<\/span><\/h1>\n<p><span style=\"font-size:19px;\"> <\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u589e\u52a0\u65e5\u5fd7\u8bb0\u5f55\uff0c\u66f4\u65b9\u4fbf\u76f4\u89c2\u7684\u67e5\u770b\u4ee3\u7801\u6267\u884c\u987a\u5e8f\u3002<\/span><\/p>\n<p><span style=\"font-size:19px;\"> <\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff08<\/span><span style=\"font-size:19px;\">1<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff09\u3001\u5f15\u5305<\/span><\/p>\n<pre style=\"background:#2B2B2B;\"><span style=\"font-size:15px;color:#E8BF6A;\">&lt;dependency&gt; &lt;groupId&gt;<\/span><span style=\"font-size:15px;color:#A9B7C6;\">log4j<\/span><span style=\"font-size:15px;color:#E8BF6A;\">&lt;\/groupId&gt; &lt;artifactId&gt;<\/span><span style=\"font-size:15px;color:#A9B7C6;\">log4j<\/span><span style=\"font-size:15px;color:#E8BF6A;\">&lt;\/artifactId&gt; &lt;version&gt;<\/span><span style=\"font-size:15px;color:#A9B7C6;\">1.2.17<\/span><span style=\"font-size:15px;color:#E8BF6A;\">&lt;\/version&gt;&lt;\/dependency&gt;<\/span><\/pre>\n<p style=\"text-indent:28px;\"><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff08<\/span><span style=\"font-size:19px;\">2<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff09\u3001\u914d\u7f6e\u65e5\u5fd7\u8bb0\u5f55\u683c\u5f0f<\/span><span style=\"font-size:19px;\">log4j.properties<\/span><\/p>\n<pre style=\"background:#2B2B2B;\"><span style=\"font-size:15px;color:#CC7832;\">log4j.rootLogger<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">debug,Console,logInfo,logError,logDebug<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.category.org.springframework<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">debug,Console,logInfo,logError,logDebug<\/span><span style=\"font-size:15px;color:gray;\">#<\/span><span style=\"font-size:15px;color:gray;\">\u8f93\u51fa\u5230\u63a7\u5236\u53f0<\/span><span style=\"font-size:15px;color:gray;\"><\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.Console<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">org.apache.log4j.ConsoleAppender<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.Console.Target<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">System.out<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.Console.layout<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">org.apache.log4j.PatternLayout<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.Console.layout.ConversionPattern<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">[%p][%d{yyyy-MM-dd HH<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">mm<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">ss,SSS}][%C.%M(%F<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">%L)] || %m%n<\/span><span style=\"font-size:15px;color:gray;\">#<\/span><span style=\"font-size:15px;color:gray;\">\u8f93\u51fa\u5230\u6587\u4ef6<\/span><span style=\"font-size:15px;color:gray;\"><\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logInfo<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">org.apache.log4j.DailyRollingFileAppender<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logInfo.File<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">${pwd}\/SpringBootDemoLogs\/SpringBootDemoLog_<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logInfo.Append<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">true<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logInfo.DatePattern<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">yyyy-MM-dd'.log'<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logInfo.Threshold<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">ALL<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logInfo.layout<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">org.apache.log4j.PatternLayout<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logInfo.layout.ConversionPattern<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">[%p][%d{yyyy-MM-dd HH<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">mm<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">ss,SSS}][%C.%M(%F<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">%L)] || %m%n<\/span><span style=\"font-size:15px;color:gray;\">#<\/span><span style=\"font-size:15px;color:gray;\">\u9519\u8bef\u65e5\u5fd7\u5355\u72ec\u8bb0\u5f55<\/span><span style=\"font-size:15px;color:gray;\"><\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logError<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">org.apache.log4j.DailyRollingFileAppender<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logError.File<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">${pwd}\/SpringBootDemoLogs\/SpringBootDemoErrorLog_<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logError.Append<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">true<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logError.DatePattern<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">yyyy-MM-dd'.log'<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logError.Threshold<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">ERROR<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logError.layout<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">org.apache.log4j.PatternLayout<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logError.layout.ConversionPattern<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">[%p][%d{yyyy-MM-dd HH<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">mm<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">ss,SSS}][%C.%M(%F<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">%L)] || %m%n<\/span><span style=\"font-size:15px;color:gray;\">#Debug<\/span><span style=\"font-size:15px;color:gray;\">\u65e5\u5fd7\u5355\u72ec\u8bb0\u5f55<\/span><span style=\"font-size:15px;color:gray;\"><\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logDebug<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">org.apache.log4j.DailyRollingFileAppender<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logDebug.File<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">${pwd}\/SpringBootDemoLogs\/SpringBootDemoDebugLog_<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logDebug.Append<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">true<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logDebug.DatePattern<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">yyyy-MM-dd'.log'<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logDebug.Threshold<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">DEBUG<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logDebug.layout<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">org.apache.log4j.PatternLayout<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logDebug.filter.infoFilter<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">org.apache.log4j.varia.LevelRangeFilter<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logDebug.filter.infoFilter.LevelMin<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">DEBUG<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logDebug.filter.infoFilter.LevelMax<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">DEBUG<\/span><span style=\"font-size:15px;color:#CC7832;\">log4j.appender.logDebug.layout.ConversionPattern<\/span><span style=\"font-size:15px;color:gray;\">=<\/span><span style=\"font-size:15px;color:#6A8759;\">[%p][%d{yyyy-MM-dd HH<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">mm<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">ss,SSS}][%C.%M(%F<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">%L)] || %m%n<\/span><\/pre>\n<p><span style=\"font-size:19px;\"> <\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff08<\/span><span style=\"font-size:19px;\">3<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff09\u3001<\/span><span style=\"font-size:19px;\">Logger<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u5de5\u5177\u7c7b<\/span><span style=\"font-size:19px;\">LoggerUtils<\/span><\/p>\n<pre style=\"background:#2B2B2B;\"><span style=\"font-size:15px;color:#CC7832;\">import <\/span><span style=\"font-size:15px;color:#A9B7C6;\">org.apache.log4j.Logger<\/span><span style=\"font-size:15px;color:#CC7832;\">;<\/span><em><span style=\"font-size:15px;color:#629755;\"><\/span><\/em><span style=\"font-size:15px;color:#CC7832;\">public class <\/span><span style=\"font-size:15px;color:#A9B7C6;background:#344134;\">LoggerUtils<\/span><span style=\"font-size:15px;color:#A9B7C6;\"> { <\/span><span style=\"font-size:15px;color:#CC7832;\">private static <\/span><span style=\"font-size:15px;color:#A9B7C6;\">Logger <\/span><em><span style=\"font-size:15px;color:#9876AA;\">logger<\/span><\/em><span style=\"font-size:15px;color:#CC7832;\">; public static <\/span><span style=\"font-size:15px;color:#A9B7C6;\">Logger <\/span><span style=\"font-size:15px;color:#FFC66D;\">getLogger<\/span><span style=\"font-size:15px;color:#A9B7C6;\">() { <\/span><span style=\"font-size:15px;color:#CC7832;\">if <\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><em><span style=\"font-size:15px;color:#9876AA;\">logger <\/span><\/em><span style=\"font-size:15px;color:#A9B7C6;\">== <\/span><span style=\"font-size:15px;color:#CC7832;\">null<\/span><span style=\"font-size:15px;color:#A9B7C6;\">) { <\/span><em><span style=\"font-size:15px;color:#9876AA;\">logger <\/span><\/em><span style=\"font-size:15px;color:#A9B7C6;\">= Logger.<em>getLogger<\/em>(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"SpringBootDemoLogs\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">} <\/span><span style=\"font-size:15px;color:#CC7832;\">return <\/span><em><span style=\"font-size:15px;color:#9876AA;\">logger<\/span><\/em><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">}}<\/span><\/pre>\n<p style=\"text-indent:28px;\"><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff08<\/span><span style=\"font-size:19px;\">4<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff09\u3001<\/span><span style=\"font-size:19px;\">SignAop<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u589e\u52a0\u65e5\u5fd7\u8bb0\u5f55<\/span><\/p>\n<pre style=\"background:#2B2B2B;\"><span style=\"font-size:15px;color:#BBB529;\">@Before<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><span style=\"font-size:15px;color:#6A8759;\">\"signAop()\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)<\/span><span style=\"font-size:15px;color:#CC7832;\">public void <\/span><span style=\"font-size:15px;color:#FFC66D;\">doBefore<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(JoinPoint joinPoint) <\/span><span style=\"font-size:15px;color:#CC7832;\">throws <\/span><span style=\"font-size:15px;color:#A9B7C6;\">Exception { \/\/code<\/span><span style=\"font-size:15px;color:#CC7832;\"> <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String strLog = <\/span><span style=\"font-size:15px;color:#6A8759;\">\"[\" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ Thread.<em>currentThread<\/em>().getId() + <\/span><span style=\"font-size:15px;color:#6A8759;\">\"]\" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ <\/span><span style=\"font-size:15px;color:#6A8759;\">\"[<\/span><span style=\"font-size:15px;color:#6A8759;\">\u8bf7\u6c42\u65b9\u6cd5<\/span><span style=\"font-size:15px;color:#6A8759;\">] \" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ joinPoint.getSignature().getName() + <\/span><span style=\"font-size:15px;color:#6A8759;\">\" ||\"<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">LoggerUtils.<em>getLogger<\/em>().info(strLog + <\/span><span style=\"font-size:15px;color:#6A8759;\">\"[<\/span><span style=\"font-size:15px;color:#6A8759;\">\u8bf7\u6c42\u53c2\u6570<\/span><span style=\"font-size:15px;color:#6A8759;\">] sign=\" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ sign + <\/span><span style=\"font-size:15px;color:#6A8759;\">\",timestamp=\" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ timestamp + <\/span><span style=\"font-size:15px;color:#6A8759;\">\",data=\" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ data)<\/span><span style=\"font-size:15px;color:#CC7832;\">;  \/\/code<\/span><span style=\"font-size:15px;color:#A9B7C6;\">}<\/span><em><span style=\"font-size:15px;color:#629755;\"><\/span><\/em><span style=\"font-size:15px;color:#BBB529;\">@AfterReturning<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(<\/span><span style=\"font-size:15px;color:#D0D0FF;\">value <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= <\/span><span style=\"font-size:15px;color:#6A8759;\">\"signAop()\"<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#D0D0FF;\">returning <\/span><span style=\"font-size:15px;color:#A9B7C6;\">= <\/span><span style=\"font-size:15px;color:#6A8759;\">\"params\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)<\/span><span style=\"font-size:15px;color:#CC7832;\">public <\/span><span style=\"font-size:15px;color:#A9B7C6;\">JSONObject <\/span><span style=\"font-size:15px;color:#FFC66D;\">doAfterReturning<\/span><span style=\"font-size:15px;color:#A9B7C6;\">(JoinPoint joinPoint<\/span><span style=\"font-size:15px;color:#CC7832;\">, <\/span><span style=\"font-size:15px;color:#A9B7C6;\">JSONObject params) { \/\/code<\/span><span style=\"font-size:15px;color:#CC7832;\"> <\/span><span style=\"font-size:15px;color:#A9B7C6;\">String strLog = <\/span><span style=\"font-size:15px;color:#6A8759;\">\"[\" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ Thread.<em>currentThread<\/em>().getId() + <\/span><span style=\"font-size:15px;color:#6A8759;\">\"]\" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ <\/span><span style=\"font-size:15px;color:#6A8759;\">\"[<\/span><span style=\"font-size:15px;color:#6A8759;\">\u8bf7\u6c42\u65b9\u6cd5<\/span><span style=\"font-size:15px;color:#6A8759;\">] \" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ joinPoint.getSignature().getName() + <\/span><span style=\"font-size:15px;color:#6A8759;\">\" ||\"<\/span><span style=\"font-size:15px;color:#CC7832;\">; <\/span><span style=\"font-size:15px;color:#A9B7C6;\">LoggerUtils.<em>getLogger<\/em>().info(strLog + <\/span><span style=\"font-size:15px;color:#6A8759;\">\"[<\/span><span style=\"font-size:15px;color:#6A8759;\">\u8fd4\u56de\u53c2\u6570<\/span><span style=\"font-size:15px;color:#6A8759;\">] \" <\/span><span style=\"font-size:15px;color:#A9B7C6;\">+ params)<\/span><span style=\"font-size:15px;color:#CC7832;\">; return <\/span><span style=\"font-size:15px;color:#A9B7C6;\">params<\/span><span style=\"font-size:15px;color:#CC7832;\">;<\/span><span style=\"font-size:15px;color:#A9B7C6;\">}<\/span><\/pre>\n<p><span style=\"font-size:19px;\"> <\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff08<\/span><span style=\"font-size:19px;\">5<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff09\u3001<\/span><span style=\"font-size:19px;\">Postman<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\u8bf7\u6c42\uff0c\u65e5\u5fd7\u8bb0\u5f55\u5982\u4e0b<\/span><\/p>\n<p style=\"text-align:left;background:#2B2B2B;\"><span style=\"font-size:15px;color:#A9B7C6;\">[INFO][<\/span><span style=\"font-size:15px;color:#6897BB;\">2018<\/span><span style=\"font-size:15px;color:#A9B7C6;\">-<\/span><span style=\"font-size:15px;color:#6897BB;\">09<\/span><span style=\"font-size:15px;color:#A9B7C6;\">-<\/span><span style=\"font-size:15px;color:#6897BB;\">25 23<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6897BB;\">59<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6897BB;\">46<\/span><span style=\"font-size:15px;color:#CC7832;\">,<\/span><span style=\"font-size:15px;color:#6897BB;\">483<\/span><span style=\"font-size:15px;color:#A9B7C6;\">][cn.wbnull.springbootdemo.boot.aop.SignAop.doBefore(SignAop.java:<\/span><span style=\"font-size:15px;color:#6897BB;\">50<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)] || [<\/span><span style=\"font-size:15px;color:#6897BB;\">21<\/span><span style=\"font-size:15px;color:#A9B7C6;\">][<\/span><span style=\"font-size:15px;font-family:\u5b8b\u4f53;color:#A9B7C6;\">\u8bf7\u6c42\u65b9\u6cd5<\/span><span style=\"font-size:15px;color:#A9B7C6;\">] login ||[<\/span><span style=\"font-size:15px;font-family:\u5b8b\u4f53;color:#A9B7C6;\">\u8bf7\u6c42\u53c2\u6570<\/span><span style=\"font-size:15px;color:#A9B7C6;\">] sign=fafb23d6e7daae823ca3d4a15a2ab4bd<\/span><span style=\"font-size:15px;color:#CC7832;\">,<\/span><span style=\"font-size:15px;color:#A9B7C6;\">timestamp=<\/span><span style=\"font-size:15px;color:#6897BB;\">1537888124<\/span><span style=\"font-size:15px;color:#CC7832;\">,<\/span><span style=\"font-size:15px;color:#A9B7C6;\">data={<\/span><span style=\"font-size:15px;color:#6A8759;\">\"username\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">\"123\"<\/span><span style=\"font-size:15px;color:#CC7832;\">,<\/span><span style=\"font-size:15px;color:#6A8759;\">\"password\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">\"123\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">}[INFO][<\/span><span style=\"font-size:15px;color:#6897BB;\">2018<\/span><span style=\"font-size:15px;color:#A9B7C6;\">-<\/span><span style=\"font-size:15px;color:#6897BB;\">09<\/span><span style=\"font-size:15px;color:#A9B7C6;\">-<\/span><span style=\"font-size:15px;color:#6897BB;\">25 23<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6897BB;\">59<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6897BB;\">46<\/span><span style=\"font-size:15px;color:#CC7832;\">,<\/span><span style=\"font-size:15px;color:#6897BB;\">499<\/span><span style=\"font-size:15px;color:#A9B7C6;\">][cn.wbnull.springbootdemo.controller.LoginController.login(LoginController.java:<\/span><span style=\"font-size:15px;color:#6897BB;\">26<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)] || [<\/span><span style=\"font-size:15px;color:#6897BB;\">21<\/span><span style=\"font-size:15px;color:#A9B7C6;\">] LoginController[INFO][<\/span><span style=\"font-size:15px;color:#6897BB;\">2018<\/span><span style=\"font-size:15px;color:#A9B7C6;\">-<\/span><span style=\"font-size:15px;color:#6897BB;\">09<\/span><span style=\"font-size:15px;color:#A9B7C6;\">-<\/span><span style=\"font-size:15px;color:#6897BB;\">25 23<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6897BB;\">59<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6897BB;\">46<\/span><span style=\"font-size:15px;color:#CC7832;\">,<\/span><span style=\"font-size:15px;color:#6897BB;\">604<\/span><span style=\"font-size:15px;color:#A9B7C6;\">][cn.wbnull.springbootdemo.service.LoginService.login(LoginService.java:<\/span><span style=\"font-size:15px;color:#6897BB;\">30<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)] || [<\/span><span style=\"font-size:15px;color:#6897BB;\">21<\/span><span style=\"font-size:15px;color:#A9B7C6;\">] LoginService[INFO][<\/span><span style=\"font-size:15px;color:#6897BB;\">2018<\/span><span style=\"font-size:15px;color:#A9B7C6;\">-<\/span><span style=\"font-size:15px;color:#6897BB;\">09<\/span><span style=\"font-size:15px;color:#A9B7C6;\">-<\/span><span style=\"font-size:15px;color:#6897BB;\">25 23<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6897BB;\">59<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6897BB;\">46<\/span><span style=\"font-size:15px;color:#CC7832;\">,<\/span><span style=\"font-size:15px;color:#6897BB;\">615<\/span><span style=\"font-size:15px;color:#A9B7C6;\">][cn.wbnull.springbootdemo.boot.aop.SignAop.doAfterReturning(SignAop.java:<\/span><span style=\"font-size:15px;color:#6897BB;\">84<\/span><span style=\"font-size:15px;color:#A9B7C6;\">)] || [<\/span><span style=\"font-size:15px;color:#6897BB;\">21<\/span><span style=\"font-size:15px;color:#A9B7C6;\">][<\/span><span style=\"font-size:15px;font-family:\u5b8b\u4f53;color:#A9B7C6;\">\u8bf7\u6c42\u65b9\u6cd5<\/span><span style=\"font-size:15px;color:#A9B7C6;\">] login ||[<\/span><span style=\"font-size:15px;font-family:\u5b8b\u4f53;color:#A9B7C6;\">\u8fd4\u56de\u53c2\u6570<\/span><span style=\"font-size:15px;color:#A9B7C6;\">] {<\/span><span style=\"font-size:15px;color:#6A8759;\">\"code\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">\"1000\"<\/span><span style=\"font-size:15px;color:#CC7832;\">,<\/span><span style=\"font-size:15px;color:#6A8759;\">\"sign\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">\"18954bd1a668e0d6fc98e4e15386352f\"<\/span><span style=\"font-size:15px;color:#CC7832;\">,<\/span><span style=\"font-size:15px;color:#6A8759;\">\"message\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6A8759;\">\"SUCCESS\"<\/span><span style=\"font-size:15px;color:#CC7832;\">,<\/span><span style=\"font-size:15px;color:#6A8759;\">\"timestamp\"<\/span><span style=\"font-size:15px;color:#A9B7C6;\">:<\/span><span style=\"font-size:15px;color:#6897BB;\">1537891186<\/span><span style=\"font-size:15px;color:#A9B7C6;\">}<\/span><\/p>\n<p><span style=\"font-size:19px;\"><\/span><\/p>\n<hr  \/>\n<p><span style=\"font-size:19px;\"><\/span><\/p>\n<p><span style=\"font-size:19px;\">GitHub<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff1a<\/span><span style=\"font-size:19px;\">https:\/\/github.com\/dkbnull\/SpringBootDemo<\/span><\/p>\n<p><span style=\"font-size:19px;\">CSDN<\/span><span style=\"font-size:19px;font-family:\u5b8b\u4f53;\">\uff1a<\/span><span style=\"font-size:19px;\">https:\/\/blog.csdn.net\/dkbnull\/article\/details\/82847647<\/span><\/p>\n<p><span style=\"font-size:19px;\"><\/span><\/p>\n<hr  \/>\n<p><span style=\"font-size:19px;\"><\/span><\/p>\n<p><img decoding=\"async\" class=\"lazyload\"class=\"\" data-copyright=\"0\" data-ratio=\"0.4488817891373802\" data-s=\"300,640\"  data-type=\"png\" data-w=\"626\" style=\"text-align: center;\" data-src=\"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153507923.jpg\" src=\"https:\/\/s.nmxc.ltd\/sakurairo_vision\/@2.6\/load_svg\/inload.svg\" onerror=\"imgError(this)\"  \/><noscript><img decoding=\"async\" class=\"\" data-copyright=\"0\" data-ratio=\"0.4488817891373802\" data-s=\"300,640\"  data-type=\"png\" data-w=\"626\" style=\"text-align: center;\" src=\"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153507923.jpg\"  \/><\/noscript><\/p>\n<blockquote>\n<p>\u672c\u7bc7\u6587\u7ae0\u6765\u6e90\u4e8e\u5fae\u4fe1\u516c\u4f17\u53f7:                 \u7a0b\u5e8f\u5458null              <\/p>\n<\/blockquote>\n<\/div>\n","raw":"","protected":false},"excerpt":{"rendered":"<p>\u5f53\u6211\u4eec\u4f7f\u7528Spring Boot\u53d1\u5e03\u540e\u53f0\u63a5\u53e3\u65f6\uff0c\u5982\u679c\u591a\u4e2a\u63a5\u53e3\u5b58\u5728\u76f8\u540c\u7684\u64cd\u4f5c\uff0c\u6bd4\u5982\u5bf9\u53c2\u6570\u8fdb\u884c\u975e\u7a7a\u6821\u9a8c\u6216\u9a8c\u7b7e\u3002\u8fd9\u4e9b\u64cd\u4f5c\u90fd\u662f\u5728\u5177\u4f53\u4e1a\u52a1\u4ee3 &#8230;<\/p>\n","protected":false},"author":1,"featured_media":4400,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"emotion":"","emotion_color":"","title_style":"","license":"","footnotes":""},"categories":[7],"tags":[],"class_list":["post-4408","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-spring-boot"],"post_thumbnail_image":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153458320-150x150.jpeg","content_first_image":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153501460.jpg","post_medium_image_300":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153458320-300x128.jpeg","post_thumbnail_image_624":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153458320-1024x435.jpeg","post_frist_image":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153501460.jpg","post_medium_image":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153458320-300x128.jpeg","post_large_image":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153458320-1024x435.jpeg","post_full_image":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153458320.jpeg","post_all_images":[{"imagesurl":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153501460.jpg","id":"image0"},{"imagesurl":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153501460.jpg","id":"image1"},{"imagesurl":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153502701.jpg","id":"image2"},{"imagesurl":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153502701.jpg","id":"image3"},{"imagesurl":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153504978.jpg","id":"image4"},{"imagesurl":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153504978.jpg","id":"image5"},{"imagesurl":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153505811.jpg","id":"image6"},{"imagesurl":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153505811.jpg","id":"image7"},{"imagesurl":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153507923.jpg","id":"image8"},{"imagesurl":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2024\/05\/20240524153507923.jpg","id":"image9"}],"videoAdId":"","listAd":"0","listAdId":"","listAdEvery":6,"total_comments":0,"category_name":"Spring Boot","post_date":"2018-09-27","like_count":"0","praiseWord":"\u9f13\u52b1","copyright_state":"","excitationAd":"0","rewardedVideoAdId":"","detailAdId":"","detailAd":"0","enterpriseMinapp":"0","audios":[],"postImageUrl":"https:\/\/wp-moto-1258805347.cos.ap-shanghai.myqcloud.com\/2023\/05\/20230519082947553.jpg","avatarurls":[],"related_posts":null,"pageviews":312,"next_post_id":4399,"next_post_title":"Spring Boot\u5165\u95e8\uff1a\u81ea\u5b9a\u4e49log4j\u65e5\u5fd7\u8f93\u51fa","previous_post_id":4418,"previous_post_title":"Spring Boot\u5165\u95e8\uff1a\u8bfb\u53d6properties\u914d\u7f6e\u6587\u4ef6\u4e2d\u7684\u6570\u636e","_links":{"self":[{"href":"https:\/\/xinchewhd.com.cn\/index.php\/wp-json\/wp\/v2\/posts\/4408","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/xinchewhd.com.cn\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/xinchewhd.com.cn\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/xinchewhd.com.cn\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/xinchewhd.com.cn\/index.php\/wp-json\/wp\/v2\/comments?post=4408"}],"version-history":[{"count":0,"href":"https:\/\/xinchewhd.com.cn\/index.php\/wp-json\/wp\/v2\/posts\/4408\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/xinchewhd.com.cn\/index.php\/wp-json\/wp\/v2\/media\/4400"}],"wp:attachment":[{"href":"https:\/\/xinchewhd.com.cn\/index.php\/wp-json\/wp\/v2\/media?parent=4408"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/xinchewhd.com.cn\/index.php\/wp-json\/wp\/v2\/categories?post=4408"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/xinchewhd.com.cn\/index.php\/wp-json\/wp\/v2\/tags?post=4408"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}