本文目錄一覽:
jsf是什麼?
JSF 的全稱是javaserver face
是sun推出的的一個前台展示框架。JSF是一套標準,只做定義接口。
類似struts2(JSF開發工程師中就有struts的創始人)
jsf struts jsp spring 什麼關係和區別?
Spring:業務邏輯框架,和struts,hibernate組成mvc的三大框架,也就是大家所說的ssh框架
框架的出現讓開發變得更加方便,快捷,以及可擴展性
學這個三大框架之前就會對應的學jsp,servlet和javabean
struts 1和2的區別:
struts1和struts2的區別其實並不是太大,兩者的區別:
Action 類:
◆Struts1要求Action類繼承一個抽象基類。Struts1的一個普遍問題是使用抽象類編程而不是接口。
◆Struts 2 Action類可以實現一個Action接口,也可實現其他接口,使可選和定製的服務成為可能。Struts2提供一個ActionSupport基類去實現 常用的接口。Action接口不是必須的,任何有execute標識的POJO對象都可以用作Struts2的Action對象。
線程模式:
◆Struts1 Action是單例模式並且必須是線程安全的,因為僅有Action的一個實例來處理所有的請求。單例策略限制了Struts1 Action能作的事,並且要在開發時特別小心。Action資源必須是線程安全的或同步的。
◆Struts2 Action對象為每一個請求產生一個實例,因此沒有線程安全問題。(實際上,servlet容器給每個請求產生許多可丟棄的對象,並且不會導致性能和垃圾回收問題)
Servlet 依賴:
◆Struts1 Action 依賴於Servlet API ,因為當一個Action被調用時HttpServletRequest 和 HttpServletResponse 被傳遞給execute方法。
◆Struts 2 Action不依賴於容器,允許Action脫離容器單獨被測試。如果需要,Struts2 Action仍然可以訪問初始的request和response。但是,其他的元素減少或者消除了直接訪問HttpServetRequest 和 HttpServletResponse的必要性。
可測性:
◆測試Struts1 Action的一個主要問題是execute方法暴露了servlet API(這使得測試要依賴於容器)。一個第三方擴展--Struts TestCase--提供了一套Struts1的模擬對象(來進行測試)。
◆Struts 2 Action可以通過初始化、設置屬性、調用方法來測試,“依賴注入”支持也使測試更容易。
捕獲輸入:
◆Struts1 使用ActionForm對象捕獲輸入。所有的ActionForm必須繼承一個基類。因為其他JavaBean不能用作ActionForm,開發者經常創建多餘的類捕獲輸入。動態Bean(DynaBeans)可以作為創建傳統ActionForm的選擇,但是,開發者可能是在重新描述(創建)已經存在的JavaBean(仍然會導致有冗餘的javabean)。
◆ Struts 2直接使用Action屬性作為輸入屬性,消除了對第二個輸入對象的需求。輸入屬性可能是有自己(子)屬性的rich對象類型。Action屬性能夠通過web頁面上的taglibs訪問。Struts2也支持ActionForm模式。rich對象類型,包括業務對象,能夠用作輸入/輸出對象。這種ModelDriven 特性簡化了taglib對POJO輸入對象的引用。
表達式語言:
◆Struts1 整合了JSTL,因此使用JSTL EL。這種EL有基本對象圖遍歷,但是對集合和索引屬性的支持很弱。
◆Struts2可以使用JSTL,但是也支持一個更強大和靈活的表達式語言--”Object Graph Notation Language” (OGNL).
綁定值到頁面(view):
◆ Struts 1使用標準JSP機制把對象綁定到頁面中來訪問。
◆Struts 2 使用 “ValueStack”技術,使taglib能夠訪問值而不需要把你的頁面(view)和對象綁定起來。ValueStack策略允許通過一系列名稱相同但類型不同的屬性重用頁面(view)。
類型轉換:
◆Struts 1 ActionForm 屬性通常都是String類型。Struts1使用Commons-Beanutils進行類型轉換。每個類一個轉換器,對每一個實例來說是不可配置的。
◆Struts2 使用OGNL進行類型轉換。提供基本和常用對象的轉換器。
校驗:
◆Struts 1支持在ActionForm的validate方法中手動校驗,或者通過Commons Validator的擴展來校驗。同一個類可以有不同的校驗內容,但不能校驗子對象。
◆Struts2支持通過validate方法和XWork校驗框架來進行校驗。XWork校驗框架使用為屬性類類型定義的校驗和內容校驗,來支持chain校驗子屬性
Action執行的控制:
◆Struts1支持每一個模塊有單獨的Request Processors(生命周期),但是模塊中的所有Action必須共享相同的生命周期。
◆Struts2支持通過攔截器堆棧(Interceptor Stacks)為每一個Action創建不同的生命周期。堆棧能夠根據需要和不同的Action一起使用。
jsf框架中如何創建servlet,具體步驟和配置是怎麼樣的??
您好,這樣的:
文件faces-config.xml定義了導航規則,決定JSF在用戶點擊網頁中的命令按鈕時做什麼,網頁的路徑由標記(/edit.jsp)指定。由元素分別定義了兩個導航塊(navigation case):
………. faces-config navigation-rule from-tree-id/edit.jsp/from-tree-id navigation-case from-outcomeeditOutcome/from-outcome to-tree-id/edit.jsp/to-tree-id /navigation-case navigation-case from-outcomeviewOutcome/from-outcome to-tree-id/view.jsp/to-tree-id /navigation-case /navigation-rule ………. /faces-config
文件edit.jsp包含由標記生成的兩個按鈕。每個都有一個標識(ID)、一個標籤、一個命令名稱(這裡沒有使用,但JSF需要)以及一個action或actionRef屬性:
f:use_faces h:form formName=”pform” ………. p h:command_button id=”view” label=”View” commandName=”viewCmd” action=”viewOutcome”/ h:command_button id=”boldUpperCase” label=”Bold Upper Case / View” commandName=”boldUpperCaseCmd” actionRef=”pbean.boldUpperCaseAction”/ /h:form /f:use_faces
上面JSP代碼生成如下HTML片斷:
form method=”post” action=”/usingjsf/faces/edit.jsp” ………. p input type=”submit” name=”view” value=”View” input type=”submit” name=”boldUpperCase” value=”Bold Upper Case / View” /form
JSF會在每次瀏覽器提交用戶輸入時驗證表單中的數據。如果驗證器沒有發出錯誤信號而且沒有類型轉換錯誤,JSF便會分析導航塊(navigation case)。對於第一個按鈕,JSF會得到action屬性的值viewOutcome,該值與第二個導航塊的元素中的文本匹配。因此,JSF將HTTP請求轉發給view.jsp,文件view.jsp的路徑包含在第二個導航塊的元素中。
當用戶點擊第二個按鈕時,JSF則調用PBean對象的getBoldUpperCaseAction()方法。該方法返回一個BoldUpperCaseAction的實例,BoldUpperCaseAction則是PBean的內部類。接着,JSF調用invoke()方法,該方法返回一個在運行時決定的結果而不是固定不變的HTML文件:
public class PBean implements java.io.Serializable { ………. public BoldUpperCaseAction getBoldUpperCaseAction() { return new BoldUpperCaseAction(); } public class BoldUpperCaseAction extends javax.faces.application.Action { public String invoke() { String ucText = getText().toUpperCase(); if (isBold() getText().equals(ucText)) return “viewOutcome”; else { setBold(true); setText(ucText); return “editOutcome”; } } } }
如果bold(粗體)屬性的值為true(真)並且文本的所有字符為大寫的,JSF就按照第二個導航塊中的定義,與另一個按鈕情況一樣JSF將HTTP請求轉發給view.jsp。另外,invoke()方法會將bold屬性設為true,並將文本的所有字符改為大寫的,最後返回字符串editOutcome,使JSF按照第一個導航塊的定義,保持edit.jsp為當前頁。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/243517.html