婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Tomcat解析XML和反射創建對象原理

Tomcat解析XML和反射創建對象原理

熱門標簽:地圖標注黃河的位置 山東企業外呼系統公司 濮陽好的聯通400電話申請 靈圖uu電子寵物店地圖標注 地圖標注如何改成微信號 百度地圖標注公司位置要多少錢 虛假地圖標注 承德地圖標注公司 400電話號碼辦理多少錢

下面通過實例代碼給大家介紹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和反射創建對象原理》,本文關鍵詞  Tomcat,解析,XML,和,反射,創建,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Tomcat解析XML和反射創建對象原理》相關的同類信息!
  • 本頁收集關于Tomcat解析XML和反射創建對象原理的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 孙吴县| 长沙县| 贵南县| 郓城县| 景洪市| 珲春市| 涿州市| 商洛市| 英吉沙县| 安塞县| 开化县| 县级市| 清苑县| 宾阳县| 辉县市| 名山县| 芒康县| 榆林市| 兰西县| 孝义市| 临沭县| 德兴市| 昭平县| 嘉善县| 乡宁县| 那坡县| 长武县| 宁明县| 永和县| 神木县| 西乌珠穆沁旗| 云阳县| 绥阳县| 囊谦县| 岳阳县| 江陵县| 武汉市| 东山县| 昌江| 航空| 井冈山市|