springAOP--学习和理解--用STS搭建一个AOP演示示例01

本文详细介绍了如何在Spring框架中利用AspectJ实现AOP(面向切面编程)。从项目创建开始,逐步讲解了pom.xml依赖配置、核心业务编写、切面定义与通知设置,包括前置、后置、环绕、返回后及异常通知,并通过实例展示了SayHello业务与WebLog切面的具体应用。

1 创建项目

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2 编写pom.xml文件,添加依赖

        <dependency>
          <groupId>org.aspectj</groupId>
          <!-- runtime包 -->
          <artifactId>aspectjrt</artifactId>
          <version>1.6.11</version>
        </dependency>
        <dependency>
          <groupId>org.aspectj</groupId>
          <!-- 织入包 -->
          <artifactId>aspectjweaver</artifactId>
          <version>1.6.11</version>
        </dependency>
        <!-- 用于动态代理,基于类的代理 -->
        <dependency>
          <groupId>cglib</groupId>
          <artifactId>cglib</artifactId>
          <version>2.1</version>
        </dependency>

这里的aop包不需要再添加,因为web包里已经包含

3 编写核心演示业务,比如SayHello

package com.fhzheng.demo.controller;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping(value="/aop7")
public class SayHello {
	
	@RequestMapping(value="/hello")
	public String sayHello(@RequestParam("name") String name) {
		return "Hello-------------"+name;
	}

}

4 编写切面,即增强业务部分,比如在控制台打印输出信息

这里,最关键的几个部分是

1 切面要用@Aspect和@Component注解,让容器知道它是切面

2 定义切点表达式,特别要注意表达式的覆盖面【或者叫覆盖范围】,特别是

  • 任意返回值类型
  • 任意子包
  • 任意类
  • 任意方法
  • 任意参数类型

3 通知的位置,即连接点的定义

  • 前置通知
  • 后置通知
  • 环绕通知
  • 返回后通知
  • 异常后通知

4 整个过程叫织入,整个过程要理解

  • 切面本身:在哪里做什么事情
  • 切点:在哪个范围使用这个切面【哪些包的哪些类的哪些方法】==【切点表达式】
  • 连接点:在哪个位置插入逻辑【之前之后包围异常等】
package com.fhzheng.demo.aspect;

import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;

@Aspect
@Component
public class WebLog {

	@Pointcut("execution(* com.fhzheng.demo.controller.*.*(..))")
	public void cut(){}
	
	@Before("cut()")
	public void doBefore() {
		System.out.println("前置通知");
	}
	
//	@Around("cut()")
//	public void doAround() {
//		System.out.println("环绕通知");
//	}
//	
	@After("cut()")
	public void doAfter() {
		System.out.println("后置通知");
	}
	
	@AfterReturning("cut()")
	public void doAfterReturning() {
		System.out.println("返回后通知");
	}
//	
//	@AfterThrowing("cut()")
//	public void doAfterThrowing() {
//		System.out.println("异常通知");
//	}
	
	
}

5 运行并测试

核心业务结果
在这里插入图片描述

切面运行结果
在这里插入图片描述

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值