欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Tomcat解析XML和反射創(chuàng)建對象原理

 更新時(shí)間:2019年08月08日 10:22:12   作者:國民老公騷穎  
這篇文章主要介紹了Tomcat解析XML和反射創(chuàng)建對象原理,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

下面通過實(shí)例代碼給大家介紹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)在假如在瀏覽器中輸入一個(gè)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");
    // 獲取權(quán)限
    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é)點(diǎn)
    Element rootElement = document.getRootElement();
    //System.out.println(rootElement.getName());
    // 4.獲取根節(jié)點(diǎn)下 的子節(jié)點(diǎn)
    List<Element> servletList = rootElement.elements();
    // 記錄與urlPattern相同的servlet-name標(biāo)簽的內(nèi)容
    String servletName = "";
    // 記錄servlet標(biāo)簽中的servlet-class的內(nèi)容
    // servletClassName的內(nèi)容也就是Servlet的全類名
    String servletClassName = "";
    // 5.遍歷子節(jié)點(diǎn)
    for (Element servletElement : servletList) {
      //System.out.println(servletElement.getName());
      // 判斷如果是servlet-mapping標(biāo)簽時(shí),執(zhí)行代碼
      if ("servlet-mapping".equals(servletElement.getName())) {
        // 獲取url-pattern標(biāo)簽對象
        Element url = servletElement.element("url-pattern");
        // 判斷標(biāo)簽的內(nèi)容和入的urlPattern值是否相同
        if (urlPattern.equals(url.getText())) {
          // 記錄與urlPattern相同的servlet-name標(biāo)簽的內(nèi)容
          // 如果相同,則記錄ServletName
          // 獲取servlet-mapping中的servelt-name的內(nèi)容
          servletName = servletElement.element("servlet-name").getText();
        }
      }
    }
    // 再次遍歷
    for (Element servletElement : servletList) {
      // 判斷如果是servlet標(biāo)簽時(shí),執(zhí)行此代碼
      if ("servlet".equals(servletElement.getName())) {
        // 判斷上一次的遍歷獲取的servletName的值和這次遍歷中的servlet-name的內(nèi)容是否相同
        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對象 可以獲取其內(nèi)部的屬性
    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)在想要設(shè)置name值
    String fileName = "name";
    //創(chuàng)建一個(gè)方法名
    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);
  }

總結(jié)

以上所述是小編給大家介紹的Tomcat解析XML和反射創(chuàng)建對象原理,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • 一篇文章講透Tomcat的類加載機(jī)制

    一篇文章講透Tomcat的類加載機(jī)制

    Tomcat的類加載機(jī)制是違反了雙親委托原則的,對于一些未加載的非基礎(chǔ)類,各個(gè)web應(yīng)用自己的類加載器會(huì)優(yōu)先加載,加載不到時(shí)再交給commonClassLoader走雙親委托,這篇文章主要給大家介紹了如何通過一篇文章講透Tomcat的類加載機(jī)制的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • Tomcat實(shí)現(xiàn)WebSocket的方法

    Tomcat實(shí)現(xiàn)WebSocket的方法

    WebSocket協(xié)議屬于HTML5標(biāo)準(zhǔn),越來越多瀏覽器已經(jīng)原生支持WebSocket,它能讓客戶端和服務(wù)端實(shí)現(xiàn)雙向通信。這篇文章主要介紹了Tomcat實(shí)現(xiàn)WebSocket的方法的相關(guān)資料,需要的朋友可以參考下
    2016-11-11
  • Tomcat常見異常及解決方案代碼實(shí)例

    Tomcat常見異常及解決方案代碼實(shí)例

    這篇文章主要介紹了Tomcat常見異常及解決方案代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • Tomcat的卸載和重裝的實(shí)現(xiàn)(圖文)

    Tomcat的卸載和重裝的實(shí)現(xiàn)(圖文)

    這篇文章主要介紹了Tomcat的卸載和重裝的實(shí)現(xiàn)(圖文),文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 如何通過LambdaProbe實(shí)現(xiàn)監(jiān)控Tomcat

    如何通過LambdaProbe實(shí)現(xiàn)監(jiān)控Tomcat

    這篇文章主要介紹了如何通過LambdaProbe實(shí)現(xiàn)監(jiān)控Tomcat,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • nginx和tomcat訪問圖片和靜態(tài)頁面的配置方法

    nginx和tomcat訪問圖片和靜態(tài)頁面的配置方法

    這篇文章主要介紹了nginx和tomcat訪問圖片和靜態(tài)頁面的配置方法,需要的朋友可以參考下
    2018-04-04
  • servlet簡介_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    servlet簡介_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    Servlet是一種服務(wù)器端的編程語言,是J2EE中比較關(guān)鍵的組成部分。本文給大家簡單介紹servlet的基本知識,感興趣的朋友一起看看吧
    2017-07-07
  • Ubuntu18.04 中tomcat9安裝圖文教程

    Ubuntu18.04 中tomcat9安裝圖文教程

    這篇文章主要介紹了Ubuntu18.04 中tomcat9安裝圖文教程,需要的朋友可以參考下
    2018-07-07
  • IDEA編輯器整合Apache Tomcat的詳細(xì)教程

    IDEA編輯器整合Apache Tomcat的詳細(xì)教程

    這篇文章主要介紹了IDEA編輯器整合Apache Tomcat教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • tomcat常見的錯(cuò)誤與解決方案小結(jié)

    tomcat常見的錯(cuò)誤與解決方案小結(jié)

    web容器其實(shí)都是tomcat,但tomcat的內(nèi)核很豐富,如果要完全理解需要很長的時(shí)間和較多的編程經(jīng)驗(yàn)。不管是初學(xué)者還是有經(jīng)驗(yàn)的web程序員,使用Tomcat容器的時(shí)候會(huì)發(fā)生包括404,運(yùn)行啟動(dòng)錯(cuò)誤,以及亂碼等等的問題,本文將開發(fā)過程中遇到的常見錯(cuò)誤和簡單解決方法分享給大家。
    2016-11-11

最新評論