欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

Java代碼體切面 java切面實現

Java配置切面的幾種方式你都知道嗎

演示5種方式配置文件AOP

創(chuàng)新互聯是專業(yè)的稱多網站建設公司,稱多接單;提供成都網站建設、成都網站制作,網頁設計,網站設計,建網站,PHP網站建設等專業(yè)做網站服務;采用PHP框架,可快速的進行稱多網站開發(fā)網頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網站,專業(yè)的做網站團隊,希望更多企業(yè)前來合作!

1. bean class="cn.hncu.spring4x.aop.Cat" id="cat"/bean

!-- 切點 --

bean class="org.springframework.aop.support.JdkRegexpMethodPointcut" id="pointcut"

property name="pattern" value=".*run.*"/property

/bean

!-- 通知 ,要自己寫--

bean class="cn.hncu.spring4x.aop.AroundAdvice" id="advice"/bean

!-- 切面=切點+通知 --

bean class="org.springframework.aop.support.DefaultPointcutAdvisor" id="advisor"

property name="advice" ref="advice"/property

property name="pointcut" ref="pointcut"/property

/bean

bean class="org.springframework.aop.framework.ProxyFactoryBean" id="catProxide"

property name="target" ref="cat"/property

property name="interceptorNames"

list

valueadvisor/value

/list

/property

/bean

2. bean class="cn.hncu.spring4x.aop.Cat" id="cat"/bean

!-- 切面=切點+通知 (把切點和通知寫成內部bean)--

bean class="org.springframework.aop.support.DefaultPointcutAdvisor" id="advisor"

property name="advice"

bean class="cn.hncu.spring4x.aop.AroundAdvice"/bean

/property

property name="pointcut"

bean class="org.springframework.aop.support.JdkRegexpMethodPointcut"

property name="patterns"

list

value.*run.*/value

value.*say.*/value

/list

/property

/bean

/property

/bean

bean class="org.springframework.aop.framework.ProxyFactoryBean" id="catProxide"

property name="target" ref="cat"/property

property name="interceptorNames"

list

valueadvisor/value

/list

/property

/bean

3.bean class="cn.hncu.spring4x.aop.Cat" id="cat"/bean

!--//直接在切面bean中配置“切點的正則表達式”,省去“切點bean”的配置 用到這個類 org.springframework.aop.support.RegexpMethodPointcutAdvisor --

bean class="org.springframework.aop.support.RegexpMethodPointcutAdvisor" id="advisor"

property name="advice"

bean class="cn.hncu.spring4x.aop.AroundAdvice"/bean

/property

property name="patterns"

list

value.*run.*/value

/list

/property

/bean

bean class="org.springframework.aop.framework.ProxyFactoryBean" id="catProxide"

property name="target" ref="cat"/property

property name="interceptorNames"

list

valueadvisor/value

/list

/property

/bean

4. bean class="cn.hncu.spring4x.aop.Cat" id="cat"/bean

!--//直接在切面bean中配置“切點的正則表達式”,省去“切點bean”的配置 用到這個類 org.springframework.aop.support.RegexpMethodPointcutAdvisor --

bean class="org.springframework.aop.support.RegexpMethodPointcutAdvisor" id="advisor"

property name="advice"

bean class="cn.hncu.spring4x.aop.AroundAdvice"/bean

/property

property name="patterns"

list

value.*run.*/value

/list

/property

/bean

!-- 自動代理 --

bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator"/bean

5. bean class="cn.hncu.spring4x.aop.Cat" id="cat"/bean

!--//直接在切面bean中配置“切點的正則表達式”,省去“切點bean”的配置 用到這個類 org.springframework.aop.support.RegexpMethodPointcutAdvisor --

bean class="org.springframework.aop.support.RegexpMethodPointcutAdvisor" id="advisor"

property name="advice"

bean class="cn.hncu.spring4x.aop.AroundAdvice"/bean

/property

property name="patterns"

list

value.*run.*/value

/list

/property

/bean

!-- 自動代理 --

bean class="cn.hncu.spring4x.aop.MyAutoProxy"/bean

使用java語言,如何對一個類中的靜態(tài)方法做切面編程?

aop的事務代理機制最重要的放心是確定切入點,面,通知.具體看代碼,下面是在spring中配置的我自己寫的一個異常處理的aop作用類 ,該配置切入面在于在controller包下的所有類的所有注解為aspect的切面類,通知類型為表示在目標方法之前切入,切入點為controller包下的所有類所有方法.至于樓主所說的靜態(tài)方法對于事務機制應該沒什么區(qū)別吧,只要用within方法一樣可以的

!-- 定義共同處理組件 --

bean id="loggerBean"

class="org.tedu.cloudnote.aspect.LoggerBean"

/bean

!-- 將loggerBean組件切入到Controller方法上 --

aop:config

!-- 要切入哪個共同處理組件,ref指定共同組件id值 --

aop:aspect ref="loggerBean"

!-- aop:before表示在目標方法之前切入,

method指定方法名;pointcut指定目標組件 --

aop:before method="logController"

pointcut="within(org.tedu.cloudnote.controller..*)"/

/aop:aspect

/aop:config

之后這個bean所定義的 自定義類的代碼如下 ,希望樓主給個采納,如果問友喜歡,也可以給我個贊哦,摸摸大

package org.tedu.cloudnote.aspect;

import org.aspectj.lang.annotation.Aspect;

import org.aspectj.lang.annotation.Before;

import org.springframework.stereotype.Component;

//封裝共同處理的組件

@Component//掃描,等價于bean定義

@Aspect//等價于aop:aspect ref=""

public class LoggerBean {

//要在Controller.execute開始位置切入

//方法規(guī)則:public void 方法名(){...} (前置通知)

@Before("within(org.tedu.cloudnote.controller..*)")

//等價于aop:before method="logController" pointcut=""

public void logController(){

System.out.println("進入Controller組件處理");

}

}

java怎么運用切面編程生成日志

1.首先創(chuàng)建一個自定義注解攔截Controller類,代碼如下

/**

* 自定義注解 攔截Controller

*/

@Target({ ElementType.PARAMETER, ElementType.METHOD })

@Retention(RetentionPolicy.RUNTIME)

@Documented

public @interface ControllerLog {

String desc() default "";//標示默認打印空

}

2.創(chuàng)建一個打印日志的切面類,引入切面注解@Aspect,

新建方法代碼如下:

// Controller層切點

@Pointcut("@annotation(org.springframework.web.bind.annotation.RequestMapping)")

public void recordLog() {

}

@Around("recordLog()")

public Object around(ProceedingJoinPoint pjp) throws Throwable {

// ExPatternParser.initLogger();

long start = System.currentTimeMillis();

Object[] args = pjp.getArgs();

String remark = this.getControllerMethodDescription(pjp);

Object retVal = null;

try {

retVal = pjp.proceed();

} catch (Throwable e) {

// TODO Auto-generated catch block

logger.error("請求失敗" + e.toString(),e);

remark = remark + "。Exception Cause By " + e.toString();

throw e;

}finally{

long end = System.currentTimeMillis();

long cost = end - start;

//打印訪問日志

// Controller中所有方法的參數,前兩個分別為:Request,Response

if(args != null args.length 0){

Object o = args[0];

if(o instanceof HttpServletRequest){

HttpServletRequest request = (HttpServletRequest) args[0];

PrintLog.visit(request, cost,remark);

}

}

}

return retVal;

}

/**

* 獲取注解中對方法的描述信息 用于Controller層注解

* @param joinPoint切點

* @return 方法描述

* @throws Exception

*/

public static String getControllerMethodDescription(ProceedingJoinPoint 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) {

ControllerLog controllerLog = method.getAnnotation(ControllerLog.class);

if(controllerLog !=null){

description =

controllerLog.desc();

}

break;

}

}

}

return description;

}

3.然后在每個Controller類上加上注解:

@ControllerLog(desc = "要 打印的日志內容")

java切點和切面講解,主要是干什么的,有什么作用,省代碼?高效?務必通俗易懂,跪謝

切點和通知構成切面;比如現在你想在所有的save方法前加一些相同代碼,那你的切點就是save前,然后通知就是你所加的代碼,而這兩個整體構成一個切面,當你那天突然覺得這段代碼需要改一下,那你就可以直接改通知內容,結果是開發(fā)效率變高,代碼量減少,耦合度降低,你可以參考聲明式事務的配置方式來梳理這部分知識,會快一點

本文名稱:Java代碼體切面 java切面實現
URL分享:http://chinadenli.net/article26/ddodsjg.html

成都網站建設公司_創(chuàng)新互聯,為您提供網站維護虛擬主機電子商務軟件開發(fā)定制開發(fā)企業(yè)建站

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

微信小程序開發(fā)