Java Servlet技术与JSP技术使Java服务器端技术,目前他们控制了整个服务器端Java技术市场,并且逐渐成为构建商业Web应用的标准。Java开发者喜欢这些技术是由于很多的原因,包括:这些技术很容易学习,一次编写,处处运行(Write Once, Run Anywhere)。更重要的是,如果更高效地采用了下面的实践,Servlet与JSP能够帮助分开Web的表示与内容。“最佳实践”是被证明为开发高质量、可重用与易维护的基于Servlet和JSP的Web应用的较好方法。与此相对应的是,将Java代码混合在HTML中,这样很容易产生低效率、不易重用、难于维护的复杂应用程序。最佳实践将改变这些弊端。
本文将描述为Servlets与JSP准备的最佳实践的重要性;这里假设读者已经了解两者的基本工作原理。这篇文章将涵盖以下内容:
类似于通用网关接口(CGI)脚本,servlets支持请求响应编程模式。当客户端给服务器发送请求时,服务器将请求发送给servlet。然后,servlet构建一个响应,服务器将该响应发送回客户端。然而,跟CGI脚本不同的是,servlets和HTTP服务器运行在同一个进程内。
当发出客户端请求的时候,调用service 方法并传递一个请求和响应对象。Servlet首先判断该请求是GET 操作还是POST 操作。然后它调用下面的一个方法:doGet 或 doPost。如果请求是GET就调用doGet方法,如果请求是POST就调用doPost方法。doGet和doPost都接受请求(HttpServletRequest)和响应(HttpServletResponse)。
最简单地说,servlets是能够使用print语句产生动态HTML内容的Java类。然而,有一点必须要提一下,那就是servlets是在一个容器内运行的,并且APIs 提供了对会话和对象的生命周期的管理。因此,当你使用servlets时,你就能获得Java平台的所有优势,它包括沙箱 (安全)、通过JDBC的数据库存取API和具有跨平台可移植性的servlets。
JSP技术是Servlet技术的一个较高层次的抽象。它是Sun公司开发、开放的技术,是与Microsoft公司的ASP动态网页技术相似的一种技术,并且它是Java2 企业版(J2EE)的一个关键组件。目前,很多商业的应用服务器(例如BEA WebLogic, IBM WebSphere, Live JRun, Orion等等)都支持JSP。
JSP页面如何工作?
JSP页面实际上是一个带有传统HTML和Java代码的Web页面。JSP页面的文件扩展名是.jsp而并不是.html或.htm,该扩展名告诉服务器该页面需要特殊的处理,该特殊处理必须由服务器扩展或插件实现。
当一个JSP页面被读取时,他首先将被编译(JSP引擎来做这件事情)为一个Servlet。 这时候这个Servlet就像其他Servlet一样被交给Servlet引擎来处理。然后Servlet引擎读取那个Servlet对应的类(用ClassLoader)并且执行它,产生一个动态HTML页面(图1)。这个Servlet创建一些必需的元件,然后将这些元件作为一个字符串写入输出流(OutputStream),并显示在浏览器中。
调用JSP页面时,首先会将它编译成一个 (通过JSP引擎) Java servlet。这时,servlet引擎处理该servlet,就像处理任何其他servlet一样。然后,servlet引擎加载servlet类 (使用类加载器) 并执行它创建动态HTML发送给浏览器,如图1所示。Servlet创建所有必需的对象,并将所有对象作为字符串写入到输出流中,并在浏览器中显示。
图1: 调用一个JSP页面的请求/响应流程图
下次请求该页面的时候,JSP引擎执行早就装载的servlet除非JSP页面早就更改,在这种情况下,会将它自动重新编译进一个servlet中并执行。
在本节中,将描述在Servelt, 特别是JSP中的最佳实践。强调JSP最佳实践是因为JSP比Servlet得到更为广泛的应用(也许是因为JSP技术促进了表示与逻辑的分离)。一个集成Servlet与JSP的最佳实践是“模型-显示-控制器”设计模式(Model View Controller, MVC),将在本文的后面部分进行讨论。
当JSP正在转换成Servlet时,第一种include机制将包含指定文件的内容(转换阶段),对于第二种include机制来说,当该页面执行后时,页面包含了用Response产生的内容。当被包含的页面不太改变的时候,我推荐使用第一种include指令方式,这种方式比较快,性能较好;当被包含的文件经常改变(其中也有动态内容)时,并且在执行主页的时候不能确定所要引入的的页面的时候,使用第二种include行为方式。
另一种include机制是使用JSP标准标记库(JSTL)中的<c:import> 行为标记。可以使用这种方式来包含本地的或者远程的文件,下面是一些例子:
<c:import url="./copyright.html"/>
<c:import url="http://www.somewhere.com/hello.xml"/>
如果在你的应用程序中使用了Enterprise JavaBeans (EJBs)组件,必须将业务逻辑保留在EJB组件中,提供生命周期管理,事务支持与对多客户端对域对象(实体Beans)的存取。可以在Enterprise BluePrints 获得更为详细的资料。
简而言之,你可以使用和使用HTML创建表达式一样的方法来通过自定义标记完成复杂的任务。
编写自定义标记库的时候,可以使用下列编程指南:
<someTags:aTag attribute="<%=
pageContext.getAttribute("aName") %>">
或自定义的JavaBeans组件的值:
<%= aCustomer.getAddress().getCountry() %>
表达式语言允许页面作者使用简化的语法存取对象。例如,可以使用下面的语句存取简单变量:
<someTags:aTag attribute="${aName}">
如果想要存取嵌套的JavaBeans属性,可以使用下面的语句:
<someTags.aTag attribute="${
aCustomer.address.country}">
如果你使用JavaScript,你将会觉得非常熟悉,因为EL采用JavaScript语法存取结构化数据。
JSP规范给出了使用JSP页面构建Web应用程序的两个方案:JSP模型1和模型2体系结构。这两个模型的区别在于处理的位置。在模型1的体系结构中,如图2所示,JSP页面负责处理请求并将响应发送给客户端。
图 2: JSP模型1 体系结构
模型2体系结构,如图3所示,集成使用了servlets 和JSP页面。在该模型中,JSP页面用于表示层,并且servlets负责处理各类任务。Servlet作为一个控制器,负责处理请求并创建JSP页面所需的任何bean。该控制器也负责确定将该请求传递到哪个JSP页面。JSP页面检索servlet创建的对象,并提取动态内容插入在一个模板中。
图 3: JSP模型 2 体系结构
该模型促进了模型视图控制器(MVC)体系结构风格设计模式的使用。注意,早就存在多个框架能够实现该有用的设计模式,并将内容和表示真正地独立开来。Apache Struts是MVC的形式化框架。该框架非常适用于复杂的应用程序,在这些复杂的应用程序中单个请求或表单提交会产生看起来截然不同的结果。
最佳实践—事实证明是经常重复出现的问题的解决方案—产生了高质量的应用程序。本文是开发servlet时需要遵守的多个指南和最佳实践-和基于JSP的Web应用程序。
请留心servlets和JSP技术,因为在这些技术中有许多激动人心的东西。例如,JavaServer Faces (JFC),是一个Java程序社区(Java Community Process),它的目标是定义一个标准的Web应用框架,这将很好地和Apache Struts集成。
……