- 浏览: 135443 次
- 性别:
- 来自: 安徽
文章分类
最新评论
-
7_iroy:
竟然没人来评论??不错的学习源码啊,不过LZ没有给出表格,这有 ...
触发器-----------数据库(SQL) -
fatedgar:
best_yuan 写道好像运行不了,缺少spring包
没啊 ...
根据RTF模版输出doc文件(草稿) -
syfye:
请问Linux下中文乱码,遇到过吗?如何解决?
根据RTF模版输出doc文件(草稿) -
best_yuan:
好像运行不了,缺少spring包
根据RTF模版输出doc文件(草稿)
在Struts中,擔任 MVC / Model 2 中Controller角色的是ActionServlet,所有的請求都必須先通過它,然而在Struts 1.1後,有關於請求的處理大部份已交由RequestProcessor,當ActionServlet收到GET或POST的請求,其doGet() 或doPost()會呼叫process()方法來處理請求:
RequestUtils是個工具類,ActionServlet呼叫其selectApplication()方法,藉由 request.getServletPath()來取得請求路徑以選擇應用程式模塊來處理請求,之後從ApplicationConfig物件取得 RequestProcessor物件,將使用者的請求委託它來進行處理。
通常是將ActionServlet當作黑盒子,您只要使用它,然而您也可以繼承ActionServlet來定義自己的控制器,但由於在Struts 1.1中大部份的請求已經委託RequestProcessor來處理,繼承ActionServlet來定義自己的控制器請求處理意義已經不大,通常的目的是重新定義ActionServlet的init()方法,增加自己的初始化動作:
預設的RequestProcessor物件是org.apache.struts.action.RequestProcessor,您可以藉由觀看 process()方法的原始碼來瞭解它作了哪些事情:
您可以繼承RequestProcessor,並改寫其中的processXXXXX()方法來自定義請求的處理方式,如果您要使用自己的 RequestProcessor,要在struts-config.xml中使用<controller>標籤來定義,例如:
struts-config.xml
在Struts 1.1後,新增了<controller>標籤,它可以用於指定ActionServlet的一些參數,在Struts 1.1之前,這些參數是在<init-params>中加以指定,使用<controller>標籤,應用程式中不同的模組也可以指定各自的參數給ActionServlet。
Struts框架只允许应用中存在一个ActionServlet类,但是可以存在多个客户化的RequestProcessor类,每个子应用模块都可以有单独的RequestProcessor类,
ActionServlet主要负责初始化,以及介绍请求并找到合适的RequestRrocessor,之后真正干活的是RequestProecssor和Action.
上回说到ActionServlet的process方法最终会调用RequestProcessor类的process方法.下面介绍这个方法.
1) 调用processMultipart()方法
如果HTTP请求方式为post,并且contentType为”multipart/form-data”开头,标准的HttpServletRequest对象将被重新包装,以方便处理”multipart”类型的HTTP请求.如果请求方式为get,或正congtentType属性不是”mulitipart”,就直接返回原始的HttpServletRequest对象.
2) 调用processPath()方法
获得请求的URI的路径,这一信息可用于选择合适的Struts Action组件.
3) 调用processLocale方法
当ControllerConfig对象的locale属性为true,将读取用户请求中包含的Locale信息,然后把Locale实例保存在session范围内.
4) 调用processContendType(contentType)方法
读取ControllerConfig对象的conttentType属性,然后调用response.setContentType(contentType)方法,设置响应结果的文档类型和字符编码.
processContent()方法如下
5) 调用processNoCache()方法
读取ControllerConfig对象的nocache属性,如果nocache属性为true,在响应结果中将加入特定的头参数:Pragma,Cache-Control和Expires,
防止页面被存储在客户的浏览器的缓存中,processNoCache方法的代码如下:
6)调用processPreprocess()方法
该方法不执行任何操作.直接返回true.子类可以覆盖这个方法.
执行客户化的预处理请求操作.
7)调用processMapping()方法
寻找和用户请求的URI匹配的ActionMapping,如果不存在这样的ActionMapping,则向用户返回恰当的错误信息.
8)调用processRoles()方法
先判断是否为Action配置了安全角色,如果配置了安全角色,就调用isUserInRole()方法判断当前用户是否具备必需的角色,如果不具备,就结束请求处理流程.,向用户返回恰当的错误消息.
9)调用processActionForm()方法
先判断是否为ActionMapping配置了ActionForm,如果配置了ActionForm,就先从ActionForm的存在范围内(request或session)寻找改ActionForm实例,如果不存在,就创建一个实例,接下来把它保存在合适的范围内,保存时使用的属性key为ActionMapping的name属性。
10)调用processPopulate()方法
如果为ActionMapping配置了ActionForm,就先调用ActionForm的reset()方法,再把请求中的表单数据组装到ActionForm中。
11)调用processValidate()方法
如果为ActionMapping配置了ActionForm,并且ActionMapping的validate属性为true,就调用ActionForm的validate()方法,如果validate方法返回的ActionErrors对象中包含ActionMessage对象,说明表单验证失败。就把ActionErrors对象放在request范围内,再把请求转发到ActionMapping的input属性指定的Web组件。如果ActionForm的validate方法执行表单验证成功,就继续执行下面的处理流程。
12)调用processForward()方法
判断是否在ActionMapping中配置了forward属性。如果配置了这个属性,就调用RequestDispatcher的forward方法,请求处理流程结束。否则进行下一步。
13)调用processInclude()方法
判断是否在ActionMapping中配置了include属性。如果配置了这个属性,就调用RequestDispatcher的include方法,请求处理流程结束。否则进行下一步。
14)调用processActionCreate()方法
先判断是否在Action缓存中存在这个Action实例,如果没有就新建一个Action实例,把它放在Action缓存中。可以看出Action也是只有一个实例在运行的。
15)调用processActionPerform
该方法调用Action实例的execute方法,该方法位于try/catch中,以及捕获异常。processActionPerform()方放代码如下。
16)调用processActionForward方法
把你的Action的excute方法返回的ActionFoward对象作为参数传给它,processActionForward对象包的请求转发信息来执行请求转发或重定向。
在RequestProcessor类的process方法中,会访问ControllerConfig、ActionMappig和ActionForward实力的属性,ControllerConfig类和struts配置文件的<controlle>r元素对应,ActionMapping类和<action>元素对应,ActionForward和<forward>元素对应,process方法通过访问这三个类实例的属性来获得相关的配置信息。
写了这么多,RequestProcessor干得事够多的吧。
如果想修改RequestProcessor的一些默认功能,改易覆盖RequestProcessor基类中的相关方法.
在struts配置文件中,<controller>元素的processorClass属性用于配置你自己的RequestProcessor类
protected void process(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { RequestUtils.selectApplication(request, getServletContext()); getApplicationConfig( request).getProcessor().process(request, response); }
RequestUtils是個工具類,ActionServlet呼叫其selectApplication()方法,藉由 request.getServletPath()來取得請求路徑以選擇應用程式模塊來處理請求,之後從ApplicationConfig物件取得 RequestProcessor物件,將使用者的請求委託它來進行處理。
通常是將ActionServlet當作黑盒子,您只要使用它,然而您也可以繼承ActionServlet來定義自己的控制器,但由於在Struts 1.1中大部份的請求已經委託RequestProcessor來處理,繼承ActionServlet來定義自己的控制器請求處理意義已經不大,通常的目的是重新定義ActionServlet的init()方法,增加自己的初始化動作:
public class CustomActionServlet extends ActionServlet { public void init() throws ServletException { super.init(); // 增加自己的初始化動作 .... } }
預設的RequestProcessor物件是org.apache.struts.action.RequestProcessor,您可以藉由觀看 process()方法的原始碼來瞭解它作了哪些事情:
public void process(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { // 處理 contentType 為 multipart/form-data 的 POST 請求 request = processMultipart(request); // 取得 URI 路徑 String path = processPath(request, response); if(path == null) return; ..... // 確定客戶端的位置 // 是否要將一個Locale物件儲存在 session 中 // 配合 <controller> 的 locale 屬性使用 processLocale(request, response); // 確定contentType,預設是 text/html processContent(request, response); // 判斷<controller>屬性nocache是否被設定 // 若是,在 response 中加入防止快取的header processNoCache(request, response); // 前置處理,預設返回 true //子類可以重新定義它以決定要不要繼續處理 if(!processPreProcess(request, response)) { return; } // 從URI路徑確定ActionMapping ActionMapping mapping = processMapping(request, response, path); if(mapping == null) { return; } .... // 處理ActionForm // 如果沒有就新增一個,之後一直使用它 ActionForm form = processActionForm(request, response, mapping); // 將表單的欄位值填入ActionForm processPopulate(request, response, form, mapping); // 判斷是否執行ActionForm的validate()方法 if(!processValidate(request, response, form, mapping)) { return; } // 判斷 <action> 標籤的 forward 或 include 標籤 // 是不是被設定,這兩個標籤在設定一個路徑 // 其與 type 屬性是互斥的,當設定其中一個屬性時 // 調用 RequestDispatcher 的 forward() 或 include() // 其作用與設定ForwardAction或IncludeAction相同 // 直接繞送而不再使用Action物件進行接下來的處理 if(!processForward(request, response, mapping)) { return; } if(processInclude(request, response, mapping)) { return; } // 處理Action,如果沒有就生成一個,之後一直使用它 Action action = processActionCreate(request, response, mapping); if(action == null) { return; } // 呼叫Action的execute()或perform()方法 // 並返回ActionForward ActionForward forward = processActionPerform(request, response, action, for, mapping); // 處理ActionForward processActionForward(request, response, forward); }
您可以繼承RequestProcessor,並改寫其中的processXXXXX()方法來自定義請求的處理方式,如果您要使用自己的 RequestProcessor,要在struts-config.xml中使用<controller>標籤來定義,例如:
struts-config.xml
... <controller contentType="text/html;charset=Big5" locale="true" nocache="true" processorClass="caterpillar.CustomRequestProcessor"/> ...
在Struts 1.1後,新增了<controller>標籤,它可以用於指定ActionServlet的一些參數,在Struts 1.1之前,這些參數是在<init-params>中加以指定,使用<controller>標籤,應用程式中不同的模組也可以指定各自的參數給ActionServlet。
Struts框架只允许应用中存在一个ActionServlet类,但是可以存在多个客户化的RequestProcessor类,每个子应用模块都可以有单独的RequestProcessor类,
ActionServlet主要负责初始化,以及介绍请求并找到合适的RequestRrocessor,之后真正干活的是RequestProecssor和Action.
上回说到ActionServlet的process方法最终会调用RequestProcessor类的process方法.下面介绍这个方法.
一.RequestProcessor的process方法
public void process(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { // Wrap multipart requests with a special wrapper request = processMultipart(request); // Identify the path component we will use to select a mapping String path = processPath(request, response); if (path == null) { return; } if (log.isDebugEnabled()) { log.debug("Processing a '" + request.getMethod() + "' for path '" + path + "'"); } // Select a Locale for the current user if requested processLocale(request, response); // Set the content type and no-caching headers if requested processContent(request, response); processNoCache(request, response); // General purpose preprocessing hook if (!processPreprocess(request, response)) { return; } this.processCachedMessages(request, response); // Identify the mapping for this request ActionMapping mapping = processMapping(request, response, path); if (mapping == null) { return; } // Check for any role required to perform this action if (!processRoles(request, response, mapping)) { return; } // Process any ActionForm bean related to this request ActionForm form = processActionForm(request, response, mapping); processPopulate(request, response, form, mapping); // Validate any fields of the ActionForm bean, if applicable try { if (!processValidate(request, response, form, mapping)) { return; } } catch (InvalidCancelException e) { ActionForward forward = processException(request, response, e, form, mapping); processForwardConfig(request, response, forward); return; } catch (IOException e) { throw e; } catch (ServletException e) { throw e; } // Process a forward or include specified by this mapping if (!processForward(request, response, mapping)) { return; } if (!processInclude(request, response, mapping)) { return; } // Create or acquire the Action instance to process this request Action action = processActionCreate(request, response, mapping); if (action == null) { return; } // Call the Action instance itself ActionForward forward = processActionPerform(request, response, action, form, mapping); // Process the returned ActionForward instance processForwardConfig(request, response, forward); }
1) 调用processMultipart()方法
如果HTTP请求方式为post,并且contentType为”multipart/form-data”开头,标准的HttpServletRequest对象将被重新包装,以方便处理”multipart”类型的HTTP请求.如果请求方式为get,或正congtentType属性不是”mulitipart”,就直接返回原始的HttpServletRequest对象.
2) 调用processPath()方法
获得请求的URI的路径,这一信息可用于选择合适的Struts Action组件.
3) 调用processLocale方法
当ControllerConfig对象的locale属性为true,将读取用户请求中包含的Locale信息,然后把Locale实例保存在session范围内.
4) 调用processContendType(contentType)方法
读取ControllerConfig对象的conttentType属性,然后调用response.setContentType(contentType)方法,设置响应结果的文档类型和字符编码.
processContent()方法如下
protected void processContent(HttpServletRequest request, HttpServletResponse response) { String contentType = moduleConfig.getControllerConfig().getContentType(); if (contentType != null) { response.setContentType(contentType); } }
5) 调用processNoCache()方法
读取ControllerConfig对象的nocache属性,如果nocache属性为true,在响应结果中将加入特定的头参数:Pragma,Cache-Control和Expires,
防止页面被存储在客户的浏览器的缓存中,processNoCache方法的代码如下:
protected void processNoCache(HttpServletRequest request, HttpServletResponse response) { if (moduleConfig.getControllerConfig().getNocache()) { response.setHeader("Pragma", "No-cache"); response.setHeader("Cache-Control", "no-cache,no-store,max-age=0"); response.setDateHeader("Expires", 1); } }
6)调用processPreprocess()方法
该方法不执行任何操作.直接返回true.子类可以覆盖这个方法.
执行客户化的预处理请求操作.
7)调用processMapping()方法
寻找和用户请求的URI匹配的ActionMapping,如果不存在这样的ActionMapping,则向用户返回恰当的错误信息.
8)调用processRoles()方法
先判断是否为Action配置了安全角色,如果配置了安全角色,就调用isUserInRole()方法判断当前用户是否具备必需的角色,如果不具备,就结束请求处理流程.,向用户返回恰当的错误消息.
9)调用processActionForm()方法
先判断是否为ActionMapping配置了ActionForm,如果配置了ActionForm,就先从ActionForm的存在范围内(request或session)寻找改ActionForm实例,如果不存在,就创建一个实例,接下来把它保存在合适的范围内,保存时使用的属性key为ActionMapping的name属性。
10)调用processPopulate()方法
如果为ActionMapping配置了ActionForm,就先调用ActionForm的reset()方法,再把请求中的表单数据组装到ActionForm中。
11)调用processValidate()方法
如果为ActionMapping配置了ActionForm,并且ActionMapping的validate属性为true,就调用ActionForm的validate()方法,如果validate方法返回的ActionErrors对象中包含ActionMessage对象,说明表单验证失败。就把ActionErrors对象放在request范围内,再把请求转发到ActionMapping的input属性指定的Web组件。如果ActionForm的validate方法执行表单验证成功,就继续执行下面的处理流程。
12)调用processForward()方法
判断是否在ActionMapping中配置了forward属性。如果配置了这个属性,就调用RequestDispatcher的forward方法,请求处理流程结束。否则进行下一步。
13)调用processInclude()方法
判断是否在ActionMapping中配置了include属性。如果配置了这个属性,就调用RequestDispatcher的include方法,请求处理流程结束。否则进行下一步。
14)调用processActionCreate()方法
先判断是否在Action缓存中存在这个Action实例,如果没有就新建一个Action实例,把它放在Action缓存中。可以看出Action也是只有一个实例在运行的。
15)调用processActionPerform
该方法调用Action实例的execute方法,该方法位于try/catch中,以及捕获异常。processActionPerform()方放代码如下。
protected ActionForward processActionPerform(HttpServletRequest request, HttpServletResponse response, Action action, ActionForm form, ActionMapping mapping) throws IOException, ServletException { try { return (action.execute(mapping, form, request, response)); } catch (Exception e) { return (processException(request, response, e, form, mapping)); }
16)调用processActionForward方法
把你的Action的excute方法返回的ActionFoward对象作为参数传给它,processActionForward对象包的请求转发信息来执行请求转发或重定向。
在RequestProcessor类的process方法中,会访问ControllerConfig、ActionMappig和ActionForward实力的属性,ControllerConfig类和struts配置文件的<controlle>r元素对应,ActionMapping类和<action>元素对应,ActionForward和<forward>元素对应,process方法通过访问这三个类实例的属性来获得相关的配置信息。
写了这么多,RequestProcessor干得事够多的吧。
二、扩展RequestProcessor类
如果想修改RequestProcessor的一些默认功能,改易覆盖RequestProcessor基类中的相关方法.
Public class CustomRequestProcessor extends RequestProcessor{ protected void processPreprocess (HttpServletRequest request, HttpServletResponse response) { …………………. } }
在struts配置文件中,<controller>元素的processorClass属性用于配置你自己的RequestProcessor类
</controller contentType=“text/html:charset=”GB2312” locale=”true” nocache=”true” processorCalss=”com.test.CustomRequestProcessor”/>
发表评论
-
领先的 Web 技术教程
2012-02-06 17:25 1094领先的 Web 技术教程 - 全部免费 在w3school,你 ... -
JQuery实例(草稿)
2012-02-06 13:57 1179首先要有JQuery.js文件,可在官网上下 其次要引入js文 ... -
写出三种创建类的实例的方法
2011-12-21 20:59 924例如Test类。他在包:com.niit.action下 1、 ... -
用JQuery来写Ajax
2011-12-08 18:10 996下面是用Javascript来写的ajax代码 <scr ... -
用ajax来读xml(servlet生成的)用到JQuery技术
2011-12-08 17:07 1222准备: 下载Jquery.js文件、dom4j.jar包 新建 ... -
JQuery强大的选择器
2011-12-08 11:46 844主要可分为:基本选择器,层次选择器,过滤选择器,表单选择器 基 ... -
10种排序算法总结
2011-12-05 20:28 1019排序算法有很多,所以在特定情景中使用哪一种算法很重要。 ... -
Javascript中的window对象的方法和属性
2011-12-03 17:46 680JavaScript-window对象的方法和属性 熟练win ... -
fckeditor文本编辑器
2011-12-03 14:03 926用的是fckeditor 下载地址:http://ckedit ... -
AJAX笔记1
2011-12-02 23:04 1033AJAX(Asynchronous Javascript An ... -
JQuery笔记1
2011-12-02 22:43 9581.首先去下个JQuery.js文 ...
相关推荐
3. **代理逻辑**:在代理RequestProcessor中,我们可以添加一些预处理或后处理的逻辑,例如在请求处理前,利用Spring的AOP能力,自动为Action注入所需的依赖;在请求处理后,可以做一些统一的清理工作或异常处理。 ...
这里我们将详细探讨如何解决 Struts 中的中文乱码问题。 一、在 Action 类中的解决方法: 当在 Action 类中遇到中文乱码问题时,可以使用以下代码进行转换。创建一个静态工具类,如 `Chinese`,并定义一个 `...
`RequestProcessor`是Struts框架中的核心组件,它负责处理ActionServlet接收到的所有请求,并将请求分解为多个任务。通过自定义`RequestProcessor`,我们可以在请求处理的早期阶段就解决编码问题,使得所有后续操作...
- **自定义 RequestProcessor 类:**继承 Struts 的 RequestProcessor 类,并重写 `processPreprocess` 方法,在此方法中设置请求的字符编码。 ```java package servlets; import java.io....
2. **使用DelegatingRequestProcessor替换RequestProcessor**:在`struts-config.xml`中,将Struts的RequestProcessor替换为Spring的`DelegatingRequestProcessor`,并在Spring配置文件中定义与Struts `...
4. **拦截器**:虽然Struts1没有正式的拦截器概念,但通过RequestProcessor可以实现类似的功能。 5. **标签库**:Struts1提供了丰富的自定义标签库,如logic、bean、html等,简化了JSP页面的编写。 **Struts2详解:...
API文档是开发者理解并熟练运用任何框架的基础,Struts1.x中文API文档详细解释了框架中的各个类、接口、方法以及常量等,使得国内开发者无需英文基础也能轻松掌握Struts的核心功能。通过查阅这份文档,你可以了解到...
在Java Web开发中,DispatcherAction和RequestProcessor是两种常见的控制器组件,它们在处理HTTP请求、组织业务逻辑和呈现视图方面扮演着重要角色。这里我们将深入探讨这两种控制器类的工作原理、用途以及如何进行...
10. **RequestProcessor**:RequestProcessor是Struts1处理请求的起点,它负责解析请求,初始化ActionForm,调用Action,以及处理其他请求相关的任务。 "readme2.txt" 和 "readme.txt" 文件通常包含关于压缩包的...
3. **配置Struts**:在`struts-config.xml`文件中,将`processorClass`属性设置为自定义RequestProcessor的全限定类名,如下所示: ```xml 此处填写MyProcessor类的全路径"/> ``` 方法二: 1. **实现Filter接口*...
1. **基础概念**:Struts的核心组件包括Action、ActionForm、ActionMapping、RequestProcessor等。手册会解释这些组件的作用和相互关系,以及它们如何协同工作以处理HTTP请求。 2. **配置文件**:Struts的配置文件...
5. **RequestProcessor**:处理请求的入口,它是Struts生命周期的第一步,负责初始化和调度ActionServlet。 6. **ActionForward**:表示请求转发的对象,用于定义请求处理后转向的页面或资源。 7. **Tiles**:...
Struts1是一个经典的Java Web开发框架,由Apache软件基金会维护,它主要负责处理MVC(Model-View-Controller)架构中的Controller部分。Struts1 API是开发者在使用该框架时的重要参考文档,提供了详细的类、接口和...
//第一种方式:使用 Spring 的 ActionSupport 类整合 Structs ...//第二种方式:使用 Spring 的 DelegatingRequestProcessor 覆盖 Struts 的 RequestProcessor //第三种方式:将 Struts Action 管理委托给 Spring 框架
<controller processorClass="org.apache.struts.action.RequestProcessor"> ``` 或者在ActionForm的子类中覆盖`getServletEncoding()`方法返回"UTF-8"。 3. **修改JSP页面**:确保每个JSP页面顶部有正确的...
Struts框架的核心组件包括Action、ActionForm、ActionForward、ActionMapping和RequestProcessor。Action是处理业务逻辑的类,ActionForm则负责在控制器和视图之间传递数据。ActionMapping定义了请求URL与Action之间...
3. **配置Struts配置文件**:在`struts-config.xml`中,我们需要指定我们的自定义`RequestProcessor`。将`<controller>`标签内的`processorClass`属性设置为`MyProRequestProcessor`的全限定类名。 ```xml ``` 4....
Struts1.x的配置相对静态,每个Action的请求处理器(RequestProcessor)配置在web.xml中,不易修改。而Struts2.x通过拦截器栈(Interceptor Stack)实现了动态配置,可以根据需要为不同Action配置不同的拦截器,大大...
- 可以通过自定义`RequestProcessor`类来扩展Struts的功能,`processorClass`属性指定自定义的处理器类。 7. **DynaActionForm**: - DynaActionForm是Struts的一种动态表单,允许在运行时定义表单属性,无需预先...
- **struts-core-1.3.8.jar**:这是Struts的核心库,包含了Action、ActionForm、ActionMapping、RequestProcessor等关键类。这些类用于处理HTTP请求,调度业务逻辑,并将结果返回给用户界面。 - **struts-taglib-...