您現在的位置: 365建站網 > 365學習 > 我認為JSP有問題(上)

我認為JSP有問題(上)

文章來源:365jz.com     點擊數:494    更新時間:2015-09-16 20:13   參與評論

(編者:這篇文章的原文首次在國外出現時,JSP還只是一種剛剛嶄露頭角的技術,并沒有像現在這樣如日中天?,F在看來這篇文章的某些觀點可能會有一定的局限性,但我不得不承認這是一篇很大氣的作品,其中涉及很多JSP的內在原理。因此,我想還是有必要把這篇文章介紹給大家,以便各位從另一個側面更深入的了解JSP技術。)

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

  本文將比較JSP和另一項基于servlets的技術:template engines(模板引擎)。

直接使用Servlets的問題

  當Servlets被發明時,整個世界都看到了它的優越性?;赟ervlet的動態網頁可以被快速執行,可以在多個服務器之間輕易轉移, 并且可以和后臺數據庫完美地集成,因此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??梢愿鶕撠熆刂频膕ervlet的內部邏輯來選擇適當的JSP頁面進行顯示。這樣,JSP文件成為了一個漂亮的template view。這就是另一種發展,并被另外一些開發者所推崇至今。

進入Template Engines

  如果使用template engine來代替通常目的的JSP, 接下去的設計將變得簡單,語法更簡單,出錯信息更易讀,工具也更用戶化。一些公司已經做了這樣的引擎,最著名的可能是WebMacro,他們的引擎是免費的。

  開發者應該明了,選定一個template engine來取代JSP提供了以下一些技術優勢,而這些同時也正是jsp的不足之處:

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

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

  問題 #2: 要求寫Java代碼

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

  $#@60;a href="$#@60;%= request.getContextPath() %$#@62;/index.html"$#@62;Home page$#@60;/a$#@62;

  你可以試圖避免Java代碼,而使用 $#@60;jsp:getProperty$#@62; 標記,但這將給你如下難以閱讀的字符串:

  $#@60;a href="$#@60;jsp:getProperty name="request" property="contextPath"/$#@62;/index.html"$#@62;HomePage$#@60;/a$#@62;

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

  $#@60;a href="$Request.ContextPath;/index.html"$#@62;Home page$#@60;/a$#@62;

  在WebMacro中, ContextPath 作為 $Request變量的一個屬性,使用類似Perl的語法。其它template engines使用了其它的語法類型。

  再看另一個例子,假設一個高級的"view"需要設定一個cookie來記錄用戶缺省的顏色配置 -- 這種任務看起來大概只能由view而不是servlet控制器來完成。在JSP中要有這樣的Java代碼:

  $#@60;% Cookie c = new Cookie("colorscheme", "blue"); response.addCookie(c); %$#@62;

  在WebMacro中則沒有Java代碼:

  #set $Cookie.colorscheme = "blue"

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

  $#@60;% String colorscheme = ServletUtils.getCookie(request, "colorscheme"); %$#@62;

  在WebMacro中沒有對工具類的需要,通常是:

  $Cookie.colorscheme.Value

  對于必須去寫jsp的圖形界面設計師,哪一種語法更容易學習呢?

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

 

如對本文有疑問,請提交到交流論壇,廣大熱心網友會為你解答??! 點擊進入論壇


發表評論 (494人查看,0條評論)
請自覺遵守互聯網相關的政策法規,嚴禁發布色情、暴力、反動的言論。
用戶名: 驗證碼: 點擊我更換圖片
最新評論
------分隔線----------------------------
自拍偷拍福力视频,偷拍国际精品,麻豆一区福利电影,国产网红视频午夜福利,se视频大全,久久国产AV影院 99久久国产精品免费| 欧美熟妇| poronodrome另类极品| 同桌上课脱我裙子弄到高潮| 秋霞在线| 美女视频免费永久观看的网站| 日本老熟妇六十0930| 暧暧视频 免费观看| 日本高清视频www色| 女厕真实偷拍撒尿视频| yellow2019最新资源| a片太大太长太深好爽在线观看| 坏老人全本免费阅读| 护士情欲短篇小说强| 日本无遮挡真人床震视频| 特级欧美aaaaaa片| 免费看12萝裸体视频国产| 国产日韩av免费无码一区二区| 亚洲丁香婷婷综合久久| 咪咪网| 日本高清乱理伦片中文字幕| 国产亚洲人成网站在线观看| 中文字幕人妻不在线无吗视频| 人与人性恔配视频免费| 无码毛片视频一区二区本码| 抖音奶片故意走漏15秒| 80岁老太婆牲交人与、鲁| free女厕所vedio| 高挑美女被遭强高潮摸下面| 男人边吃奶边做好爽免费视频| chinese熟女老女人hd| http://www.windowsoxford.com