SpringBoot2.x下“后置處理器”完成AOP代理實(shí)戰(zhàn)—注解版日志打印

Spring完成AOP代理有兩種途徑,一種依賴AbstractAutoProxyCreator來完成自動(dòng)代理(例如事務(wù)就是依賴其子類完成代理)陨溅。另一種是依賴AbstractAdvisingBeanPostProcessor來完成代理(例如@Async就是依賴其子類完成代理)。

使用AbstractAutoProxyCreator完成AOP代理埂伦,只需要將Advisor注冊(cè)到Spring容器中潦牛。而AbstractAdvisingBeanPostProcessor需要使用其子類來完成AOP代理。

1. AbstractAdvisingBeanPostProcessor子類

image.png

Spring使用模板方法模式狠角,只是將個(gè)性化的功能留給子類來實(shí)現(xiàn),那么我們先點(diǎn)擊MethodValidationPostProcessor類蚪腋,看下它實(shí)現(xiàn)了父類什么方法丰歌。

image.png

那么MethodValidationPostProcessor做了什么?便完成了對(duì)方法校驗(yàn)的AOP代理屉凯?立帖??

public class MethodValidationPostProcessor extends AbstractBeanFactoryAwareAdvisingPostProcessor
        implements InitializingBean {
    //在初始化時(shí)悠砚,創(chuàng)建了一個(gè)Advisor并賦予給父類
    //(AbstractAdvisingBeanProcessor)的advisor屬性晓勇。
    @Override
    public void afterPropertiesSet() {
        Pointcut pointcut = new AnnotationMatchingPointcut(this.validatedAnnotationType, true);
        this.advisor = new DefaultPointcutAdvisor(pointcut, createMethodValidationAdvice(this.validator));
    }
    protected Advice createMethodValidationAdvice(@Nullable Validator validator) {
        return (validator != null ? new MethodValidationInterceptor(validator) : new MethodValidationInterceptor());
    }
}

只是在后置處理器定義了一個(gè)Advisor,并將其賦予給父類的屬性,Spring便可以使用該Advisor對(duì)Bean進(jìn)行代理绑咱。

沒錯(cuò)绰筛,就是這么簡(jiǎn)單!C枞凇铝噩!

3. 注解版日志打印實(shí)戰(zhàn)

@Target({ElementType.METHOD, ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface MyLogAnno {

    Class<?>[] value() default {};

}

定義后置后置處理器(聲明advisor),在項(xiàng)目啟動(dòng)的時(shí)會(huì)對(duì)類進(jìn)行AOP代理窿克。

@Slf4j
@Component
public class MyLogAnnoBeanPostProcessor extends AbstractBeanFactoryAwareAdvisingPostProcessor
        implements InitializingBean {

    private Class<? extends Annotation> myLogAnnoType = MyLogAnno.class;


    @Override
    public void afterPropertiesSet() throws Exception {
        //對(duì)帶有myLogAnno注解的方法進(jìn)行攔截
        Pointcut pointcut =AnnotationMatchingPointcut.forMethodAnnotation(myLogAnnoType);
        this.advisor = new DefaultPointcutAdvisor(pointcut,
                (MethodBeforeAdvice) (method, args, target) -> {
                    //打印日志
                    log.info("調(diào)用方法:[{}]", method);
                    log.info("方法參數(shù):[{}]", JSON.toJSONString(args));
                    log.info("target類:[{}]", target);
                });
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末骏庸,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子年叮,更是在濱河造成了極大的恐慌具被,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件只损,死亡現(xiàn)場(chǎng)離奇詭異一姿,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)改执,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門啸蜜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來坑雅,“玉大人辈挂,你說我怎么就攤上這事」粒” “怎么了终蒂?”我有些...
    開封第一講書人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)遥诉。 經(jīng)常有香客問我拇泣,道長(zhǎng),這世上最難降的妖魔是什么矮锈? 我笑而不...
    開封第一講書人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任霉翔,我火速辦了婚禮,結(jié)果婚禮上苞笨,老公的妹妹穿的比我還像新娘债朵。我一直安慰自己,他們只是感情好瀑凝,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開白布序芦。 她就那樣靜靜地躺著,像睡著了一般粤咪。 火紅的嫁衣襯著肌膚如雪谚中。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,111評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音宪塔,去河邊找鬼磁奖。 笑死,一個(gè)胖子當(dāng)著我的面吹牛蝌麸,可吹牛的內(nèi)容都是我干的点寥。 我是一名探鬼主播,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼来吩,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼敢辩!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起弟疆,我...
    開封第一講書人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤戚长,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后怠苔,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體同廉,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年柑司,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了迫肖。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡攒驰,死狀恐怖蟆湖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情玻粪,我是刑警寧澤隅津,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站劲室,受9級(jí)特大地震影響伦仍,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜很洋,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一充蓝、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧喉磁,春花似錦谓苟、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至斤讥,卻和暖如春纱皆,著一層夾襖步出監(jiān)牢的瞬間湾趾,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工派草, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留搀缠,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓近迁,卻偏偏與公主長(zhǎng)得像艺普,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子鉴竭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345