zoukankan      html  css  js  c++  java
  • springmvc配置aop

    直接看代码

    springmvc中的配置aop对 controller和它的子包进行拦截

    springmvc中的配置

    <!--xml头部配置需要有这几行代码-->
    xmlns:aop="http://www.springframework.org/schema/aop"
    http://www.springframework.org/schema/aop
    http://www.springframework.org/schema/aop/spring-aop.xsd
    
    
    <aop:aspectj-autoproxy proxy-target-class="true" />
    <bean id="logAopAction" class="com.um.framework.baseware.webadmin.modules.controller.core.LogAopAction"/>
    <!--aop执行操作的类-->
    package com.um.framework.baseware.webadmin.modules.controller.core;
    
    import org.aspectj.lang.ProceedingJoinPoint;
    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;
    
    @Aspect
    public class LogAopAction {
        //配置接入点,如果不知道怎么配置,可以百度一下规则
         @Pointcut("execution(* com.um.framework.baseware.webadmin.modules.controller..*.*(..))")  
         private void anyMethod(){
             System.out.println("log记录------------------------");
         }//定义一个切入点
         
         @Before("anyMethod() && args(name)")
            public void doAccessCheck(String name){
                System.out.println(name);
                System.out.println("前置通知--------------------------");
            }
            
            @AfterReturning("anyMethod()")
            public void doAfter(){
                System.out.println("后置通知-------------------------");
            }
            
            @After("anyMethod()")
            public void after(){
                System.out.println("最终通知---------------------------");
            }
            
            @AfterThrowing("anyMethod()")
            public void doAfterThrow(){
                System.out.println("例外通知-----------------------------------");
            }
            
            @Around("anyMethod()")
            public Object doBasicProfiling(ProceedingJoinPoint pjp) throws Throwable{
                System.out.println("进入环绕通知------------------------------");
                Object object = pjp.proceed();//执行该方法
                System.out.println("退出方法--------------------");
                return object;
            }
    }
  • 相关阅读:
    在linux下搭建wiki环境【转】
    GitLab版本管理【转】
    linux设备驱动中的并发控制【转】
    分享三个USB抓包软件---Bus Hound,USBlyzer 和-USBTrace【转】
    Git常用命令总结【转】
    Linux中断(interrupt)子系统之一:中断系统基本原理【转】
    大话Linux内核中锁机制之原子操作、自旋锁【转】
    自旋锁spin_lock和raw_spin_lock【转】
    Linux内核同步机制之(四):spin lock【转】
    spin_lock浅析【转】
  • 原文地址:https://www.cnblogs.com/guokai870510826/p/5977948.html
Copyright © 2011-2022 走看看