Spring aop 例子

Stella981
• 阅读 706

在使用spring aop的时候报错了:The prefix "aop" for element "aop:aspectj-autoproxy" is not bound.原因是有一些地址没有被引入: Spring aop 例子

 以下是一个完整配置AOP的例子。

 首先是文件项目结构:

Spring aop 例子

SpringAOPTest.java 复制代码

import java.util.ArrayList;
import java.util.List;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class SpringAOPTest {
    [@Test](https://my.oschina.net/azibug) public void interceptorTest(){
        ApplicationContext cxt = new ClassPathXmlApplicationContext("applicationContext-Test.xml");
        UserService userService = (UserService)cxt.getBean("userService");
        List list =new ArrayList();
        list =userService.queryUserList();
        System.out.println("sd:"+list.size());
    }
}

复制代码

applicationContext-Test.xml 复制代码

<?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"
    xmlns:tx="http://www.springframework.org/schema/tx" xmlns:jdbc="http://www.springframework.org/schema/jdbc"
    xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc"
     
    xsi:schemaLocation="
     http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
     http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
     http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-4.0.xsd
     http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
     http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd
     http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
    
    
    <!-- 通过配置的方式,定义bean  -->
    <bean id="userService" class="test.UserServiceImpl"></bean>

    <!-- 启用@AspectJ风格的切面声明 --> 
    <aop:aspectj-autoproxy/> 
    
    <!-- 通过配置的方式,定义日志切面bean  -->
    <bean id="aspetbean" class="test.LogInterceptor"/>

   <aop:config>
     <aop:aspect id="asp" ref="aspetbean">
        <!--定义切入点-->  
        <aop:pointcut id="mycut" expression="execution(* test.**.*(..))" />
        <!-- 第一个*代表所有的返回值类型 第二个*代表所有的类 第三个*代表类所有方法 最后一个..代表所有的参数。 -->
        <!--定义通知(Advice)-->  
        <aop:before pointcut-ref="mycut"  method="doAccessCheck" /> <!-- 前置通知  -->
        <aop:after-returning pointcut-ref="mycut"  method="doAfterReturning" /> <!-- 后置通知  -->
        <aop:after-throwing pointcut-ref="mycut"  method="doAfterThrowing" /> <!-- 例外通知  -->
        <aop:after pointcut-ref="mycut"  method="doAfter" /> <!-- 最后通知  -->
        <aop:around pointcut-ref="mycut"  method="doBasicProfiling" /> <!-- 环绕通知  -->
     </aop:aspect>
  </aop:config>
</beans>

复制代码

LogInterceptor.java 复制代码

import org.aspectj.lang.ProceedingJoinPoint;
/**
 * 切面 
 * 例子:日志记录
 */
public class LogInterceptor {    
    public void doAccessCheck() {
        System.out.println("前置通知");
    }
    public void doAfterReturning() {
        System.out.println("后置通知");
    }
    public void doAfter() {
        System.out.println("最终通知");
    }
    public void doAfterThrowing() {
        System.out.println("例外通知");
    }
    public Object doBasicProfiling(ProceedingJoinPoint pjp) throws Throwable {
        System.out.println("进入方法");
        Object result = pjp.proceed();
        System.out.println("退出方法");
        return result;
    }
}

复制代码

User.java
复制代码

public class User {
    private String id;
    private String name;
    private String sex;
    private int age;
    public String getId() {
        return id;
    }
    public void setId(String id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getSex() {
        return sex;
    }
    public void setSex(String sex) {
        this.sex = sex;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }   
}

复制代码

UserService.java
复制代码

import java.util.List;
public interface UserService {
    public User queryUserById(int id);    
    public List<User> queryUserList();
    
}

复制代码

UserServiceImpl.java 复制代码

import java.util.ArrayList;
import java.util.List;
public class UserServiceImpl implements UserService {    
    /**
     * 通过id查询用户信息
     */
    @Override
    public User queryUserById(int id) {
        System.out.println("=========进入queryUserById方法==========");
        User user = null;
        if(id==1){
            user = new User();
            user.setAge(18);
            user.setId("1");
            user.setName("张三");
            user.setSex("1");    
        }
        return user;
    }  
    /**
     * 查询用户列表
     */
    @Override
    public List<User> queryUserList() {
        System.out.println("=========进入queryUserList方法==========");
        User user1 = new User();
        user1.setAge(18);
        user1.setId("1");
        user1.setName("张三");
        user1.setSex("1");

        User user2 = new User();
        user2.setAge(18);
        user2.setId("1");
        user2.setName("张三");
        user2.setSex("1");

        ArrayList<User> userList = new ArrayList<User>();
        userList.add(user1);
        userList.add(user2);
        return userList;
    }
}

复制代码

运行结果: Spring aop 例子

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Stella981 Stella981
3年前
Spring3核心技术之AOP配置
在Spring配置文件中,所有AOP相关定义必须放在<aop:config标签下,该标签下可以有<aop:pointcut、<aop:advisor、<aop:aspect标签,配置顺序不可变。!(http://static.oschina.net/uploads/img/201511/25003650_G0NP.jpg)●
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这