SpringCloud快捷创建注解切面

首先需要明白,实现AOP的切面主要有以下几个要素:

使用@Aspect注解将一个java类定义为切面类

使用@Pointcut定义一个切入点,可以是一个规则表达式,比如下例中某个package下的所有函数,也可以是一个注解等。

根据需要在切入点不同位置的切入内容

使用@Before在切入点开始处切入内容

使用@After在切入点结尾处切入内容

使用@AfterReturning在切入点return内容之后切入内容(可以用来对处理返回值做一些加工处理)

使用@Around在切入点前后切入内容,并自己控制何时执行切入点自身的内容

使用@AfterThrowing用来处理当切入内容部分抛出异常之后的处理逻辑

@Aspect

@Component

@Order(1)//联想为包菜同心圆结构,order等级越小,先进入,第二次后执行

public class WebLogAspect {

private Logger logger =  LoggerFactory.getLogger(this.getClass());

/**

* 定义一个切入点.

* 解释下:

*

* ~ 第一个 * 代表任意修饰符及任意返回值.

* ~ 第二个 * 任意包名

* ~ 第三个 * 代表任意方法.

* ~ 第四个 * 定义在web包或者子包

* ~ 第五个 * 任意方法

* ~ .. 匹配任意数量的参数.

*/

@Pointcut("execution(public * com.kfit.*.web..*.*(..))")

publicvoid webLog(){}

@Before("webLog()")

publicvoid doBefore(JoinPoint joinPoint){

// 接收到请求,记录请求内容

logger.info("WebLogAspect.doBefore()");

ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();

HttpServletRequest request = attributes.getRequest();

// 记录下请求内容

logger.info("URL : " + request.getRequestURL().toString());

logger.info("HTTP_METHOD : " + request.getMethod());

logger.info("IP : " + request.getRemoteAddr());

logger.info("CLASS_METHOD : " + joinPoint.getSignature().getDeclaringTypeName() + "." + joinPoint.getSignature().getName());

logger.info("ARGS : " + Arrays.toString(joinPoint.getArgs()));

//获取所有参数方法一:

Enumeration<String> enu=request.getParameterNames();

while(enu.hasMoreElements()){

String paraName=(String)enu.nextElement();

System.out.println(paraName+": "+request.getParameter(paraName));

}

}

@AfterReturning("webLog()")

publicvoid  doAfterReturning(JoinPoint joinPoint){

// 处理完请求,返回内容

logger.info("WebLogAspect.doAfterReturning()");

}

}

原文地址:https://www.cnblogs.com/liveinpresent/p/11634469.html

时间: 2024-11-02 17:05:56

SpringCloud快捷创建注解切面的相关文章

@Aspect 注解切面解析

注解切面解析 注解切面解析器 /** * 注解切面解析器 */ public class BeanFactoryAspectJAdvisorsBuilder { /** * Bean 工厂 */ private final ListableBeanFactory beanFactory; /** * 生成 Advisor 的工厂 */ private final AspectJAdvisorFactory advisorFactory; /** * 切面 Bean 名称 */ @Nullable

[Spring实战系列](18)注解切面

使用注解来创建切面是AspectJ 5所引入的关键特性.在AspectJ 5之前,编写AspectJ切面需要学习一种Java语言的扩展,但是AspectJ面向注解的模型可以非常简单的通过少量注解把任意类转变为切面. 回顾一下Audience类,没有任何地方让它成为一个切面,我们不得不使用XML声明通知和切点. 我们通过@AspectJ注解,我们再看看Audience类,不需要任何额外的类或Bean声明就能将它转换为一个切面. package com.sjf.bean; /** * 歌手实体类 *

SpringBoot基于注解切面监听事件

创建监听器三步骤: 1.事件(event)可以封装和传递监听器中要处理的参数,如对象或字符串,并作为监听器中监听的目标. 2.监听器(listener)具体根据事件发生的业务处理模块,这里可以接收处理事件中封装的对象或字符串. 3.事件发布者(publisher)事件发生的触发者. 代码展示: pom.xml <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aspe

【Spring实战】—— 13 AspectJ注解切面

前面了解了典型的AOP基于配置的使用方法,下面介绍下如何依赖于注解来实现AOP. 基于注解降低了配置文件的复杂程度,但是引入了程序间的耦合,其中的优劣待用户自己判断了. 需要注意的是,确定AspectJ与JDK之间的版本,否则会报错,详情请见. 首先看一下基于注解的切面类,这时的切面不仅仅是一个POJO类了,与AOP进行了紧密的耦合.但是配置过程和方式都与原来的方式差不多. package com.spring.test.chap44; import org.aspectj.lang.annot

Eclipse的workspace的快捷创建

1.在已有的eclipse快捷方式,拷贝出一个副本,将该副本改成自己自定义的名称. 改名后:eclipse-mybatis 2.给eclipse-mybatis这个快捷方式,指定一个workspace.具体是在属性加上 -data workspace文件目录路径,如:-data D:\workspace_orm 2.1通过右键[属性]后,最加 2.2 这个路径:D:\workspace_orm如果系统中没有,则会自定创建.双击eclipse-mybatis快捷方式,你会看到一个全新的worksp

5、springcloud整合mybatis注解方式

公众号:java乐园 1.上一篇学习了服务提供者provider,但是并不是单单就学习了服务提供者.中间还穿插使用了Hikari数据源和spring cloud整合mybatis.但是上篇使用mybatis时还是沿用了老的方式,需要配置mapper对应的xml文件.先来看看上篇使用mybatis的主要步骤一. pom.xml文件引用 <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis

Spring4深入理解AOP02----AOP简介,AspectJ基于注解(5种通知,切面优先级)

参考代码下载github:https://github.com/changwensir/java-ee/tree/master/spring4 一.AOP简介 ?AOP(Aspect-Oriented Programming, 面向切面编程):是一种新的方法论,是对传统OOP(Object-OrientedProgramming,面向对象编程)的补充. ?AOP 的主要编程对象是切面(aspect),而切面模块化横切关注点. ?在应用 AOP 编程时,仍然需要定义公共功能,但可以明确的定义这个功

AOP面向切面编程(使用注解和使用配置文件)

Aop(面向切面编程) 使用注解的方式: 加入相应的jar包: com.springsource.org.aopalliance-1.0.0.jar com.springsource.org.aspectj.weaver-1.6.8.RELEASE.jar sping-aspects-4.3.3.RELEASE.jar 创建一个切面类 package com.alibaba.wlq.invoke; import java.util.Arrays; import org.aspectj.lang.

Spring之AOP基本概念及通过注解方式配置AOP

为什么使用AOP 传统方法 AOP前前奏 首先考虑一个问题,假设我们要设计一个计算器,有如下两个需求: - 在程序运行期间追踪正在放生的活动 - 希望计算器只能处理正数的运算 通常我们会用如下代码进行实现: 定义一个接口: public interface ArithmeticCalculator { int add(int i, int j); int sub(int i, int j); int mul(int i, int j); int div(int i, int j); } 实现类(