一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - Java教程 - 使用spring boot通過(guò)自定義注解打印所需日志

使用spring boot通過(guò)自定義注解打印所需日志

2021-10-22 10:59kin_wen Java教程

這篇文章主要介紹了使用spring boot通過(guò)自定義注解打印所需日志的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

spring boot自定義注解打印日志

在實(shí)際項(xiàng)目中可能需要監(jiān)控每個(gè)接口的請(qǐng)求時(shí)間以及請(qǐng)求參數(shù)等相關(guān)信息,那么此時(shí)我們想到的就是兩種實(shí)現(xiàn)方式,一種是通過(guò)攔截器實(shí)現(xiàn),另一種則通過(guò)AOP自定義注解實(shí)現(xiàn)。

本文介紹自定義注解實(shí)現(xiàn)方式

自定義注解,四個(gè)元注解這次就不解釋了。

?
1
2
3
4
5
6
7
8
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface WebLog {
    /**
     * 日志信息描述
     */
    String description() default "";
}

AOP實(shí)現(xiàn):

1.@Order注解用來(lái)定義切面的執(zhí)行順序,數(shù)值越小優(yōu)先級(jí)越高。

2.@Around環(huán)繞通知,我們可以自定義在什么時(shí)候執(zhí)行@Before以及@After。

3.ThreadLocal針對(duì)每個(gè)線程都單獨(dú)的記錄。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
@Aspect
@Component
public class WebLogAspect {
    private static ThreadLocal<ProceedingJoinPoint> td = new ThreadLocal<>();
    @Pointcut("@annotation(com.example.demo.annotation.WebLog)")
    @Order(1)
    public void webLog(){}
    @Before("webLog()")
    public void doBefor(JoinPoint point){
        System.out.println("***********method before執(zhí)行************");
        ServletRequestAttributes attributes = (ServletRequestAttributes)RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = attributes.getRequest();
        System.out.println("請(qǐng)求URL:"+request.getRequestURL());
        System.out.println("請(qǐng)求參數(shù):"+ Arrays.toString(point.getArgs()));
        System.out.println("***********method before結(jié)束************");
    }
    @Around("webLog()")
    public Object doAround(ProceedingJoinPoint point) throws Throwable {
        System.out.println("***********執(zhí)行環(huán)繞方法開(kāi)始************");
        td.set(point);
        long startTime = System.currentTimeMillis();
        ProceedingJoinPoint joinPoint = td.get();
        Object proceed = joinPoint.proceed();
        System.out.println("執(zhí)行耗時(shí)毫秒:"+ (System.currentTimeMillis()-startTime));
        System.out.println("***********執(zhí)行環(huán)繞方法結(jié)束************");
        return proceed;
    }
}

Controller

?
1
2
3
4
5
6
7
8
@RestController
public class LoginController {
    @PostMapping("/user/login")
    @WebLog(description = "用戶登錄接口")
    public UserForm login(@RequestBody UserForm user){
        return user;
    }
}

測(cè)試結(jié)果

使用spring boot通過(guò)自定義注解打印所需日志

通過(guò)自定義注解獲取日志

1.定義一個(gè)注解

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
package com.hisense.demo02;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
 
/**
 * @author : sunkepeng  E-mail : [email protected]
 * @date : 2020/8/8 20:09
 */
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface Check {
}

2.寫一個(gè)測(cè)試用類,并使用注解

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
package com.hisense.demo02;
 
/**
 * @author : sunkepeng  E-mail : [email protected]
 * @date : 2020/8/8 20:04
 */
public class Calculator {
    @Check
    public void add(){
        System.out.println("1+0=" + (1+0));
    }
    @Check
    public void sub(){
        System.out.println("1-0=" + (1-0));
    }
    @Check
    public void mul(){
        System.out.println("1*0=" + (1*0));
    }
    @Check
    public void div(){
        System.out.println("1/0=" + (1/0));
    }
    public void show(){
        System.out.println("永無(wú)bug");
    }
}

3.使用注解,在測(cè)試類中輸出log

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
package com.hisense.demo02;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.lang.reflect.Method;
 
/**
 * @author : sunkepeng  E-mail : [email protected]
 * @date : 2020/8/8 21:39
 */
public class TestCheck {
    public static void main(String[] args) throws IOException {
        Calculator calculator = new Calculator();
        Class calculatorClass = calculator.getClass();
        Method[] methods = calculatorClass.getMethods();
        int number =0;
        BufferedWriter bufferedWriter = new BufferedWriter(new FileWriter("bug.txt"));
        for (Method method : methods) {
            if (method.isAnnotationPresent(Check.class)){
                try {
                    method.invoke(calculator);
                } catch (Exception e) {
                    number++;
                    bufferedWriter.write(method.getName()+"出現(xiàn)異常");
                    bufferedWriter.newLine();
                    bufferedWriter.write("異常的名稱:"+e.getCause().getClass().getSimpleName());
                    bufferedWriter.newLine();
                    bufferedWriter.write("異常的原因"+e.getCause().getMessage());
                    bufferedWriter.newLine();
                    bufferedWriter.write("-----------------");
                    bufferedWriter.newLine();
                }
            }
        }
        bufferedWriter.write("本次共出現(xiàn):"+number+"次異常");
        bufferedWriter.flush();
        bufferedWriter.close();
    }
}

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://blog.csdn.net/kin_wen/article/details/93412270

延伸 · 閱讀

精彩推薦
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程xml與Java對(duì)象的轉(zhuǎn)換詳解

    xml與Java對(duì)象的轉(zhuǎn)換詳解

    這篇文章主要介紹了xml與Java對(duì)象的轉(zhuǎn)換詳解的相關(guān)資料,需要的朋友可以參考下...

    Java教程網(wǎng)2942020-09-17
  • Java教程Java實(shí)現(xiàn)搶紅包功能

    Java實(shí)現(xiàn)搶紅包功能

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)搶紅包功能,采用多線程模擬多人同時(shí)搶紅包,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程20個(gè)非常實(shí)用的Java程序代碼片段

    20個(gè)非常實(shí)用的Java程序代碼片段

    這篇文章主要為大家分享了20個(gè)非常實(shí)用的Java程序片段,對(duì)java開(kāi)發(fā)項(xiàng)目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程升級(jí)IDEA后Lombok不能使用的解決方法

    升級(jí)IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級(jí),尋思已經(jīng)有好久沒(méi)有升過(guò)級(jí)了。升級(jí)完畢重啟之后,突然發(fā)現(xiàn)好多錯(cuò)誤,本文就來(lái)介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java BufferWriter寫文件寫不進(jìn)去或缺失數(shù)據(jù)的解決

    Java BufferWriter寫文件寫不進(jìn)去或缺失數(shù)據(jù)的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進(jìn)去或缺失數(shù)據(jù)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java8中Stream使用的一個(gè)注意事項(xiàng)

    Java8中Stream使用的一個(gè)注意事項(xiàng)

    最近在工作中發(fā)現(xiàn)了對(duì)于集合操作轉(zhuǎn)換的神器,java8新特性 stream,但在使用中遇到了一個(gè)非常重要的注意點(diǎn),所以這篇文章主要給大家介紹了關(guān)于Java8中S...

    阿杜7472021-02-04
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關(guān)于小米推送Java代碼,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧...

    富貴穩(wěn)中求8032021-07-12
主站蜘蛛池模板: 99精品视频一区在线观看miya | 免费看3d小舞被躁视频网站 | 丝袜捆绑调教视频免费区 | 精品videoss另类日本 | 午夜国产精品 | 91欧洲在线视精品在亚洲 | 亚洲高清中文字幕精品不卡 | sxx免费看视频在线播放 | 四虎麻豆| 热99精品只有里视频最新 | 四虎在线成人免费网站 | 美女伊人网 | 爸爸干女儿小说 | 故意短裙公车被强好爽在线播放 | 百合互慰吃奶互揉漫画 | 国产亚洲精品网站 | 大陆国产精品视频 | 91精品天美精东蜜桃传媒免费 | 欧美成人禁片在线观看俄罗斯 | 亚洲成在人网站天堂一区二区 | caoporn草棚在线视频 | 国内体内she精视频免费 | 免费一级欧美大片在线观看 | 夫妻性生活一级黄色片 | 男生的j桶女人屁免费视频 男生操男生 | 9自拍视频在线观看 | 日本中文字幕高清 | 日本无遮挡吸乳视频看看 | 久久aa毛片免费播放嗯啊 | 国外成品精品1688 | 四虎地址| 校园刺激全黄H全肉细节文 校草让我脱了内裤给全班看 | 久久精品国产免费播高清无卡 | 亚洲无线一二三区2021 | 秘书小说阿蛮 | freefron性中国| 97热久久免费频精品99国产成人 | 午夜精品久久久久久久2023 | 日本老头4569gay | 近亲乱中文字幕 | 四虎影库网址 |