动态代理工具类
2023-09-11 14:14:10 时间
我刚刚想着每次写动态代理的时候都会写非常多的代码,有点不值得,所以我写了一个实现动态代理的工具类。用户能够用JDK动态代理也能够使用CGLIB动态代理,我的ProxyUtils中提供了三种开发动态代理的方式。在实际用的过程中,能够继承Intercepter这个抽象类实如今逻辑代码前后加入控制代码。假设控制代码返回true那么证明能够通过,假设控制代码返回false说明验证不通过,假设不通过那么就返回你逻辑代码中返回的“0”值,假设你逻辑代码返回对象。那么会返回null,假设是其它类型则返回各种类型的零值,用的时候能够实现Intercepter类,也能够用匿名内部类,随你喜欢,以下是我的代码,一段代码代表一个文件,过后我会将代码再好好,封装然后打成一个jar包:
package com.utils.AOPInteface; public enum AOPMethod { JDKAOP,CGLIBAOP }
package com.utils.AOPInteface; public interface CheckCode { boolean intercepterBefore(); boolean intercepterAfter(); }
package com.utils.AOPInteface; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import net.sf.cglib.proxy.Enhancer; import net.sf.cglib.proxy.MethodInterceptor; import net.sf.cglib.proxy.MethodProxy; abstract class Intercepter implements CheckCode,InvocationHandler,MethodInterceptor{ private Object obj; public Intercepter(Object obj){ this.obj=obj; } final public Object getTarget(){ return obj; } @Override final public Object intercept(Object proxy, Method method, Object[] args, MethodProxy methodProxy) throws Throwable { Object o=null; boolean bef=intercepterBefore(); if(bef){ o=method.invoke(obj, args); }else{ return null; } boolean aft=intercepterAfter(); if(aft){ return o; }else{ return null; } } @Override final public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { return intercept(proxy, method, args, null); } }
package com.utils.AOPInteface; import java.lang.reflect.Proxy; import net.sf.cglib.proxy.Enhancer; public class ProxyUtils { public static Object getJDKProxy(Intercepter intercepter){ if(intercepter.getTarget().getClass().getInterfaces().length==0){ return getCGLIBProxy(intercepter); } return Proxy.newProxyInstance(intercepter.getTarget().getClass().getClassLoader(), intercepter.getTarget().getClass().getInterfaces(), intercepter); } public static Object getCGLIBProxy(Intercepter intercepter){ Enhancer enhancer=new Enhancer(); enhancer.setSuperclass(intercepter.getTarget().getClass()); enhancer.setCallback(intercepter); return enhancer.create(); } public static Object getProxy(AOPMethod amethod,Intercepter intercepter){ if(amethod==AOPMethod.JDKAOP){ return getJDKProxy(intercepter); }else{ return getCGLIBProxy(intercepter); } } static class Print{ public int print(){ System.out.println("Hello AOP!!!"); return 20; } } }
相关文章
- 代理重定向策略及其用户感受的分析
- Nginx反向代理的目录访问问题
- 代理转发工具详解
- Python爬虫开发:requests库的使用--ip代理参数的设置
- SAP ABAP和Java的动态代理实现
- 基于JDK动态代理实现的接口链式调用(Fluent Interface)工具
- XAI之GS:全局代理(Global Surrogate,对黑盒机器学习执行模型可解释性的技术)的简介、常用工具包、案例应用之详细攻略
- aiohttp/asyncio测试代理是否可用
- HTTP隧道ABPTTS——获取webshell的主机位于内网,并且该内网主机的icmp、dns、tcp和udp协议等都不能出网,唯一的数据通道是webshell搭建正向代理。 根据代理的稳定性、速度推荐Neo-reGeorg、reGeorg、abptts 三款工具。
- 代理模式