搭建Struts2开发环境的步骤

搭建Struts2开发环境的步骤

搭建Struts2环境时,我们一般需要做以下几个步骤的工作:

1. 创建javaweb工程

创建struts2test工程

2. 找到开发Struts2应用需要使用到的jar文件

开发struts2应用需要依赖的jar文件在解压目录的lib文件夹下。不同的应用需要的JAR包是不同的。下面给出了开发Struts 2程序最少需要的JAR。

  • struts2-core-2.3.3.31.jar:Struts 2框架的核心类库
  • xwork-core-2.3.3.31.jar:Command模式框架,WebWork和Struts2都基于xwork
  • ognl-3.0.19.jar:对象图导航语言(Object Graph Navigation Language), struts2框架通过其读写对象的属性
  • freemarker-2.3.22.jar:Struts 2的UI标签的模板使用FreeMarker编写
  • commons-logging-1.1.x.jar:ASF出品的日志包,Struts 2框架使用这个日志包来支持Log4J和JDK 1.4+的日志记录。
  • commons-fileupload-1.3.2.jar: 文件上传组件,2.1.6版本后需要加入此文件
  • commons-io-2.2.jar:传文件依赖的jar包
  • commons-lang-3-3.2.jar:对java.lang包的增强
  • asm-3.3.jar:提供了字节码的读写的功能,包含了核心的功能,而其他的jar包都是基于这个核心的扩展.
  • asm-commons-3.3.jar:提供了基于事件的表现形式。
  • asm-tree-3.3.jar:提供了基于对象的表现形式。
  • javassist-3.11.0.GA.jar:代码生成工具, struts2用它在运行时扩展 Java类
    这里写图片描述
3. 创建jsp文件
定义test.jsp文件
增加如下连接:
 <a href="${pageContext.request.contextPath}
                  /primer/HelloWorldAction.action">helloworld</a><br>
<%@ page language="java" pageEncoding="utf-8" contentType="text/html; charset=utf-8"%>
<%@ taglib uri="/struts-tags"   prefix="s"%>
<html>
  <head>
    <title>My JSP 'index.jsp' starting page</title>
    </head>
  <body>
       入门的路径:<br>  
      <a href="${pageContext.request.contextPath}/primer/helloWorldAction.action">helloWorld</a><br>


  </body>
</html>
4. 创建action文件

注:struts2中action要实现com.opensymphony.xwork2.Action的接口

import com.opensymphony.xwork2.Action;
public class HelloWorldAction implements Action{
    public String execute() throws Exception {
        System.out.println("helloWorld");
        //转到成功页面
        return "success";
    }
}
package cn.itcast.primer;

import com.opensymphony.xwork2.Action;

public class HelloWorldAction implements Action{

    @Override
    public String execute() throws Exception {
        // TODO Auto-generated method stub
        System.out.println("HelloWorldAction 的execute()方法执行");
        return "success";
    }

}
5. 编写Struts2的配置文件

Struts2默认的配置文件为struts.xml ,该文件需要存放在WEB-INF/classes下,也就是当前工程的src下,该文件的配置模版如下:
这里写图片描述

  • 配置 package 元素
    这里写图片描述

  • 配置 action 元素
    这里写图片描述

  • 配置 result 元素
    这里写图片描述

success.jsp页面:

<%@ page language="java" pageEncoding="utf-8" contentType="text/html; charset=utf-8"%>
<%@ taglib uri="/struts-tags"   prefix="s"%>
<html>
  <head>
    <title>My JSP 'index.jsp' starting page</title>
    </head>
  <body>
        primer文件夹下  helloworld成功!!!!<br>
  </body>
</html>

在struts2框架中使用包来管理Action,包的作用和java中的类包是非常类似的,它主要用于管理一组业务功能相关的action。在实际应用中,我们应该把一组业务功能相关的Action放在同一个包下。
配置包时必须指定name属性,如果其他包要继承该包,必须通过该属性进行引用,注意: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。
具体配置:

<?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>
    <!-- /primer/helloWorldAction.action
        package:包
            * name:包名,唯一的,必选项
            * namespace:命名空间,唯一的,相当于房间号。可选项,省略情况下是"/"。页面中请求连接的前半部分
            * extends:继承
                * extends="struts-default":struts2框架底层提供的核心包struts2-core-2.3.3.jar下的struts-default.xml文件
                * 为什么要继承这个struts-default.xml文件?
     -->
     <package name="primer" namespace="/primer" extends="struts-default">
            <!-- 
            action:
                * name:对应页面中请求连接的后面半部分
                * class:对应要执行的类的完整路径
         -->
         <action name="helloWorldAction" class="cn.itcast.primer.HelloWorldAction">
                <!-- 
                result:结果类型
                    * name:对应的是执行的类的方法的返回值
                        public String execute() throws Exception {
                            System.out.println("HelloWorldAction ************* execute()");
                            return "success";
                        }
                    * 后半部分的文本内容:要转向到的页面
             -->
             <result name="success">/primer/success.jsp</result>
         </action>

     </package>


</struts>
6. 在web.xml中加入Struts2 MVC框架启动配置

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

 <filter>
      <filter-name>StrutsPrepareAndExecuteFilter</filter-name>
      <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
      <!-- 自从Struts 2.1.3以后,下面的FilterDispatcher已经标注为过时
      <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class> --> 
 </filter>
 <filter-mapping>
      <filter-name>StrutsPrepareAndExecuteFilter</filter-name>
      <url-pattern>/*</url-pattern>
  </filter-mapping>

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

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

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" 
    xmlns="http://java.sun.com/xml/ns/javaee" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
    http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
  <display-name></display-name> 
  <filter>
    <filter-name>StrutsPrepareAndExecuteFilter</filter-name>
    <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>

  <filter-mapping>
    <filter-name>StrutsPrepareAndExecuteFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>


  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

Struts2的启动配置(底层代码)

这里写图片描述

最后的运行结果:
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值