jdk动态代理和CGLIB动态代理的区别:
jdk动态代理只能针对实现了接口的目标代理, CGLIB是针对类来实现动态代理,当没有实现接口的类需要代理时,就需要通过CGLIB来实现动态代理。
jdk动态代理:
User.java
public class User { private String uname; private String email; public String getUname() { return uname; } public void setUname(String uname) { this.uname = uname; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } }
UserDao.java
public interface UserDao { @Test public void read(String uname,String email); @Test public void write(String uname,String email); }
UserDaoImpl.java
public class UserDaoImpl implements UserDao { @Override public void read(String uname, String email) { System.out.println("read " + uname + "'s Email is :"+email); } @Override public void write(String uname, String email) { System.out.println("write " + uname + "'s Email is :"+email); } }
UserInvocationHandler.java
public class UserInvocationHandler implements InvocationHandler { private Object obj = null; public UserInvocationHandler(Object obj){ this.obj = obj; } private String getMethodName(Method method){ return method.getName(); } private Annotation[] getAnnotation(Method method){ return method.getAnnotations(); } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { Object result = null; System.out.println(proxy.getClass().getSimpleName()); System.out.println("begin..."); //获取方法名 String methodName = getMethodName(method); System.out.println("方法名称:"+methodName); //获取方法上的注解 Annotation[] annotation = getAnnotation(method); System.out.println("注解名称:"+annotation[0].toString()); result = method.invoke(obj, args); System.out.println("end..."); return result; } }
UserTest.java
public class UserTest { public static void main(String[] args) { UserDao uDao = new UserDaoImpl(); UserInvocationHandler invocationHandler = new UserInvocationHandler(uDao); UserDao proxy = (UserDao) Proxy.newProxyInstance(uDao.getClass().getClassLoader(), uDao.getClass().getInterfaces(), invocationHandler); proxy.write("xuwei", "123@123.com"); proxy.read("xuwei", "123@123.com"); } }
运行结果:
$Proxy0 begin... 方法名称:write 注解名称:@org.junit.Test(expected=class org.junit.Test$None, timeout=0) write xuwei's Email is :123@123.com end... $Proxy0 begin... 方法名称:read 注解名称:@org.junit.Test(expected=class org.junit.Test$None, timeout=0) read xuwei's Email is :123@123.com end...
CGLIB动态代理:
BookDao.java
public interface BookDao { public void create(); public void query(); public void update(); public void delete(); }
BookDaoImpl.java
public class BookDaoImpl implements BookDao{ @Override public void create() { System.out.println("create() is running..."); } @Override public void query() { System.out.println("query() is running..."); } @Override public void update() { System.out.println("update() is running..."); } @Override public void delete() { System.out.println("delete() is running..."); } }
MyCglibProxy.java
public class MyCglibProxy implements MethodInterceptor { public Enhancer enhancer = new Enhancer(); private String name; public MyCglibProxy(String name) { this.name = name; } @Override public Object intercept(Object object, Method method, Object[] args, MethodProxy methodProxy) throws Throwable { System.out.println("调用的方法是:" + method.getName()); // 对用户进行判断 if (!"boss".equals(name)) { System.out.println("你没有权限!"); return null; } Object result = methodProxy.invokeSuper(object, args); return null; } }
MyProxyFilter.java
public class MyProxyFilter implements CallbackFilter { @Override public int accept(Method arg0) { if (!"query".equalsIgnoreCase(arg0.getName())) return 0; return 1; } }
MyCglibProxyFactory.java
public class MyCglibProxyFactory { public static BookDaoImpl getProxyInstance(MyCglibProxy myProxy) { Enhancer en = new Enhancer(); // 进行代理 en.setSuperclass(BookDaoImpl.class); en.setCallback(myProxy); // 生成代理实例 return (BookDaoImpl) en.create(); } public static BookDaoImpl getAuthInstanceByFilter(MyCglibProxy myProxy) { Enhancer en = new Enhancer(); // 进行代理 en.setSuperclass(BookDaoImpl.class); en.setCallbacks(new Callback[]{myProxy,NoOp.INSTANCE}); en.setCallbackFilter(new MyProxyFilter()); // 生成代理实例 return (BookDaoImpl) en.create(); } }
MyCglibClient.java
public class MyCglibClient { public static void main(String[] args) { BookDaoImpl service = MyCglibProxyFactory.getProxyInstance(new MyCglibProxy("boss")); service.create(); BookDaoImpl service2 = MyCglibProxyFactory.getProxyInstance(new MyCglibProxy("john")); service2.create(); BookDaoImpl service3 = MyCglibProxyFactory.getAuthInstanceByFilter(new MyCglibProxy("join")); service3.create(); BookDaoImpl service4 = MyCglibProxyFactory.getAuthInstanceByFilter(new MyCglibProxy("john")); service4.query(); } }
运行结果:
调用的方法是:create create() is running... 调用的方法是:create 你没有权限! 调用的方法是:create 你没有权限! query() is running...
相关推荐
jdk和cglib动态代理的例子{jar包+源码} 解压:如有问题 用快压
2. CGLib代理项目: - src/main/java:包含目标类 - target/classes:编译后的class文件,包括目标类的class文件,以及由CGLib生成的子类class文件 - 测试代码:展示如何使用Enhancer创建代理对象并调用方法 这...
Spring AOP 中 JDK 和 CGLib 动态代理哪个更快?
- **CGLIB代理**适用于目标类没有接口或者不希望修改原有接口的情况,其性能通常优于JDK代理,因为它是基于字节码生成的子类,而JDK代理需要反射调用接口方法。 在实际开发中,如Spring AOP框架就同时支持JDK和...
- **CGLIB代理**:CGLIB通过ASM生成一个继承自目标类的新类,这个新类覆盖了目标类的所有方法,并在这些方法内部调用拦截器链。在运行时,这个新类的实例作为代理对象。 5. **优缺点**: - JDK代理简单易用,但...
JDK和CGlib是两种常用的动态代理实现方式,它们各自有不同的特性和使用场景。 首先,我们来详细了解一下JDK动态代理。JDK动态代理基于接口实现,它要求被代理的对象必须实现至少一个接口。通过`java.lang.reflect....
Spring 框架中 JDK 动态代理和 CGLIB 动态代理是 Spring AOP 中一个非常重要的知识点。Spring AOP 框架会根据实际情况选择使用 JDK 的动态代理还是 CGLIB 的动态代理。 JDK 动态代理是 Java 自带的动态代理机制,它...
本篇文章将深入探讨JDK动态代理和CGLIB代理的区别,以及它们在实际应用中的选择。 首先,JDK动态代理主要依赖于java.lang.reflect.Proxy类和java.lang.reflect.InvocationHandler接口。Proxy类用于创建一个代理对象...
本篇将详细探讨JDK动态代理和Cglib动态代理,并通过源码实例来加深理解。 首先,JDK动态代理是Java内置的一种机制,它依赖于`java.lang.reflect.Proxy`类和`java.lang.reflect.InvocationHandler`接口。`Proxy`类...
Spring框架是AOP实现的一个典范,它提供了两种主要的动态代理方式:JDK动态代理和CGLib动态代理。 **JDK动态代理**: JDK动态代理基于Java的反射API实现,适用于接口代理。当目标对象实现了至少一个接口时,Spring...
JDK代理和Cglib代理是两种常用的动态代理实现方式。 **JDK代理(Java Dynamic Proxy)** JDK动态代理是Java标准库提供的一种代理机制,位于`java.lang.reflect`包下的`Proxy`类和`InvocationHandler`接口。JDK代理...
分别使用jdk和cglib实现动态代理,包含UML图。还有相关的博客链接:http://blog.csdn.net/y_love_f/article/details/46345581.博客中有具体的代理解释
JDK动态代理和CGLIB代理是两种常用的实现方式。 首先,我们来看看JDK动态代理。JDK动态代理主要通过`java.lang.reflect.Proxy`类和`java.lang.reflect.InvocationHandler`接口来实现。Proxy类用于创建一个代理对象...
本文将深入探讨两种主要的Java代理实现:JDK动态代理和CGLIB代理。 一、JDK动态代理 JDK动态代理基于接口实现,它要求被代理的类必须实现至少一个接口。在运行时,Java会动态地创建一个新的类,这个类实现了与原始...
在Java开发中,JDK和CGLib是两种常见的实现动态代理的技术,它们允许我们在运行时创建对象的代理,以增强或拦截对象的方法调用。动态代理在AOP(面向切面编程)中扮演着重要角色,使得我们可以方便地添加如日志、...
JDK动态代理和CGlib动态代理是Java中实现这一目标的两种主要方式。 ### JDK动态代理 JDK动态代理基于Java的接口实现。如果一个类实现了至少一个接口,我们就可以为这个类创建一个动态代理。动态代理通过`java.lang....
主要存在两种常见的动态代理技术:JDK动态代理和CGLIB(Code Generation Library)动态代理。本文将深入探讨这两种技术的区别和原理。 **JDK动态代理**: JDK动态代理是Java标准库提供的一种代理机制,位于`java....
Java中的动态代理、反射和...总之,理解和掌握JDK动态代理、CGLIB动态代理、反射和拦截器是提升Java开发技能的关键步骤。通过实际操作这些示例,你将能够更好地应用这些技术到实际项目中,提高代码的灵活性和可维护性。
动态代理主要分为两种实现方式:JDK动态代理和CGLIB动态代理。 1. JDK动态代理: JDK动态代理基于Java的反射API,它要求被代理的目标对象必须实现一个或多个接口。JDK动态代理的核心类是`java.lang.reflect.Proxy`...
java常用设计模式及JDK与CGLIB实现动态代理区别(源码) /** * 使用cglib动态代理 * @author * */ public class BookFacadeProxy implements MethodInterceptor{ private Object target; @Override public...