the struts dispatcher cannot be found

在struts2.0中直接访问jsp路径,有时候会出现这样的错误: Error 500--Internal Server Error The Struts dispatcher cannot be found. This is usually caused by using Struts tags without the associated filter. Struts tags are only usable when the request has passed through its servlet filter, which initializes the Struts dispatcher needed for this tag. - [unknown location] at org.apache.struts2.views.jsp.TagUtils.getStack(TagUtils.java:60) at org.apache.struts2.views.jsp.StrutsBodyTagSupport.getStack(StrutsBodyTagSupport.java:52) at org.apache.struts2.views.jsp.ComponentTagSupport.doStartTag(ComponentTagSupport.java:49) at jsp_servlet._report.__customerinfo._jspService(__customerinfo.java:133) at weblogic.servlet.jsp.JspBase.service(JspBase.java:34) at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:227) at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:125) at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:283) at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:26) at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42) at org.apache.struts2.dispatcher.ActionContextCleanUp.doFilter(ActionContextCleanUp.java:99) at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42) at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3242) at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321) at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:121) at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2010) at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:1916) at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1366) at weblogic.work.ExecuteThread.execute(ExecuteThread.java:209) at weblogic.work.ExecuteThread.run(ExecuteThread.java:181) 错误提示里已经说得很明白:这通常是由于不经由Filter访问包含struts标签的jsp页面导致的。那么,只要通过配置,使得对jsp页面的访问请求由Filter过滤转发即可。 方法1:在strut.xml中配置一个通用Action,通过这个Action转发到jsp页面。这个时候,原先访问jsp的请求路径就要换成相应的Action路径了。写法如下。 <action name="*"><result>/{1}.jsp</result></action> 方法2:在web.xml中配置Filter的url-parttern。写法如下。其中struts2-dispatcher 是已定义的Filter。 <filter-mapping><filter-name>struts2-dispatcher </filter-name><url-pattern>*.action </url-pattern></filter-mapping><filter-mapping><filter-name>struts2-dispatcher </filter-name><url-pattern>*.jsp </url-pattern></filter-mapping> 方法3:在web.xml中配置扩展名。写法如下。配置完成后,就可以这样访问了:http://localhost:8080/yk_cpp/public/index.html 在web.xml中加 <init-param><param-name>struts.action.extension</param-name><param-value>html</param-value></init-param> 在struts.xml中加 <constant name="struts.action.extension" value="html"></constant> 方法4:修改struts.properties文件。去struts2的包里看一下default.properties,里面默认的action是struts.action.extension=action,,(注意有两个逗号,意思是第二个配置是空)空是全部拦截。在这里修改要拦截的带扩展名的文件,比如struts.action.extension=action,jnlp,do 不过这些没有经过测试;因为我的本地服务器没有出500的错误,问题是出在正式服务器上的,所以没法调试。下次设法在本地重现一下问题,然后挨个试一试。
### 问题分析 在使用 Struts2 框架进行文件上传操作时,如果出现 `org.apache.struts2.dispatcher.StrutsRequestWrapper cannot be cast to com.oreilly.servlet.MultipartRequest` 异常,通常表明当前请求的封装类与预期的文件上传处理类不兼容。Struts2 默认使用 `StrutsRequestWrapper` 来封装 HTTP 请求,而 `MultipartRequest` 是 `cos` 文件上传库中的类,用于处理上传请求。当两者混用时,会出现类型转换异常[^2]。 ### 常见原因 - **库版本冲突**:`cos` 库与 Struts2 的文件上传处理机制存在冲突,尤其是在 Struts2 使用内置的 `PellMultipart/form-data` 或 `Apache Commons FileUpload` 时。 - **拦截器配置错误**:未正确配置或替换 `fileUpload` 拦截器,导致请求未被正确封装为 `MultipartRequest`。 - **手动封装请求**:在自定义拦截器或 Action 中手动封装请求时,使用了 `MultipartRequest` 而未确保其兼容性。 ### 解决方案 #### 1. 使用 Struts2 默认的文件上传机制 Struts2 提供了内置的文件上传支持,推荐优先使用其默认机制,而不是引入第三方库如 `cos`。确保 `struts.xml` 中启用了 `fileUpload` 拦截器,并且未手动封装请求为 `MultipartRequest`。 ```xml <interceptor-ref name="fileUpload"/> ``` #### 2. 避免手动使用 `MultipartRequest` 在自定义拦截器或 Action 中,避免使用如下代码: ```java MultipartRequest multi = new MultipartRequest(request, "/path/to/upload"); ``` 该代码会将 `HttpServletRequest` 封装为 `MultipartRequest`,而 Struts2 默认使用 `StrutsRequestWrapper`,导致类型转换异常。应使用 Struts2 提供的 `FileUpload` API 或 `ServletActionContext.getRequest()` 获取封装后的请求对象。 #### 3. 替换文件上传处理库 如果确实需要使用 `cos` 或其他库进行文件上传,应替换 Struts2 默认的文件上传处理机制。可以通过自定义 `FileUploadProvider` 来实现: ```java public class CosFileUploadProvider implements FileUploadProvider { @Override public void parse(HttpServletRequest request, String saveDir, String encoding) { new MultipartRequest(request, saveDir); } } ``` 并在 `struts.xml` 中配置: ```xml <bean type="org.apache.struts2.dispatcher.multipart.MultiPartRequest" name="cos" class="com.example.CosMultiPartRequest"/> <constant name="struts.multipart.parser" value="cos"/> ``` #### 4. 检查依赖库版本 确保项目中没有多个版本的 `cos` 或 `commons-fileupload` 库共存,避免类加载冲突。可以使用 Maven 或 Gradle 管理依赖版本,排除冲突库。 ### 相关问题 - Struts2 中如何自定义文件上传拦截器? - 如何在 Struts2 中使用 `cos` 进行文件上传? - Struts2 的文件上传机制是如何工作的? ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值