JavaWeb框架————Struts2(一)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Jorocco/article/details/79981306

1、什么是Struts2
Strut是一种基于MVC模式的轻量级的web框架,本质上相当于一个Servlet,Struts2作为控制器来建立模型与视图的数据交互。具有以下优势:
提供Exception处理机制;Result方式的页面导航,通过Result标签很方便的实现重定向和页面跳转;通过简单、集中的配置来调度业务类,使得配置和修改都非常容易;提供简单、统一的表达式语言来访问所有可供访问的数据;提供标准、强大的表达式语言来访问所有可供访问的数据;提供强大的、可以有效减少页面代码的标签;提供良好的Ajax支持。
这里写图片描述
这里写图片描述
2、Struts框架的搭建
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
3、配置详解
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
HelloAction.java

package cn.ctgu.struts;
//Action类
public class HelloAction {
    public String hello() {
        System.out.println("hello world");
        return "success";
    }
}

src下的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>
    <!--常量配置方式二  -->
    <!--i18n:国际化,解决post提交乱码-->
    <constant name="struts.i18n.encoding" value="UTF-8"></constant>
    <!-- 指定访问action时的后缀名为.do或空
        http://localhost:8080/struts2_1/hello/HelloAction.do
    -->
    <constant name="struts.action.extension" value="do,,"></constant>
    <!-- 指定struts2是否以开发模式运行
        1、热加载主配置文件(不需要重启即可生效)
        2、提供更多错误信息输出,方便开发时调试
     -->
    <constant name="struts.devMode" value="true"></constant>

    <!-- package:将Action配置封装,就是可以在Package中配置很多action
        name属性:给包起个名字,起到标识作用,随便起,不能与其他包名重复
        namespace属性:给action的访问路径中定义一个命名空间
        extends属性:继承一个指定包
        abstract属性:包是否为抽象的,标识属性,标识该包不能独立运行,专门呢被继承
         -->
    <package name="struts" namespace="/hello" extends="struts-default">
        <!-- action元素:配置action类
            name属性:决定了Action访问资源名
            class属性:action的完整类名
            method属性:指定调用Action中的哪个方法来处理请求
         -->
        <action name="HelloAction" class="cn.ctgu.struts.HelloAction" method="hello">
            <!--result元素:结果配置
                name属性:标识结果处理的名称,与action方法的返回值对应
                type属性:指定调用哪一个result类来处理结果,默认使用转发
                标签体:填写页面的相对路径
              -->
            <result name="success" type="dispatcher">/hello.jsp</result>
        </action>
    </package>

    <!-- 引入其他struts配置文件 -->
    <include file="cn/ctgu/dynamic/struts.xml"></include>
    <include file="cn/ctgu/_default/struts.xml"></include>
</struts>

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
  <display-name>Struts2_1</display-name>
  <!-- 配置常量方法三 -->
  <!-- <context-param>
    <param-name>struts.i18n.encoding</param-name>
    <param-value>utf-8</param-value>
  </context-param> -->

  <!-- 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>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>
</web-app>

动态调用
这里写图片描述
package cn.ctgu.dynamic.Demo2Action.java

package cn.ctgu.dynamic;

//动态方法调用
public class Demo1 {
    public String add() {
        System.out.println("添加用户");
        return "success";
    }
    public String delete() {
        System.out.println("删除用户");
        return "success";
    }
    public String update() {
        System.out.println("修改用户");
        return "success";
    }
    public String find() {
        System.out.println("查找用户");
        return "success";
    }
}

cn.ctgu.dynamic下的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>
    <!--常量配置方式二  -->
    <!--i18n:国际化,解决post提交乱码-->
    <constant name="struts.i18n.encoding" value="UTF-8"></constant>
    <!-- 指定访问action时的后缀名为.do或空
        http://localhost:8080/struts2_1/hello/HelloAction.do
    -->
    <constant name="struts.action.extension" value="do,,"></constant>
    <!-- 指定struts2是否以开发模式运行
        1、热加载主配置文件(不需要重启即可生效)
        2、提供更多错误信息输出,方便开发时调试
     -->
    <constant name="struts.devMode" value="true"></constant>

    <!-- package:将Action配置封装,就是可以在Package中配置很多action
        name属性:给包起个名字,起到标识作用,随便起,不能与其他包名重复
        namespace属性:给action的访问路径中定义一个命名空间
        extends属性:继承一个指定包
        abstract属性:包是否为抽象的,标识属性,标识该包不能独立运行,专门呢被继承
         -->
    <package name="dynamic" namespace="/" extends="struts-default">
        <!-- action元素:配置action类
            name属性:决定了Action访问资源名
            class属性:action的完整类名
            method属性:指定调用Action中的哪个方法来处理请求
         -->
         <!-- 转发 -->
        <action name="Demo_*" class="cn.ctgu.dynamic.Demo1" method="{1}">
            <result name="success" type="dispatcher">/hello.jsp</result>
        </action>

    </package>

</struts>

使用默认配置
这里写图片描述
package cn.ctgu._default.Demo2Action.java

package cn.ctgu._default;
//测试默认配置
public class Demo2Action {
    public String execute() {
        System.out.println("Demo2Action~~~~~~");
        return "success";
    }

}

cn.ctgu._default下的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>

    <package name="default" namespace="/default" extends="struts-default">
            <!--找不到包下的action请求(url中),会使用Demo2Action作为默认action处理请求 -->
            <default-action-ref name="Demo2Action"></default-action-ref>

            <!--method默认属性是:execute方法 -->
            <!--result的name属性:success -->
            <!--result的type属性默认是:dispatcher转发  -->
            <!--class属性:com.opensymphony.xwork2.ActionSupport  -->
            <action name="Demo2Action" class="cn.ctgu._default.Demo2Action" method="execute">
            <result name="success">/hello.jsp</result>
        </action>
    </package>
</struts>

4、API类详解

配置文件时上面src下的struts.xml
这里写图片描述
Demo3Action.java

package cn.ctgu.api;

//方式1:创建一个类,可以使POJO
//POJO:不用继承任何父类,也不需要实现任何接口
//使struts框架的代码侵入性更低
//不常用
public class Demo3Action {

}

Demo4Action.java

package cn.ctgu.api;

import com.opensymphony.xwork2.Action;

//方式2:实现一个接口Action
//里面有execute方法,提供action方法的规范
//Action接口预置了一些字符串,可以在返回结果时使用,为了方便,例如: success  none error......
//不常用
public class Demo4Action implements Action{

    @Override
    public String execute() throws Exception {
        // TODO Auto-generated method stub
        return null;
    }

}

Demo5Action.java

package cn.ctgu.api;

import com.opensymphony.xwork2.ActionSupport;

//方式3:继承一个类,ActionSupport
//帮我们实现了Validateable,ValidationAware,TextProvider,LocaleProvider
//如果我们需要用到这些接口的实现时,不需要自己来实现了
public class Demo5Action extends ActionSupport{

}
阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页