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

主頁 > 知識庫 > 困擾JSP的一些問題與解決方法

困擾JSP的一些問題與解決方法

熱門標簽:外呼系統啥意思 電銷外呼系統 排行榜 山東智能云外呼管理系統 廣州三五防封電銷卡 長春回撥外呼系統廠家 四川電信外呼系統靠譜嗎 地圖標注創業項目入駐 地圖標注制作道路 珠海銷售外呼系統運營商

  如今每一個使用servlets的開發者都知道JSP,一種由Sun公司發明并花費大量精力加以推行并建構在servlet技術之上的web技術。JSP將servlet中的html代碼脫離了出來,從而可以加速web應用開發和頁面維護。實際上,由Sun發布的官方"應用開發模型"文檔上說得更遠: "JSP技術應該被視為標準,而servlets在多數情況下可視為一種補充。" ( Section 1.9, 1999/12/15聽取意見版 )。

  本文的目的在于聽取對該申明的合理性的評估 -- 通過比較JSP和另一項基于servlets的技術: template engines(模板引擎)。

  直接使用Servlets的問題

  起初,servlets被發明,整個世界都看到了它的優越。基于servlet的動態網頁可以被快速執行,可以在多個服務器之間輕易轉移, 并且可以和后臺數據庫完美地集成。 Servlets被廣泛接受成為一種web服務器端的首選平臺。
但是,通常通過簡單方式即可實現的html代碼現在卻要讓程序員通過 out.println()調用每一行HTML行,這在實際的 servlet應用中成為了一個嚴重問題。 HTML內容不得不通過代碼來實現, 對于大的HTML頁來說不啻是一項繁重費時的工作。另外,負責網頁內容的人員不得不請開發人員來進行所有的更新。為此,人們尋求這一種更好的解決方式。

  JSP到!

  JSP 0.90出現了。在這種技術中你可以將Java代碼嵌入到HTML文件,服務器將自動為頁面創建一個 servlet。 JSP被認為是一種寫servlet的簡易方式。所有HTML可以直接得到而不必通過out.println()調用,而負責頁面內容的人員可以直接修改HTML而不必冒破壞Java代碼的風險。
  但是,讓頁面美術設計師和開發人員在同一文件上工作并不理想,讓Java嵌入HTML被證明是就象將HTML 嵌入Java一樣令人尷尬。讀取一堆很亂的代碼仍然是一件困難的事情。

  于是,人們在使用jsp方面變得成熟,更多地使用了JavaBeans。 Beans包含了jsp所需的業務邏緝代碼。JSP中的大多數代碼都可以取出來放到bean中去,而只留下極少的標記用于調用bean。

  最近,人們開始認為這種方式下的JSP頁面真的很象是視圖(view)。它們成為一個用于顯示客戶端請求的結果的組件。于是人們會想,為什么不直接對view發送請求呢? 目標view如果對該請求不合適又將如何? 說到底,很多的請求有多種可能來取得結果view視圖。例如,同一請求可能產生成功的頁面,數據庫例外出錯報告,或者是缺少參數的出錯報告。同一請求可能產生一個英文頁面也可能是西班牙文頁面,這取決于客戶端的locale。為什么客戶端必須直接將請求發送給view?為什么客戶端不應該將請求發送給一些通用的服務器組件并讓服務器來決定JSP view的返回?

  這使很多人接受了已被稱為"Model 2"的設計, 這是在JSP 0.92中定義的基于model-view-controller的模型。在這種設計中,請求被發送到一個servlet控制器,它執行了商業邏緝并產生一個相近的數據"model"來用于顯示。這一數據隨后通過內部送到一個JSP "view"來進行顯示,這樣看起來JSP頁就象是一個普通的嵌入的JavaBean。 可以根據負責控制的servlet的內部邏輯來選擇適當的JSP頁面進行顯示。這樣,JSP文件成為了一個漂亮的template view。這就是另一種發展,并被另外一些開發者所推崇至今.

  進入Template Engines

  使用template engine來代替通常目的的JSP, 接下去的設計將變得簡單,語法更簡單,出錯信息更易讀,工具也更用戶化。 一些公司已經做了這樣的引擎,最著名的可能是WebMacro (http://webmacro.org, from Semiotek),他們的引擎是免費的。
  開發者應該明了,選定一個template engine來取代JSP提供了這么一些技術優勢,這也正是jsp的一些不足之處:

  問題 #1: Java代碼太模板化了

  雖然被認為是不好的設計,JSP仍試圖將Java代碼加入web頁面。這有些象是Java曾經做的,即對C++的簡化修改,template engines也通過將jsp中的較低層的源碼移去來使之簡化。Template engines實行了更好的設計。

  問題 #2: 要求Java代碼

  在JSP頁中要求寫一些Java代碼。例如,假設某頁要決定當前web應用中根的上下文從而導向其主頁,
在JSP中最好使用如下Java代碼:

  <a href="<%= request.getContextPath() %>/index.html">Home page</a>
 
  你可以試圖避免 Java代碼,而使用 <jsp:getProperty> 標記但這將給你六下難以閱讀的字串:

  <a href="<jsp:getProperty name="request"
  property="contextPath"/>/index.html">HomePage</a>

  使用template engine則沒有Java代碼和難看的語法。這里是同樣要求下在WebMacro中的寫法:

  <a href="$Request.ContextPath;/index.html">Home page</a>

  在WebMacro中, ContextPath 作為 $Request變量的一個屬性,使用類似Perl的語法。其它er template engines使用了其它的語法類型。
  
  再看另 一個例子,假設一個高級的"view"需要設定一個cookie來記錄用戶缺省的顏色配置 -- 這種任務看起來大概只能由view而不是servlet控制器來完成。在JSP中要有這樣的Java代碼:

  <% Cookie c = new Cookie("colorscheme", "blue"); response.addCookie(c); %>

  在WebMacro中則沒有Java代碼:

  #set $Cookie.colorscheme = "blue"

  作為最后一個離子,假如又要重新找回原來的cookie中的顏色配置。對于JSP,我們可以認為也有一個相應的工具類來提供幫助,因為用getCookies()直接做這樣低層的會變得可笑而且困難。在JSP中:

  <% String colorscheme = ServletUtils.getCookie(request, "colorscheme"); %>

  在WebMacro中沒有對工具類的需要,通常是:$Cookie.colorscheme.Value .對寫jsp的圖形藝術師,又是哪一種語法更容易學習呢?

  JSP 1.1 引入了自定義標記(custom tags)允許任意的和HTML相似的標記在JSP頁面中在后臺執行Java代碼,這將具有一定的價值,但前提是要有一個廣泛知曉的,全功能的,可以免費得到的,標準化的標記庫。目前還沒有出現這樣的標記庫。

  問題 #3: 簡單工作仍然很累人

  即使是很簡單的工作,例如包含 header和 footer,在JSP中仍然很很困難。 假設有一個 "header"和一個 "footer"模板要包含到所有頁面,而每一個模板要在content中包含當前的頁標題。
在JSP中最佳辦法是:
  <% String title = "The Page Title"; %>
  <%@ include file="/header.jsp" %>
  ...你的頁面內容...
  <%@ include file="/footer.jsp" %>

  頁面設計者要記住不能遺漏第一行的分號并要將title定義為一個字符串。此外, /header.jsp和/footer.jsp必須在根目錄下并且必須是可存取的完整文件。
  在WebMacro中包含headers和footers做起來比較簡單:

  #set $title = "The Page Title"
  #parse "header.wm"
  Your content here
  #parse "footer.wm"

  這里對設計者來說沒有要牢記的分號或對title的定義, .wm文件可以放在可自定義的搜索路徑下。

  問題 #4: 很粗的循環

  在JSP中循環很困難。這里是用JSP重復打印出每一個ISP對象名字。
  <%
  Enumeration e = list.elements();
  while (e.hasMoreElements()) {
  out.print("The next name is ");
  out.println(((ISP)e.nextElement()).getName());
  out.print("<br>");
  }
  %>

  也許什么時候會有用戶自定義標記來做這些循環。對"if"也是如此。JSP頁可能看上去成了很古怪的java代碼。而同時,webmacro循環很漂亮:
  #foreach $isp in $isps {
  The next name is $isp.Name <br>
  }

  如果必要的話,#foreach指令可被自定義的 #foreach-backwards指令很容易地取代。

  用jsp的話很可能變這樣:(這里是一個可能的 <foreach>標記)

  <foreach item="isp" list="isps">
  The next name is <jsp:getProperty name="isp" property="name"/> <br>
  </foreach>

  設計者當然地回選擇前者。
  問題 #5: 無用的出錯信息

  JSP常有一些令人驚訝的出錯信息。這是因為頁面首先被轉換成為一個servlet然后才進行編譯。好的JSP 工具可以相對增加找到出錯位置的可能性,但即使是最好的工具也無法使所有出錯信息都能容易地被讀懂。由于轉化的過程,一些錯誤對工具來說可能根本不可能被識別。
例如,假設JSP頁面需要建立一個對所有頁通用的標題。以下代碼并沒有錯:

  <% static String title = "Global title"; %>

  但Tomcat會提供以下出錯信息:
  work/%3A8080%2F/JC_0002ejspJC_jsp_1.java:70: Statement expected.
  static int count = 0;
  ^

  此信息認為以上腳本被放入 _jspService()方法而靜態變量不允許放入方法中。該語法應該是 <%! %>。頁面設計者很難讀懂這些出錯信息。即使最好的平臺在這方面也做得很不夠。即使所有 Java代碼都從頁中移出也無法解決問題。另外,以下表達式有什么錯?

  <% count %>
  tomcat給出:
  work/8080/_0002ftest_0002ejsptest_jsp_0.java:56: Class count not found in
  type declaration.
  count
  ^
  work/8080/_0002ftest_0002ejsptest_jsp_0.java:59: Invalid declaration.
  out.write("\r\n");
  ^

  換句話說,只是遺失了一個標記而已。應該是 <%= count %>。

  由于template engine可以在template文件中直接產生而沒有任何戲劇性的向代碼轉化,所以可以非常容易地給出適當的出錯報告。 依次類推,當c語言的命令被打入Unix shell的命令行, 你并不希望shell 會生成一個C程序來運行這個命令,而只是需要shell簡單地解釋命令并加以執行,如有錯誤也直接給出。

  問題 #6: 需要一個編譯器

  JSP需要一個置放在webserver中的編譯器。由于Sun拒絕放棄包含了他們的javac編譯器的tools.jar庫, 這其中就變得有問題了。Web服務器可以包含進一個第三方的編譯器如ibm的 jikes。但這樣的編譯器并不能在所有平臺上順利工作(用 C++寫成的) 也不利于建立純Java 的web服務器。 JSP有一個預編譯選項可以起到一定作用,盡管并不完美。

  問題 #7: 空間的浪費

  JSP消耗了額外的內存和硬盤空間。對服務器上每30K的JSP文件,必須要有相應的大于30K的類文件產生。實際上使得硬盤空間加倍。考慮到JSP文件隨時可以很容易地通過 <%@ include>包含一個大的數據文件,這樣的關注有著很現實的意義。同時,每一個JSP的類文件數據必須加載到服務器的內存中,這意味著服務器的內存必須永遠地將整個JSP文檔樹保存下去。少數一些JVM有能力將類文件數據從內存中移去;但是,程序員通常無法控制這樣的規則來重新申明,而且對大的站點來說重新申明可能不是很有效。對template engines由于沒有產生第二個文件,所以節省了空間。Template engines還為程序員提供對templates在內存中進行緩存的完全控制。

  使用template engine也有一些問題:

  Template的問題 #1: 沒有嚴格定義

  template engine該如何工作并沒有嚴格定義。可是,但相對jsp來說,其實這并不很重要,和 JSP不同的是,template engines對web服務器沒有任何特殊要求 -- 任何支持servlet的服務器都可以支持template engines (包括API 2.0服務器如Apache/JServ,它們并不能完全支持 JSP)! 如果為最好的template engine設計提供健康的競爭本可以引起一場耀眼的革新,特別是有開放源碼的促進,(可以讓思想相互推動和促進),那么今天的WebMacro就會象Perl一樣,沒有嚴格定義但公開源碼組織的推動就是它的標準。

  Template的問題 #2: 沒有獲得公認

  Template engines并未被廣泛知曉。JSP已經占據了極大的商業市場,并且深入人心。而使用g template engines只能是一種未被了解的替代技術。

  Template的問題 #3: 尚未調配好

  Template engines還沒有被高度地調配好。沒有對template engine 和JSP兩者進行性能測試和比較。理論上說一個調配完好的template engine實現應該和一個調配好的JSP相匹配;但是,考慮到第三方為jsp已經作出了這么深遠的推動,結果只有jsp被很好地調配好了。

  JSP的角色

  當然地,JSP在將來必然會有其地位。即使從名稱上也可以看出JSP和ASP的相似性,它們只有一個字母的差別。所以如果要讓使用asp的人們轉向java,非常相似的jsp環境將對此起到很大的推動作用,和asp保持這種對應關系所能起到的作用應該也是被推出jsp的設計者重點考慮到的。
然而這里想要強調的一點是:有利于轉入新環境的工作者,以及實際上是否是使用該環境的最佳方式,這兩者是有很大不同的。

  JSP日益顯示出它正成為最重要的java技術之一, 它讓人們離開ASP的世界 -- 由此,Sun將支持這一強有力的商業case, Java相關技術支持者也將給予更大力的支持。

  可是,這并非java平臺的最佳解決方案。這將使java解決方案變得好象是沒有java的解決方案了。

標簽:玉樹 吳忠 廣元 肇慶 潮州 北海 保定 紹興

巨人網絡通訊聲明:本文標題《困擾JSP的一些問題與解決方法》,本文關鍵詞  困擾,JSP,的,一些,問題,與,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《困擾JSP的一些問題與解決方法》相關的同類信息!
  • 本頁收集關于困擾JSP的一些問題與解決方法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩国产大片| 色视频一区二区| 国产精品毛片久久久久久久| 日韩一区二区精品| 国产精品女人毛片| 亚洲国产精品v| 亚洲国产精品av| 中文字幕一区二区三区不卡在线| 91在线视频免费观看| 欧美三级韩国三级日本一级| 欧美精品一二三区| 久久99国产精品久久| 日韩一级视频免费观看在线| 国产成人精品免费视频网站| 国产一区二区三区香蕉| av中文一区二区三区| 成人av网在线| 色综合天天综合色综合av| 免费看黄色91| 不卡av在线免费观看| 5566中文字幕一区二区电影| 国产精品一色哟哟哟| 日韩视频在线一区二区| 亚洲午夜国产一区99re久久| 不卡影院免费观看| 国产精品色呦呦| 国产剧情一区二区三区| 91精品国产一区二区三区| 亚洲国产欧美在线人成| 91久久久免费一区二区| 一区二区三区四区不卡视频| 成年人网站91| 亚洲123区在线观看| 欧美在线播放高清精品| 亚洲成人免费视频| 51精品视频一区二区三区| 午夜久久福利影院| 91精品国产综合久久婷婷香蕉| 亚洲国产综合色| 91精品在线麻豆| 久久精品av麻豆的观看方式| 97se亚洲国产综合自在线| 亚洲激情中文1区| 丝袜脚交一区二区| 亚洲国产视频a| 成人av电影在线网| 欧美男女性生活在线直播观看| 日韩美女视频19| 91免费版在线| 亚洲欧洲成人自拍| 成人一区二区三区视频在线观看| 自拍偷拍亚洲综合| 久久国产精品99精品国产| 一本大道久久a久久综合婷婷| 不卡一区二区在线| 一区二区三区四区精品在线视频| 久久丝袜美腿综合| 91精品国产美女浴室洗澡无遮挡| 91蜜桃网址入口| 亚洲h在线观看| 国产精品天天看| 精品成人佐山爱一区二区| 99精品偷自拍| 91精品国产福利| 成人欧美一区二区三区黑人麻豆| 日韩福利电影在线| 成人国产亚洲欧美成人综合网 | 欧美日韩免费视频| 国产综合色精品一区二区三区| 波多野结衣中文字幕一区| 久久久久久久久久久99999| 99re在线视频这里只有精品| 亚洲韩国一区二区三区| 在线精品视频免费播放| 亚洲大片在线观看| 99久久免费国产| 欧美三级电影精品| 粉嫩13p一区二区三区| 国内精品自线一区二区三区视频| 国产成人久久精品77777最新版本| 不卡一区二区中文字幕| 欧美大片在线观看一区二区| 亚洲1区2区3区4区| 欧美伦理视频网站| 人人狠狠综合久久亚洲| 91麻豆精品国产91| 2020国产成人综合网| 国产亚洲自拍一区| 国产精品网站在线观看| 亚洲欧美日韩小说| 亚洲国产精品久久久男人的天堂| 亚洲日本一区二区三区| 亚洲高清免费观看| 日日摸夜夜添夜夜添亚洲女人| 日本韩国一区二区三区| 五月婷婷欧美视频| 欧美一区二区视频网站| 国产成人亚洲综合a∨猫咪| 中文字幕不卡的av| 91老司机福利 在线| 日本中文一区二区三区| 26uuu精品一区二区在线观看| 国产尤物一区二区在线| 日本一区二区免费在线观看视频 | 日日骚欧美日韩| 国产欧美日韩另类一区| 欧美性视频一区二区三区| 九九精品视频在线看| 一区二区三区免费网站| 精品乱码亚洲一区二区不卡| 欧美在线视频你懂得| 成人免费观看男女羞羞视频| 韩国一区二区三区| 日韩高清在线一区| 亚洲国产日韩一区二区| 最新国产の精品合集bt伙计| 国产精品每日更新| 亚洲欧洲99久久| 亚洲欧美综合在线精品| 久久精品一区二区三区不卡| 2020日本不卡一区二区视频| 另类小说一区二区三区| 欧美精品一区二区三区高清aⅴ| 午夜精品一区在线观看| 在线观看欧美黄色| 亚洲毛片av在线| 欧美精品色综合| 九九精品一区二区| 国产欧美日韩另类一区| 色综合久久久久网| 日本丶国产丶欧美色综合| 色网综合在线观看| 日韩精品一区在线观看| 国产女人18毛片水真多成人如厕| 国产精品国产三级国产普通话蜜臀 | 亚洲综合一区二区三区| 亚洲一区二区三区在线播放| 天天av天天翘天天综合网| 久久国产精品免费| 欧美视频一区在线| 国产精品乱码妇女bbbb| 婷婷综合五月天| 成人国产电影网| 7799精品视频| 亚洲www啪成人一区二区麻豆| 国产mv日韩mv欧美| 精品国产一区二区三区四区四| 亚洲欧美偷拍三级| 国产91在线看| 日韩精品一区二区三区视频在线观看 | 成人精品亚洲人成在线| 久久精品久久99精品久久| 国产欧美综合色| 欧美一区二区三区成人| 色综合久久久网| av中文字幕一区| 高清beeg欧美| 亚洲综合一区二区精品导航| 91视频在线观看| 亚洲成精国产精品女| 在线看日韩精品电影| 亚洲一本大道在线| 在线播放亚洲一区| 精品一区二区三区久久| 亚洲国产成人在线| 91美女蜜桃在线| 香蕉久久夜色精品国产使用方法| 欧美巨大另类极品videosbest| 日韩电影网1区2区| 中文在线资源观看网站视频免费不卡| 国产激情一区二区三区| 一区二区视频在线看| 欧美日韩国产123区| 韩国毛片一区二区三区| 亚洲欧美国产毛片在线| 久久久高清一区二区三区| 2021久久国产精品不只是精品| 欧美经典一区二区三区| 亚洲国产人成综合网站| 91香蕉视频mp4| 国产精品天天看| 欧美大片顶级少妇| 26uuu国产电影一区二区| 91性感美女视频| 欧美亚洲丝袜传媒另类| 在线视频你懂得一区二区三区| 欧美性生交片4| 日韩欧美专区在线| 国产欧美一区二区在线| 国产精品久久久久久久久快鸭| 1000精品久久久久久久久| 一区二区久久久久| 三级亚洲高清视频| 美女一区二区视频| 成人不卡免费av| 欧美一卡二卡三卡| 日韩美女啊v在线免费观看| 亚洲成人一区二区在线观看| 国产成人亚洲综合色影视| 色狠狠综合天天综合综合|