时间:2021-05-19
下面通过实例代码给大家介绍Tomcat解析XML和反射创建对象原理,具体代码如下所示:
import java.lang.reflect.InvocationTargetException;import java.lang.reflect.Method;import java.util.List;import org.dom4j.Document;import org.dom4j.DocumentException;import org.dom4j.Element;import org.dom4j.io.SAXReader;public class ServerReadXML1 { public static void main(String[] args) throws DocumentException, ClassNotFoundException, InstantiationException, IllegalAccessException, NoSuchMethodException, SecurityException, IllegalArgumentException, InvocationTargetException { // 现在假如在浏览器中输入一个Servlet的url-pattern String urlPattern = "/first"; // 根据urlPattern 获取类名 String className = getClassByUrl(urlPattern); // 根据全类名获取Class对象 Class clazz = Class.forName(className); // 通过反射clazz对象创建指定对象 Object obj = clazz.newInstance(); // 获取service方法 Method method = clazz.getDeclaredMethod("service"); // 获取权限 method.setAccessible(true); // 执行service方法 method.invoke(obj); } private static String getClassByUrl(String urlPattern) throws DocumentException { // 1.创建SAXReader对象 SAXReader reader = new SAXReader(); // 2.读取文件 Document document = reader.read(ServerReadXML1.class.getClassLoader().getResourceAsStream("web.xml")); // 3.获取根节点 Element rootElement = document.getRootElement(); //System.out.println(rootElement.getName()); // 4.获取根节点下 的子节点 List<Element> servletList = rootElement.elements(); // 记录与urlPattern相同的servlet-name标签的内容 String servletName = ""; // 记录servlet标签中的servlet-class的内容 // servletClassName的内容也就是Servlet的全类名 String servletClassName = ""; // 5.遍历子节点 for (Element servletElement : servletList) { //System.out.println(servletElement.getName()); // 判断如果是servlet-mapping标签时,执行代码 if ("servlet-mapping".equals(servletElement.getName())) { // 获取url-pattern标签对象 Element url = servletElement.element("url-pattern"); // 判断标签的内容和入的urlPattern值是否相同 if (urlPattern.equals(url.getText())) { // 记录与urlPattern相同的servlet-name标签的内容 // 如果相同,则记录ServletName // 获取servlet-mapping中的servelt-name的内容 servletName = servletElement.element("servlet-name").getText(); } } } // 再次遍历 for (Element servletElement : servletList) { // 判断如果是servlet标签时,执行此代码 if ("servlet".equals(servletElement.getName())) { // 判断上一次的遍历获取的servletName的值和这次遍历中的servlet-name的内容是否相同 if (servletName.equals(servletElement.element("servlet-name").getText())) { // 如果相同记录servletClassName servletClassName = servletElement.element("servlet-class").getText(); } } } // 返回Servlet的全类名 servletClassName return servletClassName; }}1.反射的获取Class 4种方式
@Test public void test1() throws ClassNotFoundException { //1.类名.class Class clazz = String.class; System.out.println(clazz); //2.对象.getClass() Class clazz1 = "abc".getClass(); System.out.println(clazz1); //3.Class.forName(); Class clazz2 = Class.forName("java.lang.String"); System.out.println(clazz2); //4.ClassLoader .loadClass("全类名") Class clazz3 = ReflectTest1.class.getClassLoader().loadClass("java.lang.String"); System.out.println(clazz3); }2.反射使用属性的常用方法
@Test public void test2() throws ClassNotFoundException, NoSuchFieldException, SecurityException, IllegalArgumentException, IllegalAccessException { //获取Class对象 可以获取其内部的属性 Class clazz = Class.forName("com.atguigu.bean.User"); User user = new User(); //Field对象 代表中类的属性 getField只能获取公共属性 Field field = clazz.getField("email"); System.out.println(field); //此种方式破坏代码的封装性 不推荐使用 Field field2 = clazz.getDeclaredField("id"); System.out.println(field2); field2.setAccessible(true); field2.setInt(user, 1001); System.out.println(user); }3.反射使用方法的常用方法
@Test public void test3() throws ClassNotFoundException, InstantiationException, IllegalAccessException, NoSuchMethodException, SecurityException, IllegalArgumentException, InvocationTargetException { Class clazz = Class.forName("com.atguigu.bean.User"); //通过反射创建对象 Object obj = clazz.newInstance(); //现在想要设置name值 String fileName = "name"; //创建一个方法名 String methodName = "set" + fileName.substring(0, 1).toUpperCase() //N + fileName.substring(1).toLowerCase(); //ame //根据方法名 获取公共方法 Method method = clazz.getMethod(methodName, String.class); //执行指定的方法 method.invoke(obj, "yangjian"); System.out.println(obj); }总结
以上所述是小编给大家介绍的Tomcat解析XML和反射创建对象原理,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Gson反序列化原理原理简述gson反序列化主要分为两个过程:根据TypeToken创建出对象根据json字符串解析数据,对对象属性赋值对象的创建Constru
1、xml主要用来编写配置文件和用于数据的传输。 2、dom解析和创建xml文件技术:它是官方的结束技术,创建xml文件时代码量是非常的多,繁琐,而解析x
阅读目录Java反射API通过反射创建实例对象通过反射调用私有方法关于javap工具参考资料Java反射APIJava反射指的是在运行状态时,能够获取类的属性和
DOMDocumentphp提供了非常好用的解析html和xml文档的扩展库DOM,使用这个库可以非常高效的进行html和xml文档的解析,它的原理就是通过寻找
1、spring原理内部最核心的就是IOC了,动态注入,让一个对象的创建不用new了,可以自动的生产,这其实就是利用java里的反射,反射其实就是在运行时动态的