<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
Spring-boot-start-aop
#spring設定 spring: #切面啟用 aop: proxy-target-class: true auto: true
package cn.annotation; import java.lang.annotation.*; /** * Title: SystemControllerLog * @date 2018年8月31日 * @version V1.0 * Description: 自定義註解,攔截controller */ @Target({ElementType.PARAMETER, ElementType.METHOD})//作用在引數和方法上 @Retention(RetentionPolicy.RUNTIME)//執行時註解 @Documented//表明這個註解應該被 javadoc工具記錄 public @interface SystemControllerLog { String description() default ""; }
package cn.annotation; import java.lang.annotation.*; /** * Title: SystemControllerLog * @date 2018年8月31日 * @version V1.0 * Description: 自定義註解,攔截service */ @Target({ElementType.PARAMETER, ElementType.METHOD}) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface SystemServiceLog { String description() default ""; }
package cn.annotation; import cn.pojo.Action; import cn.pojo.User; import cn.service.ActionService; import cn.utils.IpUtils; import cn.utils.JsonUtils; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.AfterThrowing; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.aspectj.lang.annotation.Pointcut; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Component; import org.springframework.web.context.request.RequestContextHolder; import org.springframework.web.context.request.ServletRequestAttributes; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpSession; import java.lang.reflect.Method; import java.util.Date; /** * Title: SystemControllerLog * @date 2018年8月31日 * @version V1.0 * Description: 切點類 */ @Aspect @Component @SuppressWarnings("all") public class SystemLogAspect { //注入Service用於把紀錄檔儲存資料庫,實際專案入庫採用佇列做非同步 @Resource private ActionService actionService; //本地異常紀錄檔記錄物件 private static final Logger logger = LoggerFactory.getLogger(SystemLogAspect.class); //Service層切點 @Pointcut("@annotation(cn.annotation.SystemServiceLog)") public void serviceAspect(){ } //Controller層切點 @Pointcut("@annotation(cn.oa.annotation.SystemControllerLog)") public void controllerAspect(){ } /** * @Description 前置通知 用於攔截Controller層記錄使用者的操作 * @date 2018年9月3日 10:38 */ @Before("controllerAspect()") public void doBefore(JoinPoint joinPoint){ HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest(); HttpSession session = request.getSession(); //讀取session中的使用者 User user = (User) session.getAttribute("user"); String ip = IpUtils.getIpAddr(request); try { //*========控制檯輸出=========*// System.out.println("==============前置通知開始=============="); System.out.println("請求方法" + (joinPoint.getTarget().getClass().getName() + "." + joinPoint.getSignature().getName())); System.out.println("方法描述:" + getControllerMethodDescription(joinPoint)); System.out.println("請求人:"+user.getUsername()); System.out.println("請求ip:"+ip); //*========資料庫紀錄檔=========*// Action action = new Action(); action.setActionDes(getControllerMethodDescription(joinPoint)); action.setActionType("0"); action.setActionIp(ip); action.setUserId(user.getId()); action.setActionTime(new Date()); //儲存資料庫 actionService.add(action); }catch (Exception e){ //記錄本地異常紀錄檔 logger.error("==前置通知異常=="); logger.error("異常資訊:{}",e.getMessage()); } } /** * @Description 異常通知 用於攔截service層記錄異常紀錄檔 * @date 2018年9月3日 下午5:43 */ @AfterThrowing(pointcut = "serviceAspect()",throwing = "e") public void doAfterThrowing(JoinPoint joinPoint,Throwable e){ HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest(); HttpSession session = request.getSession(); //讀取session中的使用者 User user = (User) session.getAttribute("user"); //獲取請求ip String ip = IpUtils.getIpAddr(request); //獲取使用者請求方法的引數並序列化為JSON格式字串 String params = ""; if (joinPoint.getArgs()!=null&&joinPoint.getArgs().length>0){ for (int i = 0; i < joinPoint.getArgs().length; i++) { params+= JsonUtils.objectToJson(joinPoint.getArgs()[i])+";"; } } try{ /*========控制檯輸出=========*/ System.out.println("=====異常通知開始====="); System.out.println("異常程式碼:" + e.getClass().getName()); System.out.println("異常資訊:" + e.getMessage()); System.out.println("異常方法:" + (joinPoint.getTarget().getClass().getName() + "." + joinPoint.getSignature().getName() + "()")); System.out.println("方法描述:" + getServiceMethodDescription(joinPoint)); System.out.println("請求人:" + user.getUsername()); System.out.println("請求IP:" + ip); System.out.println("請求引數:" + params); /*==========資料庫紀錄檔=========*/ Action action = new Action(); action.setActionDes(getServiceMethodDescription(joinPoint)); action.setActionType("1"); action.setUserId(user.getId()); action.setActionIp(ip); action.setActionTime(new Date()); //儲存到資料庫 actionService.add(action); }catch (Exception ex){ //記錄本地異常紀錄檔 logger.error("==異常通知異常=="); logger.error("異常資訊:{}", ex.getMessage()); } } /** * @Description 獲取註解中對方法的描述資訊 用於service層註解 * @date 2018年9月3日 下午5:05 */ public static String getServiceMethodDescription(JoinPoint joinPoint)throws Exception{ String targetName = joinPoint.getTarget().getClass().getName(); String methodName = joinPoint.getSignature().getName(); Object[] arguments = joinPoint.getArgs(); Class targetClass = Class.forName(targetName); Method[] methods = targetClass.getMethods(); String description = ""; for (Method method:methods) { if (method.getName().equals(methodName)){ Class[] clazzs = method.getParameterTypes(); if (clazzs.length==arguments.length){ description = method.getAnnotation(SystemServiceLog.class).description(); break; } } } return description; } /** * @Description 獲取註解中對方法的描述資訊 用於Controller層註解 * @date 2018年9月3日 上午12:01 */ public static String getControllerMethodDescription(JoinPoint joinPoint) throws Exception { String targetName = joinPoint.getTarget().getClass().getName(); String methodName = joinPoint.getSignature().getName();//目標方法名 Object[] arguments = joinPoint.getArgs(); Class targetClass = Class.forName(targetName); Method[] methods = targetClass.getMethods(); String description = ""; for (Method method:methods) { if (method.getName().equals(methodName)){ Class[] clazzs = method.getParameterTypes(); if (clazzs.length==arguments.length){ description = method.getAnnotation(SystemControllerLog.class).description(); break; } } } return description; } }
註解加在控制器中方法上面,括號裡寫上操作描述
@SystemServiceLog(description = "")
註解加在service層方法上面,括號裡寫上操作描述
(此處為AOP攔截Service記錄異常資訊。方法不需要加try-catch)
以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45