zoukankan      html  css  js  c++  java
  • SpringMvc 面向切面1

    1.配置文件

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
     "http://www.springframework.org/dtd/spring-beans.dtd">
    <beans>
    
      <bean id="log" class="com.gc.action.LogAround"></bean>
      <bean id="timeBook" class="com.gc.action.TimeBook"></bean>
      
      <!-- logaround -->
      <bean id="logProxy" class="org.springframework.aop.framework.ProxyFactoryBean">
      
      //该配置也可以去掉
      <property name="proxyInterfaces">
       <value>com.gc.action.ITimeBook</value>
      </property>
      
       <property name="target">
       <ref bean="timeBook"></ref>
      </property>
      
      <!-- 指定要代理的类 -->
       <property name="interceptorNames">
        <list>
        <value>log</value>
        </list>
      </property>
      
      
      </bean>
      </beans>
    View Code

    2.LogAround

    package com.gc.action;
    
    import org.aopalliance.intercept.MethodInterceptor;
    import org.aopalliance.intercept.MethodInvocation;
    
    public class LogAround implements MethodInterceptor {
    
        @Override
        public Object invoke(MethodInvocation arg0) throws Throwable {
            // TODO Auto-generated method stub
            
            Object result=null;
            
            try
            {
                System.out.println("aop 之前");
                result=arg0.proceed();
                
                return result;
            }
            
            finally{
                
                System.out.println("aop 之后");
                
            }
        
        }
    
    }
    View Code

    3.TimeBook

    package com.gc.action;
    
    public class TimeBook implements ITimeBook {
    
        @Override
        public void doAudit(String name) {
            // TODO Auto-generated method stub
            System.out.println("laaaaaaaaaaaaa");
        }
    
    }
    View Code

    4.ITimeBook

    package com.gc.action;
    
    public interface ITimeBook {
    
        public void doAudit(String name);
    }
    View Code

    5. 测试

      ApplicationContext context=new FileSystemXmlApplicationContext("config-aop.xml");
              ITimeBook tb=(ITimeBook)context.getBean("logProxy");
              tb.doAudit("xiaox");
    View Code
  • 相关阅读:
    「训练反思18」 (8.16) 认清自己
    「训练日志17」 (8.12) 崩盘
    「训练日志16」 8.11 下坠
    「训练日志15」 (8.10)
    「训练反思15」(8.10)
    「训练日志14 」(8.9) 失败
    训练日志13 (8.7)
    Linux 设置vim指令
    训练日志12 (8.5)
    训练反思12 (8.5)
  • 原文地址:https://www.cnblogs.com/tiancai/p/6734356.html
Copyright © 2011-2022 走看看