码迷,mamicode.com
首页 > 其他好文 > 详细

(三十四)在所有的添加方法上记录一下(添加操作)

时间:2017-10-19 00:56:32      阅读:175      评论:0      收藏:0      [点我收藏+]

标签:ati   属性   images   若是   color   log   port   动态   param   

使用代理

/store/src/com/louis/utils/BeanFactory.java

package com.louis.utils;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

/**
 * 实体工厂类
 * @author Administrator
 *
 */
public class BeanFactory {
    /**
     * 通过给定一个id返回一个指定的实现类
     * @param id
     * @return
     */
    public static Object getBean(String id){
        //通过id获取一个指定的实现类
        
        try {
            //1.获取document对象
            Document doc=new SAXReader().read(BeanFactory.class.getClassLoader().getResourceAsStream("beans.xml"));
            //2.获取指定的bean对象 xpath
            Element ele=(Element) doc.selectSingleNode("//bean[@id=‘"+id+"‘]");
            
            //3.获取bean对象的class属性
            String value = ele.attributeValue("class");
            
            //4.反射 以前的逻辑直接返回的是实例    
            //return Class.forName(value).newInstance();
            
            //5.现在对service中add方法进行加强 返回值的是代理对象
            final Object obj=Class.forName(value).newInstance();
            //是service的实现类
            if(id.endsWith("Service")){
                Object proxyObj = Proxy.newProxyInstance(obj.getClass().getClassLoader(), obj.getClass().getInterfaces(), new InvocationHandler() {
                    @Override
                    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
                        //继续判断是否调用的add或者regist
                        if("add".equals(method.getName()) || "regist".equals(method.getName())){
                            System.out.println("添加操作");
                            return method.invoke(obj, args);
                        }
                        
                        return method.invoke(obj, args);
                    }
                });
                
                //若是service方法返回的是代理对象
                return proxyObj;
            }
            return obj;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }
    
    public static void main(String[] args) {
        System.out.println(getBean("ProductDao"));;
    }
}

技术分享

 

 

问题

动态代理

静态代理

(三十四)在所有的添加方法上记录一下(添加操作)

标签:ati   属性   images   若是   color   log   port   动态   param   

原文地址:http://www.cnblogs.com/Michael2397/p/7690000.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!