相当于servlet,处理网络请求部分。
一、导包
struts导包中没有进行区分,使用打开示例,引入示例导入部分,则可以实现基本功能,也就是hibernate中必须导入的jar包。
二、书写Action类
用于测试类的Action:
public class HelloAction {
public String hello() {
System.out.println("hello world!");
return "success";
}
}
Action实现方式有三种:
(1)不继承任何父类,不实现任何接口【POJO】,代码的侵入性降低;
(2)实现Action接口,选择性实现execte()方法,提供预制的字符串,方便实用并提醒实现规则;
(3)继承ActionSupport类,帮助实现Validateable, ValidationAware, TextProvider, LocaleProvider 。
三、书写sruts.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>
<!-- package:将Action配置封装.就是可以在Package中配置很多action.
name属性: 给包起个名字,起到标识作用.随便起.不能其他包名重复.
namespace属性:给action的访问路径中定义一个命名空间
extends属性: 继承一个 指定包
abstract属性:包是否为抽象的; 标识性属性.标识该包不能独立运行.专门被继承
-->
<package name="hello" namespace="/hello" extends="struts-default" >
<!-- action元素:配置action类
name属性: 决定了Action访问资源名.
class属性: action的完整类名
method属性: 指定调用Action中的哪个方法来处理请求
-->
<action name="HelloAction" class="com.future.HelloAction" method="hello" >
<!-- result元素:结果配置
name属性: 标识结果处理的名称.与action方法的返回值对应.
type属性: 指定调用哪一个result类来处理结果,默认使用转发.
标签体:填写页面的相对路径
-->
<result name="success" >/hello.jsp</result>
</action>
</package>
</struts>
struts.xml放置在src目录下,以至于编译生成class文件在WEB-INF下,实现运行时调用。
也可以放置在其他目录下,但是在src目录下需要有一个struts.xml。其他路径下的struts.xml文件在该文件中使用include标签引入。注意引入时,路径必须完全正确,是以src目录下开始,不包含src。
在执行成功后会转发hello.jsp文件,当前项目需要创建该jsp文件。
struts.xml文件中还能进行struts常量配置,主要包含以下常用的:
<!-- i18n:国际化. 解决post提交乱码 -->
<constant name="struts.i18n.encoding" value="UTF-8"></constant>
<!-- 指定反问action时的后缀名 -->
<constant name="struts.action.extension" value="action,do,,"></constant>
<!-- 指定struts2是否以开发模式运行
1.热加载主配置.(不需要重启即可生效)
2.提供更多错误信息输出,方便开发时的调试
-->
<constant name="struts.devMode" value="true"></constant>
在struts.xml中,针对一个Action中有多个方法的,还可以使用动态配置方法,以下为推荐设置:
<?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.enable.DynamicMethodInvocation" value="false"></constant>
<package name="dynamic" namespace="/dynamic" extends="struts-default" >
<!-- 动态方法调用方式2:通配符方式
使用{1} 取出第一个星号通配的内容
-->
<action name="Demo1Action_*" class="com.future.dynamic.Demo1Action" method="{1}" >
<result name="success" >/hello.jsp</result>
</action>
</package>
</struts>
在调用时,Demo1Action_*后面的*替换成为Demo1Action中的方法名即可实现调用。
四、配置struts2核心过滤器
在WEB-INF目录下的web.xml文件中添加核心过滤器的配置。
<!-- struts2核心过滤器 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
注意:在当前文件中,下面部分添加了welcome-file-list标签,其中引入的文件必须当前项目中包含。
五、测试
将项目运行到tomcat服务器下,通过浏览器可以访问。在实际的使用中,还需要实现Action方法与服务器的交互。当前项目就可以运行查看。运行前提是安装tomcat服务器,并把项目运行到服务器下。【配置说明较多,不做细化】
六、注意事项
1,主struts.xml一定放置在src目录下;
2,web.xml中配置相关jsp在项目中需要实现,默认的没有添加的删除掉;
3,不必要的库依赖也清除掉。