网站首页 > java教程 正文
一、分类
- 按照代理创建的时期进行分类,可以分为两类:静态代理、动态代理。
- 静态代理的代理类=原始类+增强(额外功能)+和原始类实现同一个接口,即基于接口的代理。
- 动态代理又分为jdk动态代理,其也是基于接口的代理;cglib的动态代理。
二、动态代理的实现
1、实现jdk的动态代理,即基于接口的代理
import lombok.extern.slf4j.Slf4j;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Proxy;
@Slf4j
public class TestProxy {
public static void main(String[] args) {
TestService testService=new TestServiceImpl();
//2. 创建JDK动态代理
InvocationHandler handler = (proxy, method, args1) -> {
System.out.println("------proxy pass before --------");
//原始方法运行
Object ret = method.invoke(testService, args1);
System.out.println("------proxy pass after --------");
return ret;
};
TestService testServiceProxy = (TestService) Proxy.newProxyInstance(TestServiceImpl.class.getClassLoader(), testService.getClass().getInterfaces(), handler);
testServiceProxy.isPass();
}
interface TestService{
boolean isPass();
}
static class TestServiceImpl implements TestService{
@Override
public boolean isPass() {
log.info("测试jdk代理");
//测试代码
return false;
}
}
}
2、输出结果
- ------proxy pass before --------
- 19:53:51.279 [main] INFO com.xxx.xxx.controller.TestProxy - 测试jdk代理
- ------proxy pass after --------
3、实现cglib的动态代理
import lombok.extern.slf4j.Slf4j;
import org.springframework.cglib.proxy.Enhancer;
import org.springframework.cglib.proxy.MethodInterceptor;
import org.springframework.cglib.proxy.MethodProxy;
import java.lang.reflect.Method;
@Slf4j
public class TestProxy {
public static void main(String[] args) {
AddProxy addProxy=new AddProxy();
TestCglib testCglib=new TestCglib(addProxy);
addProxy= (AddProxy) testCglib.getProxy();
addProxy.test();
}
static class AddProxy{
public void test(){
log.info("..........业务逻辑..........");
}
}
static class TestCglib implements MethodInterceptor {
private Object trarget;
public TestCglib(Object trarget) {
this.trarget = trarget;
}
public Object getProxy() {
Enhancer enhancer = new Enhancer();
enhancer.setSuperclass(trarget.getClass());//目标对象
enhancer.setCallback(this);//
return enhancer.create();
}
@Override
public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
log.info("proxy pass before");
Object object = methodProxy.invoke(trarget, objects);
log.info("proxy pass after");
return object;
}
}
}
4、执行结果的输出
- 20:11:26.276 [main] INFO com.xxx.xxx.controller.TestProxy - proxy pass before
- 20:11:26.306 [main] INFO com.xxx.xxx.controller.TestProxy - ..........业务逻辑..........
- 20:11:26.306 [main] INFO com.xxx.xxx.controller.TestProxy - proxy pass after
猜你喜欢
- 2024-10-24 Java动态代理与静态代理以及它能为我们做什么
- 2024-10-24 Java 设计模式 之 代理模式 (1)(java设计模式之代理模式)
- 2024-10-24 Java设计模式:代理模式 vs. 装饰模式
- 2024-10-24 设计模式篇——代理模式详解(面试再问你代理模式,这么回答他)
- 2024-10-24 动态代理大揭秘,带你彻底弄清楚动态代理
- 2024-10-24 面试:Java的代理模式动态代理和静态代理区别,aop用的什么代理
- 2024-10-24 Java设计模式之代理模式(java代理类是什么)
- 2024-10-24 JAVA设计模式——代理模式(java编写代理服务)
- 2024-10-24 23种java设计模式之:门面模式、享元模式、代理模式
- 2024-10-24 Java 17中的动态代理:实现灵活的代理模式
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)