Java Web Framework综述
Written by 王海龙 buaawhl@sina.com
0.简介
本文介绍Java Web Framework的基本工作原理,和一些常用的开源Web MVC Framework(Struts, Web Work, Tapestry, Echo, JSF, Maverick, Spring MVC, Turbine, Cocoon, Barracuda)。
Web开发的最重要的基本功是HTTP;Java Web开发的最重要的基本功是Servlet Specification。HTTP和Servlet Specification对于Web Server和Web Framework的开发实现来说,是至关重要的协议规范。
应用和剖析开源Web Framework,既有助于深入掌握HTTP & Servlet Specification, 也有助于了解一些现代的B/S Web框架设计思想,如MVC,事件处理机制,页面组件,IoC,AOP等。在这个现代化的大潮中,即使Servlet规范本身也不能免俗,不断引入Filter、Listener等现代框架设计模式。同是Sun公司出品的JSF更是如此。
关于MVC模型、项目简介、配置文件、入门示例等基础知识,网上已经有大量的重复资料信息,本文不再赘述。
文中会提到一些相关的开源项目,和一些编程思想,如有需要,可以用相关的关键字在网上搜索,获取基本的背景知识。
本文力图言简意赅,突出重点。着重描述其他资料没有提到、或很少提到的较重要内容,如运行原理、主流用法,相关知识,关键特性等。
1. Java Web程序工作原理
[编者按:本部分内容在本期杂志《Servlet规范简介》有更详细介绍]
Tomcat的Server.xml文件中定义了网络请求路径到主机本地文件路径的映射。比如,<context path="/yourapp" docBase="yourapp_dir/webapp"/>
我们来看一下,一个HTTP Request-Response Cycle的处理过程。
HTTP Request URL一般分为三段:host, context, path。
如http://yourhost/yourapp/en/index.html这个URL,分为host=yourhost, context=yourapp, path=en/index.html三段。其中,Context部分由request.getContext()获得,path部分由request.getServletPath()获得(返回结果是“/en/index.html”)。
yourhost主机上运行的Tomcat Web Server接收到这个URL,根据Context定义,把yourapp这个网络路径映射为yourapp_dir/webapp,并在此目录下定位en/index.html这个文件,返回到客户端。
如果我们这个URL更换为http://yourhost/yourapp/en/index.jsp,这个时候Tomcat会试图把yourapp_dir/webapp/en/index.jsp文件编译成Servlet,并调用运行这个Servlet。
我们再把这个URL更换为http://yourhost/yourapp/en/index.do。
注意,戏剧化的事情就发生在这个时候,Servlet规范中最重要的类RequestDispatcher登场了。RequestDispatcher根据WEB-INF/web.xml配置文件的定义,调用对应的Servlet来处理en/index.do这个路径。
假设web.xml里面有这样的定义。
<servlet>
<servlet-name>DispatchServlet</servlet-name>
<servlet-class>yourapp.DispatchServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>DispatchServlet</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
那么,RequestDispatcher会调用yourapp.DispatchServlet类处理这个路径。
如果web.xml没有定义对应en/index.do这个路径的Servlet,那么Tomcat返回“您请求的资源不存在”。
RequestDispatcher用于Web Server中,也可以用于应用程序中进行处理转向,资源定位。比如,我们在处理en/index.do的代码中调用,
request.getRequestDispatcher(“cn/index.jsp”).forward(request, response), 就可以转交另外的资源cn/index.jsp来处理。
几乎所有的Web Framework都需要定义自己的Dispatch作用的Servlet,并调用RequestDispatcher进行转向处理。
阅读Web Framework源代码,有两条主要线索,(1)根据web.xml找到对应的Servlet类;(2)搜索包含“RequestDispatcher”词的代码文件。
我们看到,request, response 这两个参数,被RequestDispatcher在各种Servlet之间传来传去(JSP也是Servlet)。所以,request的setAttribute()和getAttribute()方法是Servlet之间传送数据的主要方式。
在MVC结构中,一般的处理流程如下:
处理HTTP Request的基本单位一般称为Action,是一个比Servlet轻量得多的接口定义,通常只有一两个方法,如execute(perform), validate等。
我们知道,URL->Servlet映射,定义在Web.xml配置文件里,但MVC框架通常会有另外一个定义URL-> Action映射的配置文件。
入口Dispatcher Servlet根据URL -> Action的映射关系,把请求转发给Action。
Action获得输入参数,调用商业逻辑,并把结果数据和View标识给(Model & View)返回给Dispatcher Servlet。
Dispatcher Servlet根据这个View 标识,定位相应的View Template Path,把处理转交给View(JSP +TagLib, Velocity, Free Marker, XSL等)。
View一般通过request.getAttribute()获得结果数据,并显示到客户端。至于是谁把结果数据设置到request.attribute里面,有两种可能:Action或Dispatcher Servlet。
2. Struts
http://struts.apache.org/
Struts是目前用户群最大、开发厂商支持最多的开源Web Framework。
Struts劳苦功高,为普及MVC框架作出了不可磨灭的贡献。显赫的声望,趋于老化的厚重结构,令Struts成为很多现代Web Framework参照、挑战的目标。
Struts应用主要包括3件事情: 配置struts-config.xml文件,实现Action类,实现View;还有一些高级扩展用法。下面分别讲述。
1. 配置struts-config.xml文件:
Struts支持多级配置文件,具体用法和限制,详见Struts文档。这里只讨论struts-config.xml主流配置的内容。:-)
(1) URL Path到Action的映射。
如<action path="/LogonSubmit" type="app.LogonAction" ... />
Struts的入口Servlet是ActionServlet。
ActionServlet需要此信息把URL Path调用对应的Action类处理。
在Struts运行期间,一个URL Path,只存在一个对应的Struts Action实例。所有的该URL Path的请求,都经过这同一个Struts Action实例处理。所以Struts Action必须线程安全。
想想看,其实这个要求并不过分,Action只是一个处理程序,不应该保存跨HTTP请求的状态数据,按理来说,也应该做成线程安全的。
(2) Template Name到View Template Path的映射。
<forward name="success" path="/pages/Welcome.jsp"/>
Action类返回一个Template Name,ActionServlet根据这个Template Name获得对应的View Template Path,然后调用
request.getRequestDispatcher(“View Template Path”),把处理转向路径对应的Servlet。在这个例子中,是转向/pages/Welcome.jsp编译后的Servlet。
我们来看一个一个Velocity的例子。
<include name="success" path="/pages/Welcome.vm"/>
web.xml的定义如下
<servlet>
<servlet-name>velocity</servlet-name>
<servlet-class>org.apache.velocity.tools.view.servlet.VelocityViewServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>velocity</servlet-name>
<url-pattern>*.vm</url-pattern>
</servlet-mapping>
这时,request.getRequestDispatcher(“/pages/Welcome.vm”)会调用VelocityViewServlet,由VelocityViewServlet负责装并驱动运行/pages/Welcome.vm这个模板文件。
这里面有一个问题,如果调用的是DispatchRequester.include()方法,那么如何才能把pages/Welcome.vm传给VelocityViewServlet呢?
如前所说,RequestDispatcher传递的参数只有两个,request和response。那么只能通过request attribute。正是为了解决这个问题,Servlet2.3规范之后,加入了javax.servlet.include.servlet_path这个属性。
参见VelocityViewServlet的代码(velocity-tool开源项目)
// If we get here from RequestDispatcher.include(), getServletPath()
// will return the original (wrong) URI requested. The following special
// attribute holds the correct path. See section 8.3 of the Servlet
// 2.3 specification.
String path = (String)request.getAttribute("javax.servlet.include.servlet_path");
从这里我们可以看出,为什么通晓Servlet Specification对于通晓Web Framework至关重要。
(3) Form Bean的定义
如<form-bean name="logonForm"
type="app.LogonForm"/>
Struts Form Bean需要继承ActionForm类。
Form Bean类,主要有三个作用:
[1]根据bean的定义,利用reflection机制,自动把request参数转化为需要的数据类型,填入到bean的属性当中。ActionForm类名中虽然有Form这个词,但不仅能够获取Form提交后的HTTP Post参数,也可以获取URL后缀的HTTP Get参数。
[2]
分享到:
相关推荐
本文将对Java Web Framework进行概述,特别是Struts框架,同时深入探讨Java Web程序的工作原理。 首先,Java Web程序的基础是HTTP协议和Servlet规范。HTTP协议定义了客户端(浏览器)与服务器之间的通信方式,而...
3. **数据库交互**:新闻系统必然涉及到数据存储和检索,可能会使用ADO.NET或Entity Framework与SQL Server或其他关系型数据库进行交互。这包括了数据查询、添加、更新和删除操作。 4. **身份验证和授权**:新闻...
【Java技术在Web环境下的网络商店销售系统】 Java技术在Web环境中的应用广泛,尤其在网络商店销售系统中,它的优势在于跨平台性、安全性以及强大的企业级开发支持。本项目是一个基于Java技术的Web环境下的网络商店...
1. Apache Axis2:一个流行的Java Web Services框架,用于生成和处理SOAP消息。 2. .NET Framework:微软提供的开发平台,内置对Web Services的支持。 3. WSO2:提供一系列开源的Web Services和API管理解决方案。 4....
在2004年的第六届ArcGIS暨ERDAS中国用户大会上,林青(Cherry Lin)介绍了如何通过Java ADF(Application Development Framework)来开发和部署ArcGIS Server应用。这不仅是一次技术分享,也是对GIS(地理信息系统)...
标题中的“ASP基于WEB在线直销商城(LW+源代码+文献综述+外文翻译)”表明这是一个关于ASP技术构建的Web应用程序,具体是用于在线直销的商城系统。它包括了完整的源代码,意味着我们可以深入研究系统的实现细节。此外...
文献综述可能对比了ASP.NET与其他Web开发技术的优缺点,如PHP、Java等,同时也可能探讨了最新的Web开发趋势,如响应式设计、单页应用(SPA)以及微服务架构,以及ASP.NET如何适应这些趋势。 外文翻译部分可能是对...
通常,ASP是与.NET Framework相关的,而Java则是完全不同的编程语言,它们不直接兼容。不过,如果这个项目中包含Java源码,可能是因为系统某些部分或额外的辅助服务是用Java编写的。"LW"在这里没有明确含义,可能是...
- ActiveX服务器框架(ActiveX Server Framework):为WEB服务器应用程序设计提供了丰富的函数和封装类。 - Internet Explorer内置的Java虚拟机:支持Java Applet运行并与ActiveX控件通过脚本语言通信。 3. ActiveX...
ASP.NET是一种基于微软.NET Framework的Web应用程序开发框架,主要用于构建动态网站、Web应用程序和Web服务。这个名为"ASP.NET网络商店设计与实现"的项目,显然涵盖了使用ASP.NET技术进行电子商务平台开发的相关知识...
ASP的主要优点包括易学易用、与.NET Framework兼容、可扩展性强,能够轻松处理数据库连接和用户交互。 二、Web在线直销商城架构 1. 用户界面:通过HTML和CSS设计美观且响应式的前端页面,使用户能方便地浏览商品、...
构件通常具有明确的接口定义,遵循一定的规范(如Java的JAR、.NET的DLL或Web服务的WSDL),保证不同构件间的互操作性。 软件构件的分类主要包括:库构件、框架构件、应用程序构件和服务构件。库构件提供基础功能,...
项目是基于ASP.NET的Web应用程序开发,旨在构建一个高性能、可扩展和可靠的在线平台。我们将使用ASP.NET MVC框架和C#编程语言来实现这个项目。 ASP.NET MVC是一种成熟的开发框架,它采用模型-视图-控制器的设计模式...
Java Web项目。项目使用了Spring MVC、Spring framework、Hibernate和Spring JDBC、Bootstrap、ECharts等技术. 毕业设计是高等教育阶段学生在完成学业前所进行的一项重要学术任务,旨在检验学生通过学习所获得的...
Eclipse Modeling Framework (EMF) 是Eclipse中的核心模型框架,提供了一套工具和库用于构建和操作数据模型。通用建模语言(UML)和其他模型可以被导入或创建,以帮助理解和管理复杂系统的结构。 四、集成开发环境...
### Android系统的开发综述 #### 一、Android系统架构概览 **1.1 软件结构** Android系统的软件结构分为四个主要层次: 1. **操作系统层**:这一层主要包括Linux内核及相关驱动程序。Android的核心服务依赖于...
JAVA是一种跨平台的面向对象语言,尤其适合开发分布式应用程序,其JSP(JavaServer Pages)和Servlet技术常用于Web开发。 4. **C#语言**:C#是微软开发的现代、类型安全的面向对象语言,主要用于.NET Framework。在...