<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 120,  comments - 19,  trackbacks - 0
    java.lang.Object
      |
      +--javax.servlet.GenericServlet
            |
            +--javax.servlet.http.HttpServlet
                  |
                  +--org.apache.struts.action.ActionServlet

    Struts提供了一個缺省版本的ActionServlet類,你可以繼承這個類,覆蓋其中的一些方法來達到你的特殊處理的需要。ActionServlet繼承與javax.servlet.http.HttpServlet,所以在本質上它和一個普通的servlet沒有區別,你完全可以把它當做一個servlet來看待,只是在其中完成的功能不同罷了。ActionServlet主要完成如下功能:

    將一個來自客戶端的URI映射到一個相應的Action類
    • 如果是這個Action類是第一次被調用,那么實例化一個并放入緩存
    • 如果在配置文件(struts-config.xml)中指定了相應的ActionForm,那么從Request中抓取數據填充FormBean
    • 調用這個Action類的perform()方法,傳入ActionMapping的一個引用,對應的ActionForm、以及由容器傳給ActionServlet的HttpServletRequest、HttpServletResponse對象。


    確省版本的ActionServlet會從配置文件web.xml中讀取如下初始化參數:
    • application
      應用使用的資源包(resources bundle)的基類
    • factory
      用于創建應用的MessageResources對象的MessageResourcesFactory的類名。確省是org.apache.struts.util.PropertyMessageResourcesFactory。
    • config
      Struts的配置文件,確省是/WEB-INF/struts-config.xml。注意這兒是與應用Context關聯的相對路徑。
    • content
      定義了確省的內容類型和編碼格式,它會被自動地被設置到每個response中,如果JSP/Servlet中沒有明確的設置。確省是text/html。
    • debug
      調試信息的級別。默認為0,比當前級別高的調試信息會被log到日志文件中。
    • detail
      與debug的作用類似,只是這個detail是initMapping()時專用的。調試信息會被打印到System.out,而不是日志文件。
    • formBean
      ActionFormBean的實現類,確省為org.apache.struts.action.ActionFormBean
    • forward
      應用中使用的ActionForward類,確省是org.apache.struts.action.ActionForward。
    • locale
      指定了確省使用的Locale對象。設為true,當得到一個session時,會自動在session中存儲一個以Action.LOCALE_KEY標示的Locale對象,如果session中還沒有與Action.LOCALE_KEY綁定的Locale對象。
    • mapping
      應用中使用的ActionMapping類,確省是org.apache.struts.action.ActionMapping。
    • multipartClass
      文件上傳使用的MutipartRequestHandler的實現類。確省為org.apache.struts.upload.DiskMultipartRequestHandler
    • nocache
      如果設為true,那么ActionServlet會自動在每個到客戶端的響應中添加nocache的HTML頭,這樣客戶端就不會對應用中的頁面進行緩存。確省為false
    • null
      如果設置為true,那么應用在得到一個未定義的message資源時,會返回null,而不是返回一個錯誤信息。確省是true。
    • maxFileSize
      文件上傳的大小上限,確省為250M
    • bufferSize
      文件上傳時的緩沖區的大小,確省為4M
    • tempDir
      設置用于上傳時的臨時目錄。工作目錄會作為一個Servlet環境(Context)的屬性提供。
    • validate
      Are we using the new configuration file format?確省為true。
    • validating

    在解析配置XML文件是是否進行有效性的驗證。確省為true

    ActionServlet中應用了命令設計模式。

    一個Servlet在由容器生成時,首先會調用init()方法進行初始化,在接到一個HTTP請求時,調用相應的方法進行處理;比如GET請求調用doGet()方法,POST請求調用doPost()方法。所以首先看看ActionServlet的init()方法,你就會很清楚為什么ActionServlet可以完成這些功能了。

    init()


    在它的init()方法中,ActionServlet依次調用如下protected的方法完成初始化:
    • initActions() -     大家可能還曾有這個疑問:Struts為什么可以找到一個請求URI對應的action類呢?答案就在這兒,ActionServlet有一個actions屬性,類型為org.apache.struts.util.FastHashMap,用于存儲以類的全名為key的已實例化的Action類。在init()時首先調用的就是initActions()方法,在這個方法中只是簡單的清除map中的所有的名值對,
      1.         synchronized (actions) {
      2.             actions.setFast(false);
      3.             actions.clear();
      4.             actions.setFast(true);
      5.         }

      首先把actions設為slow模式,這時對FastHashMap的訪問是線程同步的,然后清除actions中的所有的已存在的名/值對,最后再把actions的模式設為fast。由于FastHashMap是struts在java.util.HashMap的基礎上的一個擴展類,是為了適應多線程、并且對HashMap的訪問大部分是只讀的特殊環境的需要。大家知道java.util.HashMap是非線程安全的,所以HashMap一般適用于單線程環境下。org.apache.struts.FastHashMap就是繼承于java.util.HashMap,在其中添加多線程的支持產生的。在fast模式下的工作方式是這樣的:讀取是非線程同步的;寫入時首先克隆當前map,然后在這個克隆上做寫入操做,完成后用這個修改后的克隆版本替換原來的map。那么在什么時候會把Actions類添加到這個map中呢?我們已經提到了struts是動態的生成Action類的實例的,在每次ActionServlet接收到一個GET或POST的HTTP請求時,會在這個map中查找對應的Action類的實例,如果不存在,那么就實例化一個,并放入map中。可見這個actions屬性起到了對Action類實例的緩存的作用。
    • initInternal() -     初始化ActionServlet內部使用的資源包MessageResources,使用MessageResources.getMessageResources(internalName)得到    internalName為"org.apache.struts.action.ActionResources"對應的ActionResources.properties文件。這個資源包主要用于ActionServlet處理過程中的用到的提示信息,這兒不展開討論。
    • initDebug() -     從web.xml中讀取本應用的debug級別參數getServletConfig().getInitParameter("debug"),然后賦給debug屬性。
    • initApplication()-    初始化應用資源包,并放置入ServletContext中。
      1.         String factory =getServletConfig().getInitParameter(“factory”);    
      2.         String oldFacory = MessageResourcesFactory.getFactoryClass();
      3.         if (factory !=null)
      4.                 MessageResourcesFactory.setFactoryClass(factory);
      5.         String value = getServletConfig().getInitParameter("application");
      6.         MessageResourcesFactory factoryObject =
      7.                 MessageResourcesFactory.createFactory();
      8.         application = factoryObject.createResources(value);
      9.         MessageResourcesFactory.setFactory(oldFactory); 
      10.         getServletContext().setAttribute(Action.MESSAGES_KEY, application);

      說明:文中引用的代碼片斷可能會省略了一些例外檢查等非主線的內容,敬請注意。

      首先從配置文件中讀取factory參數,如果這個參數不為空,那么就在MessageResourcesFactory中使用這個指定的Factory類;否則,使用默認的工廠類org.apche.struts.util.PropertyMessageResourceFactory。然后調用MessageResourcesFactory的靜態createFactory()方法,生成一個具體的MessageResourceFactory對象(注意:MessageResourcesFactory是抽象類)。這樣就可以調用這個具體的MessageResourceFactory的createResource()方法得到配置文件(web.xml)中定義的資源文件了。
      上面的application對象類型為MessageResources。在web.xml中在配置ActionServlet時可以指定一個特定的工廠類。不能直接MessageResourcesFactory的createResources()方法,因為這個方法是abstract的。創建factoryObject的過程如下:
      1.     
      2.         MessageResourceFactory factoryObject=
      3.                 MessageResourcesFactory.createFactory();
      4.         application = factoryObject.createResources(value);

      <li>initMapping() -    為應用初始化mapping信息ActionServlet有一個protected的屬性:mapping,封裝了一個ActionMapping的對象集合,以便于管理、查找ActionMapping。mappings是org.apache.struts.action.ActionMappings類的實例。主要有兩個方法:addMapping(ActionMapping mapping)和findMapping(String path)。ActionMapping也是使用上面提到的org.apache.struts.util.FastHashMap類來存儲所有的ActionMapping對象。
      1.         mappings.setServlet(this);
      2.         ……
      3.         // Initialize the name of our ActionFormBean implementation class
      4.         value = getServletConfig().getInitParameter("formBean");
      5.         if (value != null)
      6.             formBeanClass = value;
      7.     
      8.         // Initialize the name of our ActionForward implementation class
      9.         value = getServletConfig().getInitParameter("forward");
      10.         if (value != null)
      11.                 forwardClass = value;
      12.         // Initialize the name of our ActionMapping implementation class
      13.         value = getServletConfig().getInitParameter("mapping");
      14.         if (value != null)
      15.                 mappingClass = value;

      在initMapping()中,首先鏈接mappings對象到本servlet實例。其實這句話的作用很簡單,在ActionMappings中會有一個ActionServlet類型的屬性,這個屬性就界定了這個ActionMappings對象所屬的ActionServlet。Struts的實現比較靈活,其中的ActionFormBean、ActionForward、ActionMapping類你完全可以使用自己實現的子類,來定制Struts的工作方式。上面的代碼就從配置文件(web.xml)中讀取formBean、forward、mapping參數,這些參數就是你定制的ActionFormBean、ActionForward、ActionMapping類名。
      1.         // Initialize the context-relative path to our configuration resources
      2.         value = getServletConfig().getInitParameter("config");
      3.         if (value != null)
      4.                 config = value;
      5.                 // Acquire an input stream to our configuration resource
      6.         InputStream input = getServletContext().getResourceAsStream(config);
      7.         Digester digester = null;
      8.                 digester = initDigester(detail);
      9.         try {
      10.                 formBeans.setFast(false);
      11.                 forwards.setFast(false);
      12.                 mappings.setFast(false);
      13.                 digester.parse(input);
      14.                 mappings.setFast(true);
      15.                 forwards.setFast(true);
      16.                 formBeans.setFast(true);
      17.         } catch (SAXException e) {
      18.                 throw new ServletException
      19.         (internal.getMessage("configParse", config), e);
      20.         } finally {
      21.                 input.close();
      22.         }

      從web.xml讀取Struts的配置文件的位置。使用org.apache.struts.digester.Digester解析config參數標示的配置文件,通常為“/WEB-INF/struts-config.xml”,解析出所有的data-source、form-bean、action-mapping、forward。從上面的程序片斷看到,Digester僅僅調用了一個parse()方法,那么,Digester是怎樣把解析struts-config.xml文件并把解析的結果form-bean等信息存儲到屬性變量formBeans等中的呢?你可以注意到在調用digester.parse(InputStream)之前,首先調用了initDigester()方法:
      1.         Digester digester = new Digester();
      2.         digester.push(this);
      3.         digester.addObjectCreate("struts-config/action-mappings/action",
      4.                                  mappingClass, "className");
      5.         digester.addSetProperties("struts-config/action-mappings/action");
      6.         digester.addSetNext("struts-config/action-mappings/action",
      7.                             "addMapping",
      8.                             "org.apache.struts.action.ActionMapping");
      9.         digester.addSetProperty
      10.             ("struts-config/action-mappings/action/set-property",
      11.              "property""value");

      在這個方法中首先生成一個Digester對象,然后設置解析的規則和回調,如果你對XML、SAX不是很熟,這兒不必糾纏太深。要注意的是addSetNext()方法,設置了每一個要解析元素的Set Next回調方法,而這個方法就是由digester解析器的父提供的。上面的片斷中的“addMapping”就是ActionServlet本身定義的一個方法,將由Digester回調。Digester就是籍此把解析出的每一個FormBean、ActionForward、ActionMapping等存儲到屬性變量formBeans、forwards、mappings等中的。
    • initUpload() -    初始化有關Upload的一些參數,比如:bufferSize、tempDir。
    • initDataSource() -取出在initMapping()中從配置文件中讀取的每一個DataSource,設置LogWriter,如果為GenericDataSource的實例,則打開數據源。然后,把每個dataSource放入Context中。
      dataSource.setLogWriter(scw);
      ((GenericDataSource)dataSource).open();
      getServletContext().setAttribute(key,dataSource);
    • initOther() -        設置其它尚未初始化的的參數(content、locale、nocache),并發布formBeans、forwards、mappings到Context:
      getServletContext().setAttribute(Action.FORM_BEANS_KEY, formBeans);
      getServletContext().setAttribute(Action.FORWARDS_KEY, forwards);
      getServletContext().setAttribute(Action.MAPPINGS_KEY, mappings);
    • initServlet() -    初始化Controller Servlet的Servlet Mapping。這兒也使用了Digester工具,掃描web.xml所有的<web-app/servlet-mapping>,尋找servlet-name與當前Servlet相同的mapping,置入Context。代碼如下;
      1.         Digester digester = new Digester();
      2.         digester.push(this);
      3.         digester.setDebug(debug);
      4.         digester.setValidating(validating);
      5.         digester.addCallMethod(“web-appservlet-mapping”,“addServletMapping”, 2);
      6.         digester.addCallParm(“web-appservlet-mappingservlet-name”, 0);
      7.         digester.addCallParm(“web-appservlet-mappingurl-pattern”, 1);
      8.         InputStream is = getServletContext().getResourceAsStream(“/WEB-INFweb.xml”);
      9.         digester.parse(is); 
      10.         getServletContext().setAttribute(Action.SERVLET_KEY,servletMapping);


    posted on 2007-04-06 09:48 阿成 閱讀(464) 評論(0)  編輯  收藏 所屬分類: Struts
    主站蜘蛛池模板: 鲁丝片一区二区三区免费| 亚洲AV一区二区三区四区| 国产av天堂亚洲国产av天堂| 国产精品亚洲玖玖玖在线观看| 国产免费卡一卡三卡乱码| 大陆一级毛片免费视频观看| 女人18毛片水真多免费看| 国产色爽免费视频| 国产免费看插插插视频| 九月婷婷亚洲综合在线| 亚洲伊人成无码综合网| 亚洲欧洲日产国码无码久久99 | A级毛片内射免费视频| 日韩精品无码区免费专区| 好吊妞788免费视频播放| 国产乱色精品成人免费视频 | 无码国产精品一区二区免费模式 | a级毛片无码免费真人| 四虎影视在线永久免费观看| 亚洲性在线看高清h片| 精品亚洲综合久久中文字幕| 亚洲综合在线视频| 亚洲综合色婷婷在线观看| 婷婷亚洲综合一区二区| 中文字幕成人免费高清在线| 日本视频在线观看永久免费| 日本最新免费网站| 成人a视频片在线观看免费| 亚洲成AV人网址| 久久精品亚洲一区二区| 亚洲最大天堂无码精品区| 日本永久免费a∨在线视频| 国产线视频精品免费观看视频| 91香蕉国产线观看免费全集| 午夜dj在线观看免费视频| 久久精品国产亚洲一区二区三区| 亚洲AV成人无码久久精品老人| 亚洲www77777| a毛片全部免费播放| 三年片在线观看免费大全| 日韩精品电影一区亚洲|