电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:4日期:2024-07-04 15:42:34

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

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

直接使用Servlets的問題

起初,servlets被發(fā)明,整個世界都看到了它的優(yōu)越。基于servlet的動態(tài)網(wǎng)頁可以被快速執(zhí)行,可以在多個服務器之間輕易轉(zhuǎn)移, 并且可以和后臺數(shù)據(jù)庫完美地集成。 Servlets被廣泛接受成為一種web服務器端的首選平臺。;

但是,通常通過簡單方式即可實現(xiàn)的html代碼現(xiàn)在卻要讓程序員通過 out.println()調(diào)用每一行HTML行,這在實際的 servlet應用中成為了一個嚴重問題。 HTML內(nèi)容不得不通過代碼來實現(xiàn), 對于大的HTML頁來說不啻是一項繁重費時的工作。另外,負責網(wǎng)頁內(nèi)容的人員不得不請開發(fā)人員來進行所有的更新。為此,人們尋求這一種更好的解決方式。

JSP到!

JSP 0.90出現(xiàn)了。在這種技術(shù)中你可以將Java代碼嵌入到HTML文件,服務器將自動為頁面創(chuàng)建一個 servlet。 JSP被認為是一種寫servlet的簡易方式。所有HTML可以直接得到而不必通過out.println()調(diào)用,而負責頁面內(nèi)容的人員可以直接修改HTML而不必冒破壞Java代碼的風險。;

但是,讓頁面美術(shù)設計師和開發(fā)人員在同一文件上工作并不理想,讓Java嵌入HTML被證明是就象將HTML 嵌入Java一樣令人尷尬。讀取一堆很亂的代碼仍然是一件困難的事情。;

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

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

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

  進入Template Engines

使用template engine來代替通常目的的JSP, 接下去的設計將變得簡單,語法更簡單,出錯信息更易讀,工具也更用戶化。 一些公司已經(jīng)做了這樣的引擎,最著名的可能是WebMacro (http://webmacro.org, from Semiotek),他們的引擎是免費的。;

開發(fā)者應該明了,選定一個template engine來取代JSP提供了這么一些技術(shù)優(yōu)勢,這也正是jsp的一些不足之處:

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

雖然被認為是不好的設計,JSP仍試圖將Java代碼加入web頁面。這有些象是Java曾經(jīng)做的,即對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=".ContextPath;/index.html">Home page</a>

在WebMacro中, ContextPath 作為 template engines使用了其它的語法類型。;

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

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

在WebMacro中則沒有Java代碼:

#set .colorscheme = "blue"

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

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

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

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

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

即使是很簡單的工作,例如包含 header和 footer,在JSP中仍然很很困難。 假設有一個 "header"和一個 "footer"模板要包含到所有頁面,而每一個模板要在content中包含當前的頁標題。;

在JSP中最佳辦法是:;

<% String title = "The Page Title"%>;

<%@ include file="/header.jsp" %>;

...你的頁面內(nèi)容...;

<%@ include file="/footer.jsp" %>

頁面設計者要記住不能遺漏第一行的分號并要將title定義為一個字符串。此外, /header.jsp和/footer.jsp必須在根目錄下并且必須是可存取的完整文件。;

在WebMacro中包含headers和footers做起來比較簡單:

#set 24 = "The Page Title";

#parse "header.wm";

Your content here;

#parse "footer.wm"

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

問題 #4: 很粗的循環(huán)

在JSP中循環(huán)很困難。這里是用JSP重復打印出每一個ISP對象名字。;

<%;

Enumeration e = list.elements();;

while (e.hasMoreElements()) {;

out.print("The next name is ");;

out.println(((ISP)e.nextElement()).getName());;

out.print("<br>");;

};

%>

也許什么時候會有用戶自定義標記來做這些循環(huán)。對"if"也是如此。JSP頁可能看上去成了很古怪的java代碼。而同時,webmacro循環(huán)很漂亮:;

#foreach in {;

The next name is .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常有一些令人驚訝的出錯信息。這是因為頁面首先被轉(zhuǎn)換成為一個servlet然后才進行編譯。好的JSP 工具可以相對增加找到出錯位置的可能性,但即使是最好的工具也無法使所有出錯信息都能容易地被讀懂。由于轉(zhuǎn)化的過程,一些錯誤對工具來說可能根本不可能被識別。

例如,假設JSP頁面需要建立一個對所有頁通用的標題。以下代碼并沒有錯:

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

但Tomcat會提供以下出錯信息:;

work/%3A8080%2F/JC_0002ejspJC_jsp_1.java:70: Statement expected.;

static int count = 0;;

^;

此信息認為以上腳本被放入 _jspService()方法而靜態(tài)變量不允許放入方法中。該語法應該是 <%! %>。頁面設計者很難讀懂這些出錯信息。即使最好的平臺在這方面也做得很不夠。即使所有 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("rn");;

^

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

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

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

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

問題 #7: 空間的浪費

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

使用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已經(jīng)占據(jù)了極大的商業(yè)市場,并且深入人心。而使用g template engines只能是一種未被了解的替代技術(shù)。

Template的問題 #3: 尚未調(diào)配好

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

JSP的角色

當然地,JSP在將來必然會有其地位。即使從名稱上也可以看出JSP和ASP的相似性,它們只有一個字母的差別。所以如果要讓使用asp的人們轉(zhuǎn)向java,非常相似的jsp環(huán)境將對此起到很大的推動作用,和asp保持這種對應關(guān)系所能起到的作用應該也是被推出jsp的設計者重點考慮到的。;

然而這里想要強調(diào)的一點是:有利于轉(zhuǎn)入新環(huán)境的工作者,以及實際上是否是使用該環(huán)境的最佳方式,這兩者是有很大不同的。

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

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

標簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 密封圈_泛塞封_格莱圈-[东莞市国昊密封圈科技有限公司]专注密封圈定制生产厂家 | 登车桥动力单元-非标液压泵站-非标液压系统-深圳市三好科技有限公司 | 广东风淋室_广东风淋室厂家_广东风淋室价格_广州开源_传递窗_FFU-广州开源净化科技有限公司 | 磷酸肌酸二钠盐,肌酐磷酰氯-沾化欣瑞康生物科技 | 贴片电容-贴片电阻-二三极管-国巨|三星|风华贴片电容代理商-深圳伟哲电子 | 定量包装机,颗粒定量包装机,粉剂定量包装机,背封颗粒包装机,定量灌装机-上海铸衡电子科技有限公司 | 中山市派格家具有限公司【官网】 | 电子元器件呆滞料_元器件临期库存清仓尾料_尾料优选现货采购处理交易商城 | 板式换热器_板式换热器价格_管式换热器厂家-青岛康景辉 | 超声波清洗机_细胞破碎仪_实验室超声仪器_恒温水浴-广东洁盟深那仪器 | 余姚生活网_余姚论坛_余姚市综合门户网站 | 时代北利离心机,实验室离心机,医用离心机,低速离心机DT5-2,美国SKC采样泵-上海京工实业有限公司 工业电炉,台车式电炉_厂家-淄博申华工业电炉有限公司 | bkzzy在职研究生网 - 在职研究生招生信息咨询平台 | 玖容气动液压设备有限公司-气液增压缸_压力机_增压机_铆接机_增压器 | T恤衫定做,企业文化衫制作订做,广告T恤POLO衫定制厂家[源头工厂]-【汉诚T恤定制网】 | 深圳办公室装修-写字楼装修设计-深圳标榜装饰公司 | 气密性检测仪_气密性检测设备_防水测试仪_密封测试仪-岳信仪器 | 全自动过滤器_反冲洗过滤器_自清洗过滤器_量子除垢环_量子环除垢_量子除垢 - 安士睿(北京)过滤设备有限公司 | 杭州用友|用友软件|用友财务软件|用友ERP系统--杭州协友软件官网 | 南京和瑞包装有限公司| 执业药师报名时间,报考条件,考试时间-首页入口 | 小程序开发公司_APP开发多少钱_软件开发定制_微信小程序制作_客户销售管理软件-济南小溪畅流网络科技有限公司 | 电子书导航网_电子书之家_电子书大全_最新电子书分享发布平台 | 捷码低代码平台 - 3D数字孪生_大数据可视化开发平台「免费体验」 | 汝成内控-行政事业单位内部控制管理服务商 | 无锡网站建设_小程序制作_网站设计公司_无锡网络公司_网站制作 | Eiafans.com_环评爱好者 环评网|环评论坛|环评报告公示网|竣工环保验收公示网|环保验收报告公示网|环保自主验收公示|环评公示网|环保公示网|注册环评工程师|环境影响评价|环评师|规划环评|环评报告|环评考试网|环评论坛 - Powered by Discuz! | 医学动画公司-制作3d医学动画视频-医疗医学演示动画制作-医学三维动画制作公司 | 喷播机厂家_二手喷播机租赁_水泥浆洒布机-河南青山绿水机电设备有限公司 | 专业深孔加工_东莞深孔钻加工_东莞深孔钻_东莞深孔加工_模具深孔钻加工厂-东莞市超耀实业有限公司 | 西装定制/做厂家/公司_西装订做/制价格/费用-北京圣达信西装 | 河南不锈钢水箱_地埋水箱_镀锌板水箱_消防水箱厂家-河南联固供水设备有限公司 | 楼承板-开闭口楼承板-无锡海逵楼承板| 安徽净化工程设计_无尘净化车间工程_合肥净化实验室_安徽创世环境科技有限公司 | 防腐储罐_塑料储罐_PE储罐厂家_淄博富邦滚塑防腐设备科技有限公司 | 网站优化公司_SEO优化_北京关键词百度快速排名-智恒博网络 | 臻知网大型互动问答社区-你的问题将在这里得到解答!-无锡据风网络科技有限公司 | 武汉不干胶印刷_标签设计印刷_不干胶标签印刷厂 - 武汉不干胶标签印刷厂家 | 河南不锈钢水箱_地埋水箱_镀锌板水箱_消防水箱厂家-河南联固供水设备有限公司 | 通信天线厂家_室分八木天线_对数周期天线_天线加工厂_林创天线源头厂家 | 冷却塔减速机器_冷却塔皮带箱维修厂家_凉水塔风机电机更换-广东康明冷却塔厂家 |