1: 首先我们要利用dom4j进行xml的解析,将所有的bean的配置读取出来。
2:利用java的反射机制进行对象的实例化。
3: 直接获得对象
package cn.Junit.test; import java.net.URL; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.XPath; import org.dom4j.io.SAXReader; import org.springframework.beans.factory.config.BeanDefinition; public class MyClassPathXmlApplicationContext { private String filemame; private List<DefBean> list = new ArrayList<DefBean>(); private Map<String, Object> singletons = new HashMap<String, Object>(); public MyClassPathXmlApplicationContext() { super(); // TODO Auto-generated constructor stub } public MyClassPathXmlApplicationContext(String filemame) { //1. 读取XML配置文件 this.readXML(filemame); //2.实例化对象 this.instanceBean(); } private void instanceBean() { for (DefBean bean : list) { try { singletons.put(bean.getId(), Class.forName(bean.getClassName()).newInstance()); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } } private void readXML(String filemame) { SAXReader saxReader = new SAXReader(); Document document = null; try { URL xmlpath = this.getClass().getClassLoader() .getResource(filemame); document = saxReader.read(xmlpath); Map<String, String> nsMap = new HashMap<String, String>(); nsMap.put("ns", "http://www.springframework.org/schema/beans");// 加入命名空间 XPath xsub = document.createXPath("//ns:beans/ns:bean");// 创建beans/bean查询路径 xsub.setNamespaceURIs(nsMap);// 设置命名空间 List<Element> beans = xsub.selectNodes(document);// 获取文档下所有bean节点 for (Element element : beans) { String id = element.attributeValue("id");// 获取id属性值 String clazz = element.attributeValue("class"); // 获取class属性值 DefBean bean = new DefBean(id, clazz); list.add(bean); } } catch (Exception e) { e.printStackTrace(); } } //3. 获得bean对象 public Object getBean(String key) { return singletons.get(key); } }