Spring的AOP与mybatis的插件与拦截器到动态代理

动态代理
2019年时候,我就学习了动态代理,不过当时只是依葫芦画瓢实现了而已,对于这个怎么用,还是不够明白
我先再次实现下动态代理

public class Test {
    static public void main(String[] arg) {
        DynaProxyHello helloproxy = new DynaProxyHello();
        Helloimplements hello = new Helloimplements();
        IHello ihello = (IHello) helloproxy.bind(hello);
        ihello.sayHello("Jerry");
    }
}

class DynaProxyHello implements InvocationHandler {
    private Object delegate;

    public Object bind(Object delegate) {
        this.delegate = delegate;
        return Proxy.newProxyInstance(
                this.delegate.getClass().getClassLoader(), this.delegate
                        .getClass().getInterfaces(), this);
    }

    public Object invoke(Object proxy, Method method, Object[] args)
            throws Throwable {
        Object result = null;
        try {
            System.out.println("问候之前的日志记录...");
            // JVM通过这条语句执行原来的方法(反射机制)
            result = method.invoke(this.delegate, args);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return result;
    }
}

interface IHello {
    void sayHello(String name);
    void sayGoogBye(String name);
}

class Helloimplements implements IHello {
    @Override
    public void sayHello(String name) {
        System.out.println("Hello " + name);
    }

    @Override
    public void sayGoogBye(String name) {
        System.out.println(name + " GoodBye!");
    }
}

基本上基于动态代理实现,也就是在InvocationHandler的invoke方法做增强,spring的AOP(JDK模式)是如此,mybatis的拦截器和插件也是如此

Spring的AOP原理
1、Spring在生成bean时候,如果加了注解并且有切面使用的,会生成代理对象而不是原生对象
2、JdkDynamicAopProxy的invoke就是InvocationHandler的invoke方法的增强
3、具体怎么实现,需要看源码

mybatis的插件及拦截器原理
mybatis重要组件有以下几个部分
Executor提供了增删改查的接口
StatementHandler负责处理Mybatis与JDBC之间Statement的交互
ResultSetHandler负责处理Statement执行后产生的结果集,生成结果列表
ParameterHandler是Mybatis实现Sql入参设置的对象

mybatis-plus的扩展,更多是对组件的重写
tkmybtis的实现,主要是对拦截器的使用

而拦截器的实现原理就是Plugin的invoke

你可能感兴趣的:(Spring,mybatis,反射,mybatis,spring,java)