Tomcat解析XML和反射创建对象原理
生活随笔
收集整理的這篇文章主要介紹了
Tomcat解析XML和反射创建对象原理
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
服務器
下面通過實例代碼給大家介紹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和反射創建對象原理,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!
總結
以上是生活随笔為你收集整理的Tomcat解析XML和反射创建对象原理的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使用Python生成Shell命令,批量
- 下一篇: haproxy基于centos和Ubun