7.AOP编程

注解和xml混合使用

1.将全部的bean都配置xmljava

<bean id="" class="">spring

2.将全部的依赖都使用注解编程

@Autowired设计模式

默认不生效。为了生效,须要在xml配置:<context:annotation-config>缓存

 

总结:安全

注解1<context:component-scan base-package=" ">框架

注解2<context:annotation-config>ide

1.通常状况两个注解不一块儿使用。函数式编程

2. “注解1”扫描含有注解(@Component 等)类,注入注解自动生效。函数

“注解2”只在xml和注解(注入)混合使用时,使注入注解生效。

 

1、AOP

 AOP介绍

  什么是AOP

  在软件业,AOPAspect Oriented Programming的缩写,意为:面向切面编程,经过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOPOOP(面向对象编程)的延续,是软件开发中的一个热点,也是Spring框架中的一个重要内容,是函数式编程的一种衍生范型。利用AOP能够对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度下降,提升程序的可重用性,同时提升了开发的效率。

 AOP采起横向抽取机制,取代了传统纵向继承体系重复性代码

 经典应用:事务管理、性能监视、安全检查、缓存 、日志等

 Spring AOP使用纯Java实现,不须要专门的编译过程和类加载器,在运行期经过代理方式向目标类织入加强代码

 AspectJ是一个基于Java语言的AOP框架Spring2.0开始,Spring AOP引入对Aspect的支持,AspectJ扩展了Java语言,提供了一个专门的编译器,在编译时提供横向代码的织入

 

AOP实现原理

  aop底层将采用代理机制进行实现。

接口 + 实现类 :spring采用 jdk 动态代理Proxy

  实现类:spring 采用 cglib字节码加强

 

 AOP术语【掌握】

1.target:目标类,须要被代理的类。例如:UserService

 

2.Joinpoint(链接点):所谓链接点是指那些可能被拦截到的方法。例如:全部的方法

 

3.PointCut 切入点:已经被加强的链接点。例如:addUser()

 

4.advice 通知/加强,加强代码。例如:afterbefore

 

5. Weaving(织入):是指把加强advice应用到目标对象target来建立新的代理对象proxy的过程.

 

6.proxy 代理类

 

7. Aspect(切面): 是切入点pointcut和通知advice的结合

 

一个线是一个特殊的面。

 

一个切入点和一个通知,组成成一个特殊的面。

 

 

 

 

 

手动方式

 JDK动态代理

 JDK动态代理 对“装饰者”设计模式 简化。使用前提:必须有接口

1.目标类:接口 + 实现类

2.切面类:用于存通知 MyAspect

3.工厂类:编写工厂生成代理

4.测试

  目标类

UserService.java
package com.jd.proxy.jdk;

/**
 * @author weihu
 * @date 2018/8/15/015 23:35
 */
public interface UserService {

    void addUser();
    void updateUser();
    void deleteUser();
}

 

  切面类

MyAspect.java
package com.jd.proxy.jdk;

/**
 * @author weihu
 * @date 2018/8/15/015 23:37
 */
public class MyAspect {

    public void before(){
        System.out.println("鸡首");
    }

    public void after(){
        System.out.println("牛后");
    }
}

 

 

工厂

MyBeanFactory.java
package com.jd.proxy.jdk;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

/**
 * @author weihu
 * @date 2018/8/15/015 23:39
 */
public class MyBeanFactory {

    public static UserService createService(){
        // 1.目标类
        UserService userService=new UserServiceImpl();
        // 2.切面类
        MyAspect myAspect=new MyAspect();
        /* 3 代理类:将目标类(切入点)和 切面类(通知) 结合 --> 切面
         *     Proxy.newProxyInstance
         *         参数1:loader ,类加载器,动态代理类 运行时建立,任何类都须要类加载器将其加载到内存。
         *             通常状况:当前类.class.getClassLoader();
         *                     目标类实例.getClass().get...
         *         参数2:Class[] interfaces 代理类须要实现的全部接口
         *             方式1:目标类实例.getClass().getInterfaces()  ;注意:只能得到本身接口,不能得到父元素接口
         *             方式2:new Class[]{UserService.class}
         *             例如:jdbc 驱动  --> DriverManager  得到接口 Connection
         *         参数3:InvocationHandler  处理类,接口,必须进行实现类,通常采用匿名内部
         *             提供 invoke 方法,代理类的每个方法执行时,都将调用一次invoke
         *                 参数31:Object proxy :代理对象
         *                 参数32:Method method : 代理对象当前执行的方法的描述对象(反射)
         *                     执行方法名:method.getName()
         *                     执行方法:method.invoke(对象,实际参数)
         *                 参数33:Object[] args :方法实际参数
         *
         */
        UserService proxService = (UserService)Proxy.newProxyInstance(
                MyBeanFactory.class.getClassLoader(),
                userService.getClass().getInterfaces(),
                new InvocationHandler() {

                    @Override
                    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {

                        //前执行
                        myAspect.before();

                        //执行目标类的方法
                        Object obj = method.invoke(userService, args);

                        //后执行
                        myAspect.after();

                        return obj;
                    }
                });

        return proxService;
    }
}
UserServiceImpl.java
package com.jd.proxy.jdk;

/**
 * @author weihu
 * @date 2018/8/15/015 23:36
 */
public class UserServiceImpl implements UserService{

    @Override
    public void addUser() {
        System.out.println("proxy.jdk.addUser");
    }

    @Override
    public void updateUser() {
        System.out.println("proxy.jdk.updateUser");

    }

    @Override
    public void deleteUser() {
        System.out.println("proxy.jdk.updateUser");

    }
}
 

  测试

TestJDK.java
package com.jd.proxy.jdk;

import org.junit.Test;

/**
 * @author weihu
 * @date 2018/8/15/015 23:48
 */
public class TestJDK {

    @Test
    public void testJDK(){
        UserService userService=MyBeanFactory.createService();
        userService.addUser();
        userService.updateUser();
        userService.deleteUser();
    }
}
相关文章
相关标签/搜索