服務器
下面通過實例代碼給大家介紹Tomcat解析XML和反射創(chuàng)建對象原理,具體代碼如下所示:

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 {
// 現(xiàn)在假如在瀏覽器中輸入一個Servlet的url-pattern
String urlPattern = /first;
// 根據(jù)urlPattern 獲取類名
String className = getClassByUrl(urlPattern);
// 根據(jù)全類名獲取Class對象
Class clazz = Class.forName(className);
// 通過反射clazz對象創(chuàng)建指定對象
Object obj = clazz.newInstance();
// 獲取service方法
Method method = clazz.getDeclaredMethod(service);
// 獲取權限
method.setAccessible(true);
// 執(zhí)行service方法
method.invoke(obj);
}
private static String getClassByUrl(String urlPattern) throws DocumentException {
// 1.創(chuàng)建SAXReader對象
SAXReader reader = new SAXReader();
// 2.讀取文件
Document document = reader.read(ServerReadXML1.class.getClassLoader().getResourceAsStream(web.xml));
// 3.獲取根節(jié)點
Element rootElement = document.getRootElement();
//System.out.println(rootElement.getName());
// 4.獲取根節(jié)點下 的子節(jié)點
List<Element> servletList = rootElement.elements();
// 記錄與urlPattern相同的servlet-name標簽的內容
String servletName = ;
// 記錄servlet標簽中的servlet-class的內容
// servletClassName的內容也就是Servlet的全類名
String servletClassName = ;
// 5.遍歷子節(jié)點
for (Element servletElement : servletList) {
//System.out.println(servletElement.getName());
// 判斷如果是servlet-mapping標簽時,執(zhí)行代碼
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標簽時,執(zhí)行此代碼
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);
//通過反射創(chuàng)建對象
Object obj = clazz.newInstance();
//現(xiàn)在想要設置name值
String fileName = name;
//創(chuàng)建一個方法名
String methodName = set + fileName.substring(0, 1).toUpperCase() //N
+ fileName.substring(1).toLowerCase(); //ame
//根據(jù)方法名 獲取公共方法
Method method = clazz.getMethod(methodName, String.class);
//執(zhí)行指定的方法
method.invoke(obj, yangjian);
System.out.println(obj);
}
總結
以上所述是小編給大家介紹的Tomcat解析XML和反射創(chuàng)建對象原理,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!
網頁題目:Tomcat解析XML和反射創(chuàng)建對象原理
分享路徑:http://chinadenli.net/article38/cgeppp.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供關鍵詞優(yōu)化、App設計、外貿網站建設、ChatGPT、網站設計公司、做網站
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)