关闭

如何使用struts2,把struts2加入到一个web project

标签: strutswebactionexceptionstring框架
3501人阅读 评论(0) 收藏 举报
分类:

 

开发Struts2依赖的jar

http://struts.apache.org/download.cgi#struts2014下载struts-2.x.x-all.zip,目前最新版为2.2。下载完后解压文件,开发struts2应用需要依赖的jar文件在解压目录的lib文件夹下。不同的应用需要的JAR包是不同的。下面给出了开发Struts 2程序最少需要的JAR

struts2-core-2.x.x.jar :Struts 2框架的核心类库

xwork-2.x.x.jar :XWork类库,Struts 2在其上构建

ognl-2.6.x.jar :对象图导航语言(Object Graph Navigation Language),Struts 2框架使用的一种表达式语言

freemarker-2.3.x.jar :Struts 2UI标签的模板使用FreeMarker编写

commons-logging-1.1.x.jar :ASF出品的日志包,Struts 2框架使用这个日志包来支持Log4JJDK 1.4+的日志记录。

Commons-fileupload   拷进去

还有一种最省事的做法是:

如果不需要跟第三方框架集成,把不带-plugin结尾的jar文件都添加入类路径即可。如果需要跟第三方框架集成,这时候还需要加入对应的-plugin jar文件。例如跟spring集成,需要加入struts2-spring-plugin-2.x.x.jar.

Struts2的启动配置

struts1.x中, struts框架是通过Servlet启动的。在struts2中,struts框架是通过Filter启动的。他在web.xml中的配置如下:

<filter>

    <filter-name>struts2</filter-name>

    <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>

</filter>

<filter-mapping>

    <filter-name>struts2</filter-name>

    <url-pattern>/*</url-pattern>

</filter-mapping>

FilterDispatcherinit()方法中将会读取类路径下默认的配置文件struts.xml完成初始化操作。

 

注意:struts2读取到struts.xml的内容后,会将内容封装进javabean对象并存放在内存中,对于用户每次请求的处理将使用内存中的数据,而不是每次请求都读取struts.xml文件

Struts2的配置文件

Struts2默认的配置文件为struts.xml FilterDispatcher过滤器在初始化时将会在WEB-INF/classes下寻找该文件,该文件的配置模版如下:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE struts PUBLIC

    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"

    "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

   <package name="test" namespace="/test" extends="struts-default">

       <action name="helloworld" class="net.xabc. action.HelloWorldAction">

              <result name="success">/WEB-INF/page/hello.jsp</result>

       </action>

    </package>

</struts>

Struts2的第一个应用(编写Action)

例子中使用到的net.xabc.action.HelloWorldAction类如下:

package net.xabc.action;

public class HelloWorldAction{

       private String message;

      

       public String getMessage() {

              return message;

       }

       public void setMessage(String message) {

              this.message = message;

       }

 

       public String execute() throws Exception{

              this.message = "我的第一个struts2应用";

              return "success";

       }

}

编写JSP页面

例子中使用到的/WEB-INF/page/hello.jsp如下:

 

<%@ page language="java" pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

  <head>

    <title>第一个struts2应用</title>

  </head>

  <body>

   ${message } <br>

  </body>

</html>

 

可以使用EL表达式访问Action中的属性。

 

配置文件详解
1.Struts.xml配置包

 

<package name="test" namespace="/test" extends="struts-default">

       <action name="helloworld" class="net.xabc.action.HelloWorldAction">

              <result name="success">/WEB-INF/page/hello.jsp</result>

       </action>

 </package>

struts2框架中使用包来管理Action,包的作用和java中的类包是非常类似的,它主要用于管理一组业务功能相关的action。在实际应用中,我们应该把一组业务功能相关的Action放在同一个包下。

配置包时必须指定name属性,如果其他包要继承该包,必须通过该属性进行引用。

包的namespace属性用于定义该包的命名空间。该属性可以不配置,对本例而言,如果不指定该属性,默认的命名空间为“”(空字符串)

 

通常每个包都应该继承struts-default包, struts-default包是由struts内置的,它定义了struts2内部的众多拦截器和Result类型。Struts2很多核心的功能都是通过这些内置的拦截器实现的。如:从请求中把请求参数封装到action、文件上传和数据验证等等都是通过拦截器实现的。当包继承了struts-default包才能使用struts2提供的这些功能。 struts-default包是在struts2-core-2.x.x.jar文件中的struts-default.xml中定义。 struts-default.xml也是Struts2默认配置文件。 Struts2每次都会自动加载 struts-default.xml文件。

 

包还可以通过abstract=“true”定义为抽象包,抽象包中不能包含action

 

 

Struts.xml配置Action

 

<package name="test" namespace="/test" extends="struts-default">

       <action name="helloworld" class="net.xabc.action.HelloWorldAction">

              <result name="success">/WEB-INF/page/hello.jsp</result>

       </action>

 </package>

struts1中,通过path属性指定访问该actionURL路径。在struts2中,情况就不是这样了,访问struts2中的actionURL路径由两部份组成:包的命名空间+action的名称,例如访问上面例子中名为helloworldActionURL路径为:/test/helloworld (注意:完整路径为:http://localhost:端口/内容路径/test/ helloworld.action)

 

如果没有为action指定class,默认是ActionSupport。而ActionSupportexecute() 方法默认处理就是返回一个success字符串。method属性用于指定action中的那个方法,如果没有指定默认执行action中的execute() 方法。

Action名称的搜索顺序

 

1.获得请求路径的URI,例如url是:http://server/struts2/path1/path2/path3/test.action

2.首先寻找namespace/path1/path2/path3package,如果存在这个package,则在这个package中寻找名字为testaction,如果不存在这个package则转步骤3

3.寻找namespace/path1/path2package,如果存在这个package,则在这个package中寻找名字为testaction,如果不存在这个package,则转步骤4

4.寻找namespace/path1package,如果存在这个package,则在这个package中寻找名字为testaction,如果仍然不存在这个package,就去默认的namaspacepackage下面去找名字为testaction,如果还是找不到,页面提示找不到action

 

Struts.xml配置Actionresult

 

<action name="helloworld" class="net.xabc.action.HelloWorldAction">

       <result name="success">/WEB-INF/page/hello.jsp</result>

</action>

result配置类似于struts1中的forward,但struts2中提供了多种结果类型,如: dispatcher(默认值) redirect  redirectAction plainText

 

下面是redirectAction 结果类型的例子,如果重定向的action中同一个包下:

<result type="redirectAction">helloworld</result>

如果重定向的action在别的命名空间下:

<result type="redirectAction">

       <param name="actionName">helloworld</param>

       <param name="namespace">/test</param>

</result>

 

如果没有指定resultname属性,默认值为success

 

result中还可以使用${属性名}表达式,表达式里的属性名对应action中的属性。如下:

<result type="redirect">view.jsp?id=${id}</result>

指定需要Struts 2处理的请求后缀

 

FilterDispatcherStruts 2框架的核心控制器,它负责拦截由<url-pattern>/*</url-pattern>指定的所有用户请求,当用户请求到达时,该Filter会过滤用户请求。默认情况下,如果用户请求的路径以.action结尾,该请求将被转入Struts 2框架处理,否则该请求将略过Struts 2框架的处理。

 

默认处理的后缀是可以通过常量”struts.action.extension“进行修改的,如下面配置Struts 2只处理以.do为后缀的请求路径:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE struts PUBLIC

    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"

    "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

    <constant name="struts.action.extension" value="do"/>

</struts>

 

如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开。如:

 <constant name="struts.action.extension" value="do,go"/>

 

Struts2的处理流程

 

指定多个配置文件

 

在大部分应用里,随着应用规模的增加,系统中Action数量也大量增加,导致struts.xml配置文件变得非常臃肿。为了避免struts.xml文件过于庞大、臃肿,提高struts.xml文件的可读性,我们可以将一个struts.xml配置文件分解成多个配置文件,然后在struts.xml文件中包含其他配置文件。下面的struts.xml通过<include>元素指定多个配置文件:

 

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE struts PUBLIC

    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"

    "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

       <include file="struts-user.xml"/>

       <include file="struts-order.xml"/>

</struts>

 

通过这种方式,我们就可以将Struts 2Action按模块配置在多个配置文件中。

动态方法调用

 

如果Action中存在多个方法时,我们可以使用!+方法名调用指定方法。如下:

public class HelloWorldAction{

       private String message;

       ....

       public String execute() throws Exception{

              this.message = "我的第一个struts2应用";

              return "success";

       }

      

       public String other() throws Exception{

              this.message = "第二个方法";

              return "success";

       }

}

假设访问上面actionURL路径为: /struts/test/helloworld.action

要访问actionother() 方法,我们可以这样调用:

/struts/test/helloworld !other .action

通常不建议大家使用动态方法调用,我们可以通过常量struts.enable.DynamicMethodInvocation关闭动态方法调用。

<constant name="struts.enable.DynamicMethodInvocation" value="false"/>

 

 

使用通配符定义action

 

<package name="test" namespace="/test" extends="struts-default">

       <action name="helloworld_*" class="net.xabc.action.HelloWorldAction" method="{1}">

              <result name="success">/WEB-INF/page/hello.jsp</result>

       </action>

</package>

public class HelloWorldAction{

       private String message;

       ....

       public String execute() throws Exception{

              this.message = "我的第一个struts2应用";

              return "success";

       }

      

       public String other() throws Exception{

              this.message = "第二个方法

 

http://jinjiajie.javaeye.com/blog/843216 原文链接

 

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:1373911次
    • 积分:16419
    • 等级:
    • 排名:第645名
    • 原创:496篇
    • 转载:141篇
    • 译文:0篇
    • 评论:220条
    最新评论