「java手动切面」怎么理解面向切面编程的切面?
本篇文章给大家谈谈java手动切面,以及怎么理解面向切面编程的切面?对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
Java配置切面的几种方式你都知道吗
演示5种方式配置文件AOP
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怎么运用切面编程生成日志
1.首先创建一个自定义注解拦截Controller类,代码如下
/**
* 自定义注解 拦截Controller
*/
@Target({ ElementType.PARAMETER, ElementType.METHOD })
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface ControllerLog {
String desc() default "";//标示默认打印空
}
2.创建一个打印日志的切面类,引入切面注解@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的切面能修改参数吗
java的切面能修改参数。方法:
1、用切面的方式,在切面对controller进行拦截。
2、过滤器,自定义一个过滤器,自定义wrapper实现HttpServletRequestWrapper
关于java手动切面和怎么理解面向切面编程的切面?的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
发布于:2022-12-12,除非注明,否则均为
原创文章,转载请注明出处。