0.1概述 本用户指南为那些热衷于Web开发的人们和想用Java开发Web应用程序的人们而写。在开始阅读之前,你应该对以下这些核心技术的基础知识有所了解:
.HTTP,HTML和User Agent;
.HTTP请求响应周期;
.Java语言和应用程序框架;
.JavaBeans;
.属性文件和资源绑定;
.Java Servlet;
.JSP和JSP标签库;
.XML语言;
本章只对这些核心技术做扼要的介绍而不做详尽的描述。为了大家的方便,我们提供给大家一些可以进一步了解它们的有用链接。
如果你已熟悉Java语言本身,而不了解这些技术,我们建议你应好好看看这本指南The Java Web Services Tutorial。 这里可以下载到它的PDF版本。
如果你已经有开发其它平台的Web应用程序的经验,在这里你也可以找到你需要的资料。因为Struts用到的技术在其他的Java Web产品也可能要用到,这些背景知识对任何一个Java项目都是有用的。
如果你对Java语言还是不太了解,那么我们建议你看看另一本指南The Java Tutorial。The Java Tutorial和The Java Web Services Tutarial内容可能有重叠的部分,最好结合起来看。
如果你想了解如何开发一般的Java应用程序,那么你可以去这里看看http://developer.java.sun.com/developer/onlineTraining/new2java/divelog/part1/toc.jsp' TARGET=_blank>New to Java ,可能会给你很大帮助。
0.2 HTTP,HTML和User Agents 众所周知,互联网是建立在HTTP协议和HTML语言基础之上的。User Agent就像Web浏览器一样使用HTTP协议请求HTML文档,然后浏览器负责把其格式化并显示给用户。传输使用的HTTP协议,而HTML是Web和Web应用程序使用的通用语言。
在进行Web应用程序开发时,一些Java程序员可能自己编写HTML语言,而有的则会交给专门的页面设计人员来编写。
关于HTTP,HTML和User Agents更多知识可参考以下资源:
.Getting started with HTMLDave Raggett著;
.在Java Web Services Tutorial中的HTTP Overview ;
.HTTP/1.1规范;
.HTTP Basic and Digest Authentication 规范;
.State Management Mechanism规范(Cookies);
0.3 HTTP请求响应周期 对于Web开发人员来说,对HTTP的最关心的就是HTTP的请求响应周期,使用HTTP提交一个请求,然后HTTP服务器(如Web服务器)返回一个响应。当我们进行Web开发设计时,我们设计成一个HTTP请求对应返回一个HTTP响应。Struts框架就是对这一周期进行抽象,而对我们来说更重要的是应该知道这一幕后发生的事情。
如果你对HTTP请求响应周期并不熟悉,那么我们强烈推荐你去读一读Java Web Services Tutorial中的HTTP Overviewhttp://java.sun.com/webservices/docs/1.0/tutorial/doc/HTTP.html#63796
0.4 Java语言和应用程序框架 Struts框架是用时下最流行的万能编程语言(译者注:这么形容Java语言我觉得一点也
不为过)Java写成的。Java是面向对象的编程语言,Struts正是利用了它的面向对象这一技术。另外还有,Java自身对线程的良好支持,可以在同一时刻执行多项任务。很好的理解Java语言,面向对象编程和线程,对我们掌握Struts和使用本用户指南大有裨益。
学习Java语言和线程可以参考以下资料:
.The Java Tutorial之 Learning the Java Language ;
.The Java Language Tutorial之Learning the Threads之Doing Two or More Tasks At Once ;
即使你已经使用过Java和面向对象的编程,创建和使用应用程序框架对你编程也是大有帮助的。有关应用程序框架的更多知识,可以参考下面两本白皮书:
. Designing Reusable Classes Ralph E. Johnson 和Brian Foote著;
.Object-Oriented Application Frameworks Mohamed Fayad和Douglas C. Schmidt著;如果你正在找一个服务器端框架那么这两页可能对你有些帮助:1和2
0.5 JavaBeans 正像许多Java应用程序一样,大多Struts对象也被设计为JavaBean。使用JavaBean设计模式使Struts类更易被Java开发人员和Java部署工具使用。
JavaBan最初只是为可视化元素编程而创建的,现在这种对象设计模式已经被广泛地应用到更多可重用组件的基础设计中,如Struts框架。
关于JavaBean更多知识,可参考:
.java.sun.com中的The JavaBeans Component Architecture document.tion和JavaBeans 1.01 Specification;
.The Java Tutorial中的 The JavaBean Trail ;
.The Java Web Services Tutorial中的JavaBeans Components in JSP Pages ;
0.5.1 反射和内省机制
反射就是确定对象的哪个成员变量或方法是可用的一种处理机制。内省是JavaBean API使用的一种特殊形式的反射。使用内省我们可以知道JavaBean的哪些方法是可以被其他对象访问的。
Struts框架使用内省机制把HTTP参数转换为JavaBean属性和使用JavaBean属性组装HTML表单域。这项技术使在JavaBean和HTML表单域之间进行“双向访问”属性更加简单。
关于反射和内省更多,请参考:
. The Reflection Trail ;
.Chapter 8 of the JavaBeans API Specification ;
0.5.2 映射(Maps)
JavaBean通过使用属性来存储数据而在其他方法中操作这些数据。JavaBean是一个便捷而有强大的对象,但它不是编程人员用来存储数据的对象唯一选择。另外一个流行的对象就是映射(Map)[java.util.map]。一个映射就是一个简单的名称值对集合。映射常在“幕后”作为存储动态数据的一种便捷方法。
0.5.3 动态Bean(DynaBeans)
动态Bean集JavaBean的可扩展性和Map的灵活性于一身。我们知道即使要定义一个简单的JavaBean,也要新建一个类,定义一个属性变量,还有编写每个属性对应的两个访问方法(setXXX和getXXX)。而动态Bean则可以通过XML配置文件来定义属性,动态Bean的虚拟属性并不能像普通的Java方法一样来调用,而是要通过组件使用反射(Reflection)和内省(introspection)机制来进行访问。
在Struts框架中,你可以使用动态Bean来描述一个HTML表单。这一个策略避免了我们要为一些简单的表单域创建正式JavaBean子类。
查看本文来源
0.6 属性(Properties)文件和资源绑定(Resourse Bundles) 很多Java应用程序(包括Web应用程序在内)经常通过 属性文件进行一些配置。属性文件是Struts框架用于给应用程序提供消息资源资源绑定的基础所在。
关于属性文件更多,请参考:
.The Java Tutorial中的Using Properties to Manage Program Attributes
Java资源绑定是根据用户 区域(Locale)通过一个或多个属性文件为用户提供国际化支持。Struts从一建立开始就对应用程序的本地化有很好的支持。
关于本地化和资源绑定的更多,请参考:
.The Java Tutorial 中的About the ResourceBundle Class
0.7 Java Servlet 由于Java是一种面向对象的编程语言,所以Java Servlet平台就把HTTP强制造型(或构造)为面向对象的形式。这一策略使得Java开发人员省下更多的时间去处理自己的应用程序的功能上,而不是放在HTTP的机制处理上。
HTTP提供了一套扩展服务器的基本机制,即公共网关接口(Common Gateway Interface,CGI)。服务器可以传递一个请求给CGI程序,然后CGI程序返回一个响应。同样,一个Java服务器传递一个请求给一个Servlet容器,容器可以对请求作一些处理,也可以把这个请求直接返还给HTTP服务器,容器检查它的Servlet列表来决定是否要对这个请求进行处理,如果请求注册了一个Servlert,那么容器就把这请求转交给这个Servlet。
当一个请求进入时,容器检查该请求是否注册了Servlet,如果找到一个匹配的Servlet,容器就把这个请求传给这个Servlet,如果没有,请求就被返还给HTTP服务器。
容器的职责就是管理Servlet的生命周期,创建Servlet,调用Servlet,最后释放Servlet。
一般情况下一个Servlet是[javax.servlet.http.HttpServlet]的一个子类,一个Servlet必须实现容器需要调用的四个方法:
.public void init(ServletConfig config):当Servlet实例第一次被创建时和执行所有请求之前Servlet容器调用这个方法;
.public void doGet(HttpServletRequest request,HttpServletResponse response)此方法用于处理一个使用HTTP GET 协议的请求,并生成一个相应的动态响应;
.public void doPost(HttpServletRequest request HttpServletResponse response)此方法用于处理一个使用HTTP POST协议的请求,并生成一个相应的动态响应;
.public void destroy() 当Servlet实例中止服务时容器调用这个方法,诸如当Web应用程序正在被undeploy或当整个容器被shut down时;
Struts框架已为我们的应用程序提供一个现成Servlet[org.apache.struts.action.ActionServlet]。作为一个Struts应用程序开发人员,在使用Struts框架的ActionServlet实例的同时,了解Servlet的基础知识和明白它在Web应用程序所扮演的角色也是相当重要。
关于Servlet的更多知识,请参考:
.java.sun.com中的The Java Servlet Technology;
.java.sun.com中的The Servlet 2.2 and 2.3 Specifications;
.The Java Web Service Tutorial的Java Servlet Technology;
.The Java Web Service Tutorial的Web Applications;
0.7.1 Servlet和Thread
为了提高性能,容器支持多线程Servlet。一个具体的Servlet只能创建一个实例,通过同一个对象为注册了这个Servlet的每个请求服务。这一个策略可以使容器充分利用系统资源,与此同时也就必须考虑Servlet的doGet和doPost方法编码的线程安全问题。
关于Servlet与线程安全的更多资料,请参考:
.The Java Web Service Tutorial中的Controlling Concurrent Access to Shared Resourceshttp://java.sun.com/webservices/docs/1.0/tutorial/doc/Servlets5.html#64386;
0.7.2 Servlet上下文(Context)
ServletContext接口[javax.servlet.ServletContext]提供正在运行的Servlet所处的Web应用程序的上下文(或环境)的视图。Servlet可以通过getServletConfig()方法访问,而JSP页面可以通过隐含变量application变量获得。Servlet上下文提供的几个API在创建Struts Web应用程序时是相当有用的。
.访问Web应用程序资源:Servlet可以通过getResource()和getResourceAsStream()方法访问Web应用程序内的静态资源文件;
.Servlet上下文属性:上下文可以用来存储Java对象,通过字符串值的key来识别对象,这些属性对整个Web应用程序都是全局的,Servlet可以通过getAttribute(),getAttributeNames(),removeAtrribute()和setAttribute()方法进行访问。对JSP页面来说,Servlet上下文属性相当于“应用程序作用域Bean”;
关于Servlet上下文的更多信息,请参考:
.The Java Web Services Tutorial中的Accessing the Web Context http://java.sun.com/webservices/docs/1.0/tutorial/doc/Servlets10.html#64724;
0.7.3 Servlet请求
每个Servlet处理的请求用一个Java接口代表,一般是HttpServletRequest接口 [javax.servlet.http.HttpServletRequest]。这个请求接口提供了一套访问包含在底层HTTP请求内的所有信息的面向对象机制,包含:
.Cookie:通过getCookie()方法获得包含在请求中的有效Cookie集;
.头:可以通过名称访问包含在请求中的HTTP头。你可以枚举包含的所有的HTTP头的名称;
.参数:请求参数,可以通过名称访问包含在URL的查询字符串中(doGet)或包含在请求内容中(doPost)的请求参数;
.请求特征:输入HTTP请求的一些其他特征,诸如GET或POST方法使用的协议规格("http" 或"https"),等等;
.请求URI信息:通过getRequestURI()方法可以获得原始的请求URL。另外,Servlet容器把请求URL解析为一些可以单独访问的组成部分(contextPath、 servletPath和 pathInfo);
.用户信息:如果你使用了用户管理的安全,那么你就可以查找一个已认证用户名,获得一个代表当前用户的Principal对象,还有当前用户是否被授权为一个特定角色;
另外,Servlet请求还支持请求属性(在JSP中,就是请求作用域Bean),类似于前面讲到的Servlet上下文属性。请求属性常用于业务逻辑层和视图层之间状态信息通信,业务逻辑层产生这些状态信息,视图层使用这些信息产生相应的响应。
Servlet容器会确保一个具体的请求被一个单独线程的Servlet处理,所以你就不必担心在访问Servlet请求的属性时有关线程安全的问题。
关于Servlet请求的更多,请参考:
.The Java Web Tutorial中的Getting Information from Requestshttp://java.sun.com/webservices/docs/1.0/tutorial/doc/Servlets7.html#64433;
0.7.4 Servlet响应
一个Servlet的主要目的就是处理一个输入的Servlet请求[javax.servlet.http.HttpServletRequest],并生成对应的响应。生成响应的过程是通过调用Servlet响应接口[javax.servlet.http.HttpServletResponse]相应的方法来完成的,可用的方法如下:
.设置HTTP头:你可以设置包含在响应中的HTTP头信息。最重要的HTTP头信息就是Content-Type,它告诉你的客户端包含在响应体中信息是哪种类型的,一般情况下,设为text/html类型就是HTML页面,或设为text/xml类型就是XML文档;
.设置Cookies:你可以向当前的响应中增加Cookie;
.发送错误响应:你可以使用sendErro()发送一个HTTP错误状态信息(代替一般的页面内容);
.重定向到其他资源:你可以使用sendRedirect()方法重定向客户端到你指定的其他URL资源上去;
使用Servlet响应API的一个重要原则就是调用维护头信息和Cookies所有方法都必须在缓存的全部响应内容第一次被更新给客户端之前完成。原因是因为这些信息都是作为HTTP响应最开始部分被传输的,因此试图在头信息已被送出之后再添加头信息,必然是徒劳的。
使用Model 2模式的应用程序的表现层,你可能不直接使用Servlet 响应APIs来生成响应。一般是使用JSP页面来完成,在Servlet容器中JSP页面将被JSP编译器转换为Servlet,由这个JSP Servlet生成响应,其中可能包含一些JSP标签生成的动态信息。
其他的表现系统,诸如Struts工具Velocity框架,可能把生成响应的任务代理给一个专门的Servlet来完成,但是原理是相同的。你创建一个模板,然后动态的响应由模板动态生成。
关于Servlet响应的更多,请参考:
.The Java Web Tutorial中的Constructing Responseshttp://java.sun.com/webservices/docs/1.0/tutorial/doc/Servlets7.html#64531;
0.7.5 过滤器(Filtering)
如果你使用2.3版或更新规范的Servlet容器(如Tomcat4.x),你可以使用新的过滤器APIs[javax.servlet.Filter]组合一些组件来处理请求和生成响应。过滤器其实是一个过滤器链的集合,每个过滤器都可以处理请求和生成响应,然后把处理权交给下一个过滤器,最后调用Servlet。
Struts 1.x系列(1.0,1.1版本等)仅支持2.2版本或更早的Servlet规范的Servlet容器,所以Struts自身并没有使用过滤器。下一代的Struts(2.x系列)是基于Servlet2.3或更新规范的。Struts 2.x版可能会使用到过滤器。
关于过滤器更多,请参考:
.Filtering Requests and Responseshttp://java.sun.com/webservices/docs/1.0/tutorial/doc/Servlets8.html#64572;
0.7.6 会话(Session
查看本文来源