相当于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,不必要的库依赖也清除掉。
每个人心里都有一段永远也实现不了的爱情“暗恋”,和一个永远也到不了的地方“桃花源”。