日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

在Spring 中使用@Aspect 控制自定義注解的操作

瀏覽:119日期:2023-07-26 08:02:11

Spring 中使用@Aspect 控制自定義注解

看這篇介紹@Aspect

1.定義系統(tǒng)日志注解類

@Target(ElementType.METHOD)@Retention(RetentionPolicy.RUNTIME)@Documentedpublic @interface SysLog {String value() default '';}2.定義切面處理類

package com.kxs.common.aspect;import com.google.gson.Gson;import com.kxs.common.annotation.SysLog;import com.kxs.common.utils.HttpContextUtils;import com.kxs.common.utils.IPUtils;import com.kxs.modules.sys.entity.SysLogEntity;import com.kxs.modules.sys.entity.SysUserEntity;import com.kxs.modules.sys.service.SysLogService;import org.apache.shiro.SecurityUtils;import org.aspectj.lang.ProceedingJoinPoint;import org.aspectj.lang.annotation.Around;import org.aspectj.lang.annotation.Aspect;import org.aspectj.lang.annotation.Pointcut;import org.aspectj.lang.reflect.MethodSignature;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Component;import javax.servlet.http.HttpServletRequest;import java.lang.reflect.Method;import java.util.Date;/** * 系統(tǒng)日志,切面處理類 * * @author * @email * @date */@Aspect@Componentpublic class SysLogAspect { @Autowired private SysLogService sysLogService; @Pointcut('@annotation(com.kxs.common.annotation.SysLog)')//指向自定義注解路徑 public void logPointCut() { } /** * 切面記錄系統(tǒng)日志 * @param point * @return * @throws Throwable */ @Around('logPointCut()')// public Object around(ProceedingJoinPoint point) throws Throwable { long beginTime = System.currentTimeMillis(); //執(zhí)行方法 Object result = point.proceed(); //執(zhí)行時長(毫秒) long time = System.currentTimeMillis() - beginTime; //保存日志 saveSysLog(point, time); return result; }//保存日志 private void saveSysLog(ProceedingJoinPoint joinPoint, long time) { MethodSignature signature = (MethodSignature) joinPoint.getSignature(); Method method = signature.getMethod(); SysLogEntity sysLog = new SysLogEntity(); SysLog syslog = method.getAnnotation(SysLog.class); if(syslog != null){ //注解上的描述 sysLog.setOperation(syslog.value()); } //請求的方法名 String className = joinPoint.getTarget().getClass().getName(); String methodName = signature.getName(); sysLog.setMethod(className + '.' + methodName + '()'); //請求的參數(shù) Object[] args = joinPoint.getArgs(); try{ String params = new Gson().toJson(args[0]); sysLog.setParams(params); }catch (Exception e){ } //獲取request HttpServletRequest request = HttpContextUtils.getHttpServletRequest(); //設置IP地址 sysLog.setIp(IPUtils.getIpAddr(request)); //用戶名 String username = ((SysUserEntity) SecurityUtils.getSubject().getPrincipal()).getUsername(); sysLog.setUsername(username); sysLog.setTime(time); sysLog.setCreateDate(new Date()); //保存系統(tǒng)日志 sysLogService.save(sysLog); }}

補充:為什么添加了@Aspect 還要加@Component

官方文檔中有寫:

You may register aspect classes as regular beans in your Spring XML configuration, or autodetect them through classpath scanning - just like any other Spring-managed bean. However, note that the @Aspect annotation is not sufficient for autodetection in the classpath: For that purpose, you need to add a separate @Component annotation (or alternatively a custom stereotype annotation that qualifies, as per the rules of Spring’s component scanner).

翻譯:

您可以在Spring XML配置中注冊aspect類,或者通過類路徑掃描自動檢測它們,就像任何其他Spring管理bean一樣。但是,請注意,@aspect注釋對于在類路徑中自動檢測是不夠的:為了達到這個目的,您需要添加一個單獨的@component注解(或者根據(jù)Spring的組件掃描器的規(guī)則來定義一個定制的原型注解)。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
一区二区国产在线| 青草av.久久免费一区| 国产精品片aa在线观看| 日本一不卡视频| 欧美日韩伊人| 国产精品免费99久久久| 国产欧美日韩免费观看| 欧美亚洲免费| 精品三级国产| 久久九九精品| 91精品福利| 日韩极品在线观看| 亚洲18在线| 国产高清亚洲| 国产精品精品国产一区二区| 成人免费网站www网站高清| 亚洲成人日韩| 天海翼精品一区二区三区| 国产亚洲电影| 日本蜜桃在线观看视频| 久久久夜夜夜| 亚洲精品一级| 91日韩免费| 亚洲人亚洲人色久| 国产精品久久久久久久久久10秀| 久久久久中文| 久久国产精品免费一区二区三区| 麻豆91精品视频| 日韩视频网站在线观看| 综合国产精品| 精品一区二区三区四区五区| 91九色精品| 国产高清亚洲| 中文字幕一区二区av| 理论片午夜视频在线观看| 麻豆精品网站| 欧美13videosex性极品| 亚洲精品系列| 久久要要av| 欧美a在线观看| 免费精品视频在线| 久久美女性网| 国产探花一区二区| 国产亚洲在线| 成人羞羞视频在线看网址| 久久国产乱子精品免费女| 国产美女一区| 99精品在线观看| 伊人久久在线| 成人免费一区| 国产福利一区二区三区在线播放| 免费日本视频一区| 快she精品国产999| 日韩欧美少妇| 日韩中文在线电影| 国产精品久久久久久久久久10秀| 国产极品一区| 日欧美一区二区| 免费成人性网站| 免费视频久久| 国产一区导航| 99亚洲精品| 日韩中文字幕1| 亚洲精选久久| 97se亚洲| 国产精品一区二区精品| 欧美国产日韩电影| 国产精品白丝av嫩草影院| 91成人福利| 国产精品入口久久| 欧美91在线|欧美| 精品免费视频| 精品亚洲免a| 久久精品三级| 欧美韩日一区| 婷婷国产精品| 五月亚洲婷婷 | 亚洲精品裸体| 亚洲精品亚洲人成在线观看| 亚洲资源网站| 国产高清亚洲| 久久视频国产| 蜜桃视频第一区免费观看| 91成人小视频| 日韩国产欧美| 美女尤物久久精品| 国产精品一区二区三区美女 | 国产成人久久精品麻豆二区| 电影亚洲精品噜噜在线观看| 夜久久久久久| 久久爱www.| 日韩在线短视频| 视频一区二区三区在线| 国产日韩视频在线| 久久蜜桃精品| 国产欧美精品| 久久av一区| 鲁鲁在线中文| 欧美性www| 午夜久久福利| 成人午夜网址| 日本午夜精品一区二区三区电影| 97欧美在线视频| 日韩欧美中文字幕一区二区三区| 福利片在线一区二区| 亚洲一区av| 日韩精品影视| 国产精品99精品一区二区三区∴| 美女少妇全过程你懂的久久| 美女在线视频一区| 日韩精品a在线观看91| 黑丝一区二区| 亚洲午夜一级| 日韩毛片视频| 久久久91麻豆精品国产一区| 四虎在线精品| 一区二区国产在线| 黄色成人精品网站| 日韩一区二区三区免费播放| 国产精品乱战久久久| 免费视频一区二区| 在线视频观看日韩| 日韩在线精品| 丝袜美腿诱惑一区二区三区| 国产成人免费av一区二区午夜| 久久99蜜桃| 久久99视频| 久久婷婷国产| 国产精品99久久精品| 精品国产亚洲一区二区三区| 久久一区国产| 成人国产精品一区二区免费麻豆| 精品三级av| 亚洲精品**中文毛片| 国产精品国产一区| 成人羞羞在线观看网站| 国产精品99久久精品| 牛牛精品成人免费视频| 国产欧美日韩精品一区二区三区| 日韩和欧美一区二区三区| 日韩国产91| 美女久久久久久| 久久精品国产99国产精品| 麻豆精品在线视频| 精品国产乱码| 1000部精品久久久久久久久| 亚洲欧美日韩国产综合精品二区| 免费日韩视频| 国产亚洲一区二区三区不卡| 国产一区2区| 午夜av一区| 免费精品视频最新在线| 日本三级亚洲精品| 国产一区二区三区精品在线观看| 不卡福利视频| 欧美日韩国产一区二区三区不卡| 免播放器亚洲| 国产日韩一区| 天堂√8在线中文| 亚洲色诱最新| 欧美日韩精品一区二区三区视频 | 少妇久久久久| 日韩精品一区二区三区中文 | 日韩国产在线观看| 国产美女高潮在线| 视频一区二区三区在线| 国产精品qvod| 男女激情视频一区| 91av亚洲| 国产精品视频一区视频二区| 久久中文亚洲字幕| 麻豆91在线播放| 日韩精品久久久久久久软件91| 成人综合一区| 日本不卡中文字幕| 欧美日韩视频| 在线手机中文字幕| 日韩精品中文字幕吗一区二区 | 国产亚洲一卡2卡3卡4卡新区| 99热精品在线观看| 国产粉嫩在线观看| 久久99蜜桃| 国产欧美日韩视频在线| 欧美特黄a级高清免费大片a级| 国产夫妻在线| 丁香婷婷久久| 国产乱人伦丫前精品视频| 中文字幕日本一区| 蜜臀久久99精品久久久久久9| 久久亚洲国产| 精品72久久久久中文字幕| 午夜精品影视国产一区在线麻豆| 蜜桃国内精品久久久久软件9| 日韩欧美另类一区二区| 国产在线看片免费视频在线观看| 国产美女精品视频免费播放软件| 亚洲精品黄色| 日韩高清不卡在线| 蜜桃一区二区三区在线| 亚洲精选91|