1. ActionContext - com.opensymphony.xwork2.ActionContext 它本身就是一个Map,这个Map中存放是Action执行时的上下文,这些上下文也是一些Map组成的,它的大体结构可能就是Action(Map(session(Map(……)),application(Map(……)),locale(Map(……))……));
xwork框架的ActionContext是Action执行时的上下文,存放Action执行时需要用到的对象。在使用webwork时,其中放有Parameter、Session、ServletContext、Locale等信息。这样,webwork负责将Servlet相关数据转换为与ServletAPI无关的Map对象(即ActionContext),使得xwork的Action实现与web层、逻辑层与表现层的解耦。
ServletActionContext extends ActionContext
2. ServletActionContext - org.apache.struts2.ServletActionContext
提供直接与Servlet容器交互的途径。通过它,可以取得HttpServletRequest、HttpServletResponse 、ServletConfig、ServletContext、PageContext 对象。但是,使用ServletActionContext意味着Action与ServletAPI的紧密耦合。
3. ServletContext - javax.servlet.ServletContext可以通过取得:getRealPath(), getInitParameter(), getInitParameterNames(), getAttribute(), getAttributeNames()等等。可以理解为在web中管理参数,页面间数据传递等方面的数据。
ServletContext接口表示一个web应用的上下文。可以想象成一个web一个能用的共享数据区域,该区域保存整个web共享数据。当一个web应用启动的时候,就会创建该ServletContext接口的实现类。我们可以在根据需求,读写ServletContext这个web共享区的数据,那么如何获得ServletContext这个实例呢?下面提供了两种方法
方法1:可以通过ServletConfig接口的getServletContext()方法获得
方法2:通过GenericServlet抽象类的getServletContext()方法获得,不过这个方法其实也是调用了ServletConfig的getServletContext()方法
4. RequestDispatcher - javax.servlet. RequestDispatcher
RequestDispatcher是一个Web资源的包装器,可以用来把当前request传递到该资源,或者把新的资源包括到当前响应中。RequestDispatcher接口中定义了两个方法:include/forward
HttpServletResponse.sendRedirect()方法将响应定向到参数location指定的、新的URL。location可以是一个绝对的URL,如response.sendRedirect("http://java.sun.com")也可以使用相对的URL。如果location以“/”开头,则容器认为相对于当前Web应用的根,否则,容器将解析为相对于当前请求的URL。这种重定向的方法,将导致客户端浏览器的请求URL跳转。从浏览器中的地址栏中可以看到新的URL地址,作用类似于上面设置HTTP响应头信息的实现。
RequestDispatcher.forward()方法将当前的request和response重定向到该RequestDispacher指定的资源。这在实际项目中大量使用,因为完成一个业务操作往往需要跨越多个步骤,每一步骤完成相应的处理后,转向到下一个步骤。比如,通常业务处理在Servlet中处理,处理的结果转向到一个JSP页面进行显示。这样看起来类似于Servlet链的功能,但是还有一些区别。一个RequestDispatcher对象可以把请求发送到任意一个服务器资源,而不仅仅是另外一个Servlet。 include()方法将把Request Dispatcher资源的输出包含到当前输出中。
如果需要从servlet向下一页面(jsp、servlet……)传递request中的值时,使用页面转发RequestDispatcher,使用方法如下:
RequestDispatcher rd = this.getServletConfig().getServletContext().getRequestDispatcher("your URL");
d.forward(request.response);
5. ActionInvocation - com.opensymphony.xwork2.ActionInvocation 将Web页面中的输入元素封装为一个(请求)数据对象
ActionInvocation是Xwork中 Action 的调度的核心。 而对 Interceptor 的调度,也是有 ActionInvocation 负责。ActionInvocation 是一个接口,而DefaultActionInvocation 则是Webwork 对ActionInvocation的默认实现。
6. PageContext - javax.servlet.jsp.PageContext extends JspContext 对象提供存取所有在此网页中可被利用的隐含对象,并且可以管理它们的属性。 是隐含对象对应于javax.servlet.jsp.PageContext型态之对象它的主要功能在提供一个单一个接口,以管理各种的公开对象(像是HttpSession、ServletContext、ServletConfig、ServletRequest、ServletResponse等等),提供一个单一的API来管理属性作用范围等等。也可以是隐含对象都自动的被加入至pageContext中,您可以藉由它来取得与JSP相关的隐含对象对应之Servlet对象,像是getRequest()可以取得ServletRequest,getServletConfig()可以取得ServletConfig,getSession()可以取得HttpSession等等。
7. Jsp 中特殊字符的处理
单引号 ' 改为 \'
双引号 " 改为 \"
斜线 \ 改为 \\
起始标签 <% 改为 <%
结束标签 %> 改为 %\>
8. Jsp page 指令的使用
language ="scriptingLanguage" 主要指定JSP Container要用什么语言来编译JSP 网页。
JSP 2.0 规范中指出,目前只可以使用Java语言,不过未来不排除增加其他语言,如C、C++、Perl 等等。默认值为Java
extends = "className" 主要定义此JSP 网页产生的Servlet 是继承哪个父类
import = "importList" 主要定义此JSP 网页可以使用哪些Java API
session = "true | false" 决定此JSP 网页是否可以使用session 对象。默认值为true
buffer = "none | size inkb" 决定输出流 (output stream)是否有缓冲区。默认值为
8KB 的缓冲区
autoFlush = "true |false" 决定输出流的缓冲区是否要自动清除,缓冲区满了会产生异常 (Exception)。默认值为 true
isThreadSafe = "true |false 主要是告诉JSP Container,此JSP 网页能处理超过一个false" 以上的请求。默认值为 true,如果此值设为 false,SingleThreadModel 将会被使用。SingleThreadModel 在Servlet 2.4 中已经声明不赞成使用(deprecate)
info = "text" 主要表示此JSP 网页的相关信息
errorPage = "error_url" 表示如果发生异常错误时,网页会被重新指向那一个URL
isErrorPage = "true |false" 表示此JSP Page 是否为处理异常错误的网页
contentType = "ctinfo" 表示MIME 类型和JSP 网页的编码方式
pageEncoding = "ctinfo" 表示JSP 网页的编码方式
isELIgnored = "true |false" 表示是否在此JSP 网页中执行或忽略EL 表达式。如果为true 时,JSP Container将
9.EL 隐含对象
PageContext javax.servlet.ServletContext 表示此JSP 的PageContext
PageScope java.util.Map 取得Page范围的属性名称所对应的值
RequestScope java.util.Map 取得Request 范围的属性名称所对应的值
sessionScope java.util.Map 取得Session 范围的属性名称所对应的值
applicationScope java.util.Map 取得Application 范围的属性名称所对应的值
param java.util.Map 如同ServletRequest.getParameter(String name)。回传String 类型的值
xwork框架的ActionContext是Action执行时的上下文,存放Action执行时需要用到的对象。在使用webwork时,其中放有Parameter、Session、ServletContext、Locale等信息。这样,webwork负责将Servlet相关数据转换为与ServletAPI无关的Map对象(即ActionContext),使得xwork的Action实现与web层、逻辑层与表现层的解耦。
ServletActionContext extends ActionContext
2. ServletActionContext - org.apache.struts2.ServletActionContext
提供直接与Servlet容器交互的途径。通过它,可以取得HttpServletRequest、HttpServletResponse 、ServletConfig、ServletContext、PageContext 对象。但是,使用ServletActionContext意味着Action与ServletAPI的紧密耦合。
3. ServletContext - javax.servlet.ServletContext可以通过取得:getRealPath(), getInitParameter(), getInitParameterNames(), getAttribute(), getAttributeNames()等等。可以理解为在web中管理参数,页面间数据传递等方面的数据。
ServletContext接口表示一个web应用的上下文。可以想象成一个web一个能用的共享数据区域,该区域保存整个web共享数据。当一个web应用启动的时候,就会创建该ServletContext接口的实现类。我们可以在根据需求,读写ServletContext这个web共享区的数据,那么如何获得ServletContext这个实例呢?下面提供了两种方法
方法1:可以通过ServletConfig接口的getServletContext()方法获得
方法2:通过GenericServlet抽象类的getServletContext()方法获得,不过这个方法其实也是调用了ServletConfig的getServletContext()方法
4. RequestDispatcher - javax.servlet. RequestDispatcher
RequestDispatcher是一个Web资源的包装器,可以用来把当前request传递到该资源,或者把新的资源包括到当前响应中。RequestDispatcher接口中定义了两个方法:include/forward
HttpServletResponse.sendRedirect()方法将响应定向到参数location指定的、新的URL。location可以是一个绝对的URL,如response.sendRedirect("http://java.sun.com")也可以使用相对的URL。如果location以“/”开头,则容器认为相对于当前Web应用的根,否则,容器将解析为相对于当前请求的URL。这种重定向的方法,将导致客户端浏览器的请求URL跳转。从浏览器中的地址栏中可以看到新的URL地址,作用类似于上面设置HTTP响应头信息的实现。
RequestDispatcher.forward()方法将当前的request和response重定向到该RequestDispacher指定的资源。这在实际项目中大量使用,因为完成一个业务操作往往需要跨越多个步骤,每一步骤完成相应的处理后,转向到下一个步骤。比如,通常业务处理在Servlet中处理,处理的结果转向到一个JSP页面进行显示。这样看起来类似于Servlet链的功能,但是还有一些区别。一个RequestDispatcher对象可以把请求发送到任意一个服务器资源,而不仅仅是另外一个Servlet。 include()方法将把Request Dispatcher资源的输出包含到当前输出中。
如果需要从servlet向下一页面(jsp、servlet……)传递request中的值时,使用页面转发RequestDispatcher,使用方法如下:
RequestDispatcher rd = this.getServletConfig().getServletContext().getRequestDispatcher("your URL");
d.forward(request.response);
5. ActionInvocation - com.opensymphony.xwork2.ActionInvocation 将Web页面中的输入元素封装为一个(请求)数据对象
ActionInvocation是Xwork中 Action 的调度的核心。 而对 Interceptor 的调度,也是有 ActionInvocation 负责。ActionInvocation 是一个接口,而DefaultActionInvocation 则是Webwork 对ActionInvocation的默认实现。
6. PageContext - javax.servlet.jsp.PageContext extends JspContext 对象提供存取所有在此网页中可被利用的隐含对象,并且可以管理它们的属性。 是隐含对象对应于javax.servlet.jsp.PageContext型态之对象它的主要功能在提供一个单一个接口,以管理各种的公开对象(像是HttpSession、ServletContext、ServletConfig、ServletRequest、ServletResponse等等),提供一个单一的API来管理属性作用范围等等。也可以是隐含对象都自动的被加入至pageContext中,您可以藉由它来取得与JSP相关的隐含对象对应之Servlet对象,像是getRequest()可以取得ServletRequest,getServletConfig()可以取得ServletConfig,getSession()可以取得HttpSession等等。
7. Jsp 中特殊字符的处理
单引号 ' 改为 \'
双引号 " 改为 \"
斜线 \ 改为 \\
起始标签 <% 改为 <%
结束标签 %> 改为 %\>
8. Jsp page 指令的使用
language ="scriptingLanguage" 主要指定JSP Container要用什么语言来编译JSP 网页。
JSP 2.0 规范中指出,目前只可以使用Java语言,不过未来不排除增加其他语言,如C、C++、Perl 等等。默认值为Java
extends = "className" 主要定义此JSP 网页产生的Servlet 是继承哪个父类
import = "importList" 主要定义此JSP 网页可以使用哪些Java API
session = "true | false" 决定此JSP 网页是否可以使用session 对象。默认值为true
buffer = "none | size inkb" 决定输出流 (output stream)是否有缓冲区。默认值为
8KB 的缓冲区
autoFlush = "true |false" 决定输出流的缓冲区是否要自动清除,缓冲区满了会产生异常 (Exception)。默认值为 true
isThreadSafe = "true |false 主要是告诉JSP Container,此JSP 网页能处理超过一个false" 以上的请求。默认值为 true,如果此值设为 false,SingleThreadModel 将会被使用。SingleThreadModel 在Servlet 2.4 中已经声明不赞成使用(deprecate)
info = "text" 主要表示此JSP 网页的相关信息
errorPage = "error_url" 表示如果发生异常错误时,网页会被重新指向那一个URL
isErrorPage = "true |false" 表示此JSP Page 是否为处理异常错误的网页
contentType = "ctinfo" 表示MIME 类型和JSP 网页的编码方式
pageEncoding = "ctinfo" 表示JSP 网页的编码方式
isELIgnored = "true |false" 表示是否在此JSP 网页中执行或忽略EL 表达式。如果为true 时,JSP Container将
9.EL 隐含对象
PageContext javax.servlet.ServletContext 表示此JSP 的PageContext
PageScope java.util.Map 取得Page范围的属性名称所对应的值
RequestScope java.util.Map 取得Request 范围的属性名称所对应的值
sessionScope java.util.Map 取得Session 范围的属性名称所对应的值
applicationScope java.util.Map 取得Application 范围的属性名称所对应的值
param java.util.Map 如同ServletRequest.getParameter(String name)。回传String 类型的值