Java 动态代理插入日志

被代理对象的接口

1 public interface IScoreService {
2     public void addScore(String s,String s1);
3 }

被代理的对象的实现

1 public class ScoreServiceImpl implements IScoreService{
2     int  score = 0;
3     public  List<Integer> sList = new ArrayList<Integer>();
4     
5     public void addScore(String s,String s1){
6         System.out.println(score+=3);
7         sList.add(score);
8     }
9 }

代理类

 1 public class LogHandler implements InvocationHandler {
 2     
 3     private Object targetObject;
 4     
 5     public Object createProxy(Object targetObject){
 6         this.targetObject = targetObject;
 7         return Proxy.newProxyInstance(targetObject.getClass().getClassLoader(), 
 8                 targetObject.getClass().getInterfaces(),
 9                 this);
10     }
11 
12     public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
13         
14         Object obj = null;
15         try {
16             beforeLog();
17             obj = method.invoke(targetObject, args);
18             afterLog();
19         } catch (Exception e) {
20             e.printStackTrace();
21         }
22         
23         
24         return obj;
25     }
26     
27     private void beforeLog(){
28         System.out.println("在之前调用");
29     }
30     
31     private void afterLog(){
32         System.out.println("在之后调用");
33     }
34 
35 }

测试类

1 public class TestHandler{
2     public static void main(String [] args){
3          IScoreService servcie = (IScoreService)logHandler.createProxy(new ScoreServiceImpl());
4          servcie.addScore("","");      
5     }
6 }

 

转载于:https://www.cnblogs.com/94living/p/5426241.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值