Java反射高级应用--注入代码

       有时候我们需要改变一些系统平台里某些组件的执行流程,但限于系统平台的原因,不能通过修改源代码来直接实现,这时候反射这一大法宝就有了用武之地。下面的Demo就是一个简单的例子,通过平台对外曝露的接口,实现另类的包装,并注入我们自己的代码~

 

模拟系统平台的类:

 

package reflectInject;

public class SysComponent {
	private final Task sysTasker ;
	
	public SysComponent(){
		sysTasker = new Task() {
			
			@Override
			public void work() {
				System.out.println("Systasker is running....");
			}
		};
	}
	
	public void doWork(){
		sysTasker.work();
	}
}


上面的组件中用到的系统平台曝露的接口:

package reflectInject;

public interface Task {
	void work();
}


我们自己的Task接口的实现,其接收一个已有的Task,并对其进行了包装:

package reflectInject;

public class MyTasker implements Task {

	private Task innerTasker;
	
	
	
	public MyTasker(Task innerTasker) {
		super();
		this.innerTasker = innerTasker;
	}



	@Override
	public void work() {
		System.out.println("MyTasker is running...");
		if(innerTasker!=null){
			innerTasker.work();
		}
	}

}


 

下面就是重头戏了,看看我们的注入过程:

package reflectInject;

import reflectInject.ReflectionUtils.ReflectionException;

public class InjectSysComponent {
	
	public static void main(String[] args) throws ReflectionException {
		//模拟一个系统组件,我们是不能直接修改源码的,比如一些平台上的东东
		SysComponent sys = new SysComponent();
		//模拟系统内部调用方法,观察输出结果
		sys.doWork();
		//获得系统组件自身持有的对象
		Task sysTasker = (Task) ReflectionUtils.getFiled(SysComponent.class, sys,"sysTasker");
		//创建自己的对象,并将刚才得到的对象进行包装
		MyTasker myTaser = new MyTasker(sysTasker);
		//给系统设置上我们自定义的对象
		ReflectionUtils.setFieldValue(SysComponent.class, sys, "sysTasker", myTaser);
		//再次模拟系统内部调用方法,观察输出结果
		System.out.println("SysComponent injected....");
		sys.doWork();
	}
}


 执行结果:

 

Systasker is running....
SysComponent injected....
MyTasker is running...
Systasker is running....


 

 

哈哈哈~~成功运行了我们自己的代码,又没有破坏系统原有的流程~大笑

当然我们再注入的过程中,还可以进行更多的操作,大家就自己发挥吧~

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值