动态代理两种实现方法
原创
©著作权归作者所有:来自51CTO博客作者wx60f90dec4c4e0的原创作品,请联系作者获取转载授权,否则将追究法律责任
1.概述
在spring 开源框架中,很多情况下使用了动态代理技术,比如 FEIGN, MYBATIS 的Mapper接口,还有比如spring 的事务管理。
2. 动态代理实现
动态代理实现技术有两种方式。
1.使用jdk的动态代理
只适用在有接口的情况下
2.使用CGLIB
2.1 使用接口代理的方式
使用代码实现:
public interface IUserService {
String addUser(String name);
}
public class UserService implements IUserService{
@Override
public String addUser(String name) {
System.err.println("添加用户:" +name);
return "user:" + name ;
}
}
public class DynamicProxy {
public static <T> T createProxy(T servie){
T proxy = (T) Proxy.newProxyInstance(DynamicProxy.class.getClassLoader(),
servie.getClass().getInterfaces(), new InvocationHandler() {
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
System.err.println("前置执行。。。");
method.invoke(servie,args);
System.err.println("后置执行。。。");
return null;
}
});
return proxy;
}
}
public class JdkProxyDemo {
public static void main(String[] args) {
IUserService iUserService=new UserService();
IUserService proxy= DynamicProxy.createProxy(iUserService);
proxy.addUser("老王");
}
}
2.2 使用GCLIB的方式
<dependency>
<groupId>cglib</groupId>
<artifactId>cglib</artifactId>
<version>2.2.2</version>
</dependency>
public class UserService {
String addUser(String name) {
System.err.println(name);
return name;
}
}
public class ServiceInterceptor implements MethodInterceptor {
@Override
public Object intercept(Object obj, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
System.err.println("前置执行...");
Object result = methodProxy.invokeSuper(obj, objects);
System.err.println("后置执行...");
return result;
}
}
public class ProxyDemo {
public static void main(String[] args) {
Enhancer enhancer = new Enhancer();
enhancer.setSuperclass(UserService.class);
enhancer.setCallback(new ServiceInterceptor());
UserService userService = (UserService) enhancer.create();
userService.addUser("老王");
}
}