Struts2的<result>结果

本文介绍了Struts2框架中的结果视图概念,包括局部和全局逻辑视图的区别及其应用,并详细讲解了如何通过自定义结果类型来生成CAPTCHA图像的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.结果视图:局部和全局逻辑视图

1.1 局部逻辑视图:只服务于当前的动作


1.2 全局逻辑视图:服务于所有的动作

//全局逻辑视图:所有动作没有name = success 的局部视图,到全局视图找


更好的利用package的继承性组织全局视图:


2.自定义结果类型:CAPTCHA图像

2.1所有的结果类型都是直接或间接的实现了Result接口



2.2自定义结果类型的开发步骤

1) 直接或间接实现Result接口

//输出随机验证码图片
public class CaptchaResult extends StrutsResultSupport {
	private int width = 120;
	private int height = 20;
	
	public void setWidth(int width) {
		this.width = width;
	}

	public void setHeight(int height) {
		this.height = height;
	}

	protected void doExecute(String finalLocation, ActionInvocation invocation)
			throws Exception {
		ValidateCode code = new ValidateCode(width, height, 4, 9);
		HttpServletResponse response = ServletActionContext.getResponse();
		code.write(response.getOutputStream());
	}

}

2) 在struts.xml中声明结果类型
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
	"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
	"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
	<constant name="struts.devMode" value="true"></constant>
	<package name="default" extends="struts-default" abstract="true">
		<result-types>
			<result-type name="captcha" class="com.itheima.results.CaptchaResult"></result-type>
		</result-types>
	</package>
</struts>

3) 在动作中使用自定义的结果类型
	<package name="p1" extends="default">
		<action name="captcha">
			<result name="success" type="captcha">
				<param name="width">120</param>
				<param name="height">25</param>
			</result>
		</action>
		<action name="action1"></action>
	</package>




### 解决方案分析 当遇到Struts2框架下的`/login`请求返回404错误时,可能的原因涉及多个方面,包括但不限于Web应用的部署、过滤器配置、`struts.xml`文件中的Action映射以及JSP页面的实际位置。以下是针对该问题的具体解决方案: #### 1. **确认Web应用的部署** 确保项目的WAR包已成功部署至服务器(如Tomcat)。可以通过查看日志文件验证是否存在任何异常或警告信息。 #### 2. **检查`web.xml`中的过滤器配置** 在`web.xml`中定义了Struts2的核心过滤器`StrutsPrepareAndExecuteFilter`,其URL匹配模式决定了哪些请求会被转发给Struts2框架处理。如果未正确定义,则可能导致某些请求无法被识别[^4]。 ```xml <filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>*.action</url-pattern> </filter-mapping> ``` 上述代码片段展示了如何正确配置Struts2过滤器以捕获`.action`结尾的请求。如果你希望支持更灵活的扩展名(例如HTML或其他自定义格式),可以在`struts.xml`中调整如下常量设置[^2]: ```xml <constant name="struts.action.extension" value="action,html"/> ``` 此更改使得除了`.action`外还能够接受`.html`作为合法入口点之一。 #### 3. **校验`struts.xml`内的Action定义** 对于登录功能而言,需确保存在相应的Action条目及其结果跳转路径无误。下面是一个典型的例子说明怎样声明一个名为`Login`的动作并指定两个潜在的结果状态——失败(`error`)与成功(`success`)分别对应不同的视图组件[^1][^2]: ```xml <package name="default" namespace="/" extends="struts-default"> <action name="Login" class="com.example.actions.LoginAction"> <!-- 当认证失败时 --> <result name="error">/index.jsp</result> <!-- 成功登陆后转向内部受保护区域 --> <result name="success">/WEB-INF/views/main.jsp</result> </action> </package> ``` 请注意这里的namespace属性设为了根目录(`/`);因此实际访问地址应形似于`http://yourserver/contextpath/Login.action`而非单纯只写成`/login`. 同时也要留意所指派的目标jsp文档确实位于预期的位置下,并且具有恰当的安全权限设定以免因缺失读取权能而引发额外麻烦。 #### 4. **核实JSP文件的存在性和可访问性** 最终要核查的是目标JSP文件是否存在于项目结构当中并且可以从外部正常浏览。比如上面提到的成功场景里关联到了`main.jsp`,那么它应当存放在`src/main/webapp/WEB-INF/views/`这样的子文件夹里面而不是随便放置在外层公开区域能轻易被人篡改的地方. 另外值得注意的一点就是有时候即使一切看起来都安排妥当但仍会出现找不到资源的情况这往往是因为IDE本身缓存机制作祟所致建议尝试清理整个工程然后再重新构建运行看看效果是否有改善. --- ### 示例代码展示 以下是一份完整的示例程序帮助理解整体架构: ```java public class LoginAction { private String username; private String password; public String getUsername() {return username;} public void setUsername(String username) {this.username = username;} public String getPassword() {return password;} public void setPassword(String password) {this.password = password;} public String execute(){ if ("admin".equals(username) && "password".equals(password)){ return "success"; }else{ return "error"; } } } ``` 配合之前给出的XML片断即构成了基本的功能模块实现过程. ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值