學習心得

          BlogJava 首頁 新隨筆 聯系 聚合 管理
            3 Posts :: 0 Stories :: 1 Comments :: 0 Trackbacks

          常用鏈接

          留言簿(1)

          隨筆分類

          隨筆檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          2009年3月2日 #

          首先得弄清什么是Action?然后再搞清楚他在struts框架中扮演的什么角色?最后再了解他如何使用和基本結構生命周期等細節問題.
          在大多數人來看。Action其實就像是servlet。其實Action是一個輕量級的Java類。Servelt引用ActionMapping列表來選擇對應Action來處理。
          調用Action的方法然后返回一個ActionForward.ActionServlet再通過這個ActionForward轉發相應請求。
          posted @ 2009-03-02 16:41 Mr.wang 閱讀(208) | 評論 (0)編輯 收藏

          談到ActionMapping.相信大家用得最多的就是ActionMapping.findForward("forwardName");通過ActionMapping對象把請求轉發到指定的forward對象。
          沒錯,在大體上。ActionMapping就實現了一個路由的功能。負責把請求轉發到不同的ActionForward上。
          在我們經常用的配置就是:
          <action-mappings>
          <action path="login" type="study.struts.LoginAction"
          name
          ="login" scope="request"
              </action>
          </action-mappings
          >
          在<action-mappings>標簽中配置了N個action。實際上在struts1.1處理的時候會把這些action都裝飾成一個單例的ActionMapping對象然后放到一個
          ActionMappings的Map中,通過action的path屬性做為key。來區別不同的ActionMapping對象。struts就通過請求不同的path就可以達到把請求轉發給
          不同的Action上。
          ------------------------------------------------------------------------------------------------------
          ActionMapping工作起來就像是ActionServlet的一個路由聯絡官。取決于mapping 如何被填寫
          設置,請求可能被傳遞到任何地方。ActionMapping表達了Struts 應用的核心設計。如果你
          想知道一個 Struts 應用是如何工作的,可以從ActionMapping開始著手。如果你想知道如何
          編寫一個新的Struts 應用,也請從ActionMapping開始。Mapping處于每個Struts 應用的絕對
          核心。
          -----------------------------------截自<<struts in action>>------------------------------------------
          posted @ 2009-03-02 10:58 Mr.wang 閱讀(1575) | 評論 (0)編輯 收藏

          2009年2月26日 #

          昨天學習了struts的ActionForm 才知道,原來在struts中ActionForm扮演N多重要角色。
          今天學習到ActionForward。
          下面開始簡述一下自己學到的心得體會。
          在剛開始我理解的請求的轉發和重定向只是有一個區別,
          那就是如果用請求的轉發那么在上下文環境中儲存的參數些在轉發的下一個Action或JSP中還能用。
          而相反請求的重定向則會把上下文清空。所以那些參數也不復存在。
          其實在一開始這么理解確實沒有錯的。
          這幾天猛然翻起struts的書才發現。自己懂的還很少。

          請求的轉發:
          請求的轉發實際是在服務器那端執行的。也就是說那些request、session這里里面存放的東西只能在服務器端訪問。
          現在從客戶端發送一個請求過來,如果在Action中進行了請求的重定向,那么struts就會把請求對象傳給下一個Servelt
          處理。所以大家在上下文件環境中保存的參數都還有。在我們做的程序開發中差不多全是請求的轉發,因為要利用
          上下文環境來傳遞數據。因為在請求的轉的同時,這一次請求并沒有返回客戶端,只是在服務器端做了轉發。所以
          當響應回到客戶端的時候,客戶端并不知道服務器端進行過請求的轉發所以在客戶端的地址欄的url不做任何變化。

          請求的重定向:
          請求的重定向實際是當在服務器端接受到請求的重定向請求的時候,他會即時響應客戶端然后告訴客戶端要請求的地址。并
          自動再將請求發送給傳回來的url。實際上請求的重定向兩次向服務器發送了請求。所以當服務器第一次響應請求的時候,
          不能把request對象傳送回客戶端,所以在請求的重定向中無法通過上下文環境來保存數據。那我們怎么傳遞數據呢,只能通過
          服務器第一次響應的時候會傳送回來一個再次請求的url(http://www.baidu.com?keyword=123)。可以在url中跟上對應的參數可以達到數據傳遞的目的。這樣用著比較麻煩,但這樣做就可以改變客戶端的url地址。因為請求第一次是返回過客戶端的。所以客戶端就知道了新的url地址,相應
          也就會改變。
          小結:
          個人認為請求的重定向的轉發最大的差別就是:請求的轉發是在服務端完成的,并沒有返回客戶端。而請求的重定向會返回一次客戶端,通過
          客戶端的身份再次請求相應的url。
          posted @ 2009-02-26 14:59 Mr.wang 閱讀(2600) | 評論 (1)編輯 收藏

          僅列出標題  
          主站蜘蛛池模板: 深泽县| 海伦市| 满洲里市| 南充市| 从化市| 大埔区| 万州区| 奉化市| 浠水县| 岑巩县| 安康市| 崇信县| 青川县| 万山特区| 营山县| 弋阳县| 西丰县| 江华| 炎陵县| 上栗县| 通渭县| 沅陵县| 湖州市| 康定县| 九江市| 黄陵县| 安远县| 淳化县| 赤峰市| 怀化市| 海原县| 揭西县| 凌海市| 襄樊市| 泸州市| 新营市| 满城县| 塘沽区| 富裕县| 长春市| 耒阳市|