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.JoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.stereotype.Component;
//@Aspect:表示该类为切面类
@Aspect
//@Component:表示该类由Spring管理
@Component
public class logAspect {
//@Before:表示before方法在被通知的程序类的方法执行之前执行
//execution():表示需要被通知的类中的add方法,add方法可以用通配符表示,那就表示该类中所有的方法都要被通知
@Before(value="execution(* com.alibaba.wlq.invoke.ArithmeticImp.add(double,double))")
//JoinPoint:是程序执行中的一个精确执行点,例如类中的一个方法。它是一个抽象的概念,在实现AOP时,并不需要去定义一个join point
public void before(JoinPoint joinpoint) {
//获得被通知程序类的参数,返回类型是一个数组
Object[] args = joinpoint.getArgs();
//获取被通知程序类的方法名,返回类型是字符串
String name = joinpoint.getSignature().getName();
System.out.println("alibaba------>the method "+name+" begin with"+Arrays.asList(args));
} //@After:后置通知,表示在类的方法执行后、类中的return方法执行前执行
@After(value="execution(* com.alibaba.wlq.invoke.ArithmeticImp.add(double,double))")
public void after() {
System.out.println("alibaba------>the method *** end result");
}
}
创建被通知的类的接口
package com.alibaba.wlq.invoke; public interface Arithmetic {
public double add(double a,double b);
}
创建被通知的类并且继承接口重写其中的方法
package com.alibaba.wlq.invoke; import org.springframework.stereotype.Component; @Component
public class ArithmeticImp implements Arithmetic{ @Override
public double add(double a, double b) {
double result = a + b;
System.out.println(result);
return result;
} }
配置文件中的配置
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.2.xsd"> <!-- 包扫描,前提加入aop的jar包 -->
<context:component-scan base-package="com.alibaba.wlq"></context:component-scan>
<!-- 开启切面注解 -->
<aop:aspectj-autoproxy/>
</beans>
测试类
package com.alibaba.wlq.test; import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; import com.alibaba.wlq.controller.UsersController;
import com.alibaba.wlq.invoke.Arithmetic;
import com.alibaba.wlq.invoke.ArithmeticImp; public class Test2 { public static void main(String[] args) {
// TODO Auto-generated method stub
ApplicationContext app = new ClassPathXmlApplicationContext("app3.xml");
Arithmetic arith = (Arithmetic) app.getBean("arithmeticImp");
arith.add(15.0, 20.0);
}
}
打印结果
alibaba------>the method add begin with[15.0, 20.0]
35.0
alibaba------>the method *** end result
使用xml配置文件
导入相应的jar包
创建接口并且创建相应的类实现该接口
package com.alibaba.wlq.invoke; public interface Metic {
public double add(double a,double b);
public double sub(double a,double b);
public double mul(double a,double b);
public double div(double a,double b);
}
package com.alibaba.wlq.invoke; public class MeticImp implements Metic{ @Override
public double add(double a, double b) {
double result = a + b;
System.out.println(result);
return result;
} @Override
public double sub(double a, double b) {
double result = a - b;
System.out.println(result);
return result;
} @Override
public double mul(double a, double b) {
double result = a * b;
System.out.println(result);
return result;
} @Override
public double div(double a, double b) {
double result = a / b;
System.out.println(result);
return result;
} }创建切面类
package com.alibaba.wlq.invoke; import java.util.Arrays; import org.aspectj.lang.JoinPoint; public class Invoke {
public void before(JoinPoint joinPoint) {
Object[] args = joinPoint.getArgs();
String name = joinPoint.getSignature().getName();
System.out.println("alibaba------>the method "+name+" begin with "+Arrays.asList(args));
}
public void after(JoinPoint joinPoint) {
String name = joinPoint.getSignature().getName();
System.out.println("alibaba------>the method "+name+" end result:");
}
public void afterreturn(Object result) {
System.out.println("result:========"+result);
}
}
配置文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.2.xsd"> <!-- 定义被通知的程序类 -->
<bean id="metic" class="com.alibaba.wlq.invoke.MeticImp"></bean> <!-- 定义切面类的Bean -->
<bean id="invoke" class="com.alibaba.wlq.invoke.Invoke"></bean> <!-- 配置切面 -->
<aop:config>
<!-- 定义表达式、切点 -->
<aop:pointcut expression="execution(* com.alibaba.wlq.invoke.*.*(..))" id="point"/>
<!-- 定义切面 -->
<aop:aspect ref="invoke">
<!-- 定义前置通知 -->
<aop:before method="before" pointcut-ref="point" />
<!-- 定义后置通知 -->
<aop:after method="after" pointcut-ref="point"/>
<!-- 定义返回通知returning属性值得名称要和方法中的参数名称一致 -->
<aop:after-returning method="afterreturn" pointcut-ref="point" returning="result"/>
</aop:aspect>
</aop:config>
</beans>
测试类
package Test; import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; import com.alibaba.wlq.invoke.Metic; public class Test1 {
public static void main(String[] args) {
ApplicationContext app = new ClassPathXmlApplicationContext("app.xml");
Metic arith = (Metic) app.getBean("metic");
arith.add(15, 10);
}
}输出结果
alibaba------>the method add begin with [15.0, 10.0]
25.0
alibaba------>the method add end result:
result:========25.0
AOP面向切面编程(使用注解和使用配置文件)的更多相关文章
- Spring AOP 面向切面编程相关注解
Aspect Oriented Programming 面向切面编程 在Spring中使用这些面向切面相关的注解可以结合使用aspectJ,aspectJ是专门搞动态代理技术的,所以比较专业. ...
- Spring -07 -AOP [面向切面编程] - 使用注解@+ AspectJ 方式实现环绕/前/后等通知 -超简洁 --静态代理/动态代理{JDK/cglib}
1.spring 不会自动去寻找注解,必须告诉 spring 哪些包下的类中可能有注解;使用注解来取代配置文件.1.1 引入xmlns:context ,指定扫描范围 <context:comp ...
- spring:AOP面向切面编程(注解)03
使用注解写aop时最好使用环绕通知写 切面类: /** * 用于记录日志的工具类,它里面提供了公共的代码 */ @Component("logger") @Aspect //表示当 ...
- AOP面向切面编程的四种实现
一.AOP(面向切面编程)的四种实现分别为最原始的经典AOP.代理工厂bean(ProxyFacteryBean)和默认自动代理DefaultAdvisorAutoProxyCreator以及Bea ...
- Spring:AOP面向切面编程
AOP主要实现的目的是针对业务处理过程中的切面进行提取,它所面对的是处理过程中的某个步骤或阶段,以获得逻辑过程中各部分之间低耦合性的隔离效果. AOP是软件开发思想阶段性的产物,我们比较熟悉面向过程O ...
- Spring Boot2(六):使用Spring Boot整合AOP面向切面编程
一.前言 众所周知,spring最核心的两个功能是aop和ioc,即面向切面和控制反转.本文会讲一讲SpringBoot如何使用AOP实现面向切面的过程原理. 二.何为aop aop全称Aspec ...
- 浅谈Spring AOP 面向切面编程 最通俗易懂的画图理解AOP、AOP通知执行顺序~
简介 我们都知道,Spring 框架作为后端主流框架之一,最有特点的三部分就是IOC控制反转.依赖注入.以及AOP切面.当然AOP作为一个Spring 的重要组成模块,当然IOC是不依赖于Spring ...
- 谈一谈AOP面向切面编程
AOP是什么 : AOP面向切面编程他是一种编程思想,是指在程序运行期间,将某段代码动态的切入到指定方法的指定位置,将这种编程方式称为面向切面编程 AOP使用场景 : 日志 事务 使用AOP的好处是: ...
- 基于SpringBoot AOP面向切面编程实现Redis分布式锁
基于SpringBoot AOP面向切面编程实现Redis分布式锁 基于SpringBoot AOP面向切面编程实现Redis分布式锁 基于SpringBoot AOP面向切面编程实现Redis分布式 ...
- 极简SpringBoot指南-Chapter05-SpringBoot中的AOP面向切面编程简介
仓库地址 w4ngzhen/springboot-simple-guide: This is a project that guides SpringBoot users to get started ...
随机推荐
- css进阶 05-CSS的一些小知识
05-CSS的一些小知识 #隐藏盒子的几种方式 隐藏盒子,有以下几种方式: (1)方式一: overflow:hidden; //隐藏盒子超出的部分 (2)方式二: display: none; ...
- 找和为K的两个元素
总时间限制:1000ms 内存限制: 65536kB 描述 在一个长度为n(n < 1000)的整数序列中,判断是否存在某两个元素之和为k. 输入 第一行输入序列的长度n和k,用空格分开. 第二 ...
- 【漏洞复现】Struts2-045分析(CVE-2017-5638)
如果需要大佬写好的脚本,可以直接去github上面搜 struts2 - 045 一个还比较出名的漏洞,因为涉及到利用Gopher协议反弹shell,所以写篇文章来简单学习下这个漏洞. Struts2 ...
- CSRF学习
前提环境:网站存在CSRF漏洞(也就是过于相信访问请求,只判断了用户是否存在cookie,并未判断请求的发起者) CSRF攻击原理,用户A需要转账,用户A正常向银行网站发送请求登录,登录成功后银行网站 ...
- 第九章 Nacos Config--服务配置
今天咱们接着 上一篇 第八章 SMS–短信服务 继续写 SpringCloud Alibaba全家桶 -> 第九章 Nacos Config–服务配置,废话不多说,开干 9.1 服务配置中心介绍 ...
- Azure Databricks 第一篇:创建工作区、集群和Notebook
Azure Databricks是一个可扩展的数据分析平台,基于Apache Spark.Azure Databricks 工作区(Workspace)是一个交互式的环境,工作区把对象(noteboo ...
- Java基础进阶:继承重点摘要,继承详解,方法重写注意事项,方法重载与重写的区别,抽象类,代码块, 附重难点,代码实现源码,课堂笔记,课后扩展及答案
继承重点摘要 *继承的特点: 子类在初始化之前,一定要先完成父类数据的初始化 子类在初始化之前,一定要先访问父类构造,完成父类数据的初始化 系统在每一个构造方法中默认隐藏了一句super(); 如果我 ...
- 用漫画的形式展现——什么是web
Web主要经历了web1.0和web2.0的阶段.万维网的初期都是web1.0的时代:静态页面. 在不同的时代,流行的web安全问题也不太相同.在web1.0时代,web安全主要是 Web1.0:sq ...
- Mapreduce实例--去重
数据去重"主要是为了掌握和利用并行化思想来对数据进行有意义的筛选.统计大数据集上的数据种类个数.从网站日志中计算访问地等这些看似庞杂的任务都会涉及数据去重. 数据去重的最终目标是让原始数据中 ...
- 负载均衡各个算法JAVA诠释版
00 前言 首先给大家介绍下什么是负载均衡(来自百科) 负载均衡建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展 网络设备和 服务器的带宽.增加 吞吐量.加强网络数据处理能力.提高网络的灵活 ...