web填坑-Struts2

Struts2实例

src下创建com.Struts2Test.HelloStruts
LoginAction.java

package com.Struts2Test.HelloStruts;

/**
 * Created by elijahliu on 2017/2/22.
 */
public class LoginAction {
    private String username;
    private  String password;

    public String execute() {
        if (username.equals("admin") && password.equals("123")) {
            return "success";
        } else {
            return "fail";
        }
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }
}

这里的execute()方法会由Struts自动调用,有点像servtlet的service方法那样。

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>
   <!--该标签用于创建一个JavaBean实例-->
   <!--bean class=""></bean>-->

   <!--该标签用于Struts2默认行为标签,改变默认配置-->
   <!--这里设置了编码集,也就是运行struts(相当于过滤器)后,就不需要在每个servlet中写
   HttpServletRequest.setCharacterEncodingd了-->
   <constant name="struts.i18n.encoding" value="UTF-8"></constant>
   <!--这一条也就是说如果不配置的话,只会拦截后缀名为.action请求,配置后,过滤器也会拦截后缀.do的请求-->
   <constant name="struts.action.extension" value="do"/>
   <!--这个属性设置是指浏览器是否缓存静态内容,默认是true,但是开发阶段建议关闭,避免修改后测试不准-->
   <constant name="struts.serve.static.browserCache" value="false"/>
   <!--当struts配置文件修改后,系统是否重新加载该文件,默认为false-->
   <constant name="struts.configuration.xml.reload" value="true"/>
   <!--开发模式下使用,可以打印出更加详细的错误信息-->
   <constant name="struts.devMode" value="true"/>
   <!--默认试图主题-->
   <constant name="struts.ui.theme" value="simple"/>



   <!--该标签用于区分不同的请求文件的标签,比如 网站前台请求,或网站后台请求-->
   <!--name属性:包名,用于被别的包调用或继承-->
   <package name="com.Struts2Test" namespace="/new" extends="struts-default">
       <!--action相当于以前的servlet的概念,对应一个请求name为请求的url地址
       如访问这个 action的话 url为 localhost:8080/项目名/new/login.do
       /new为命名空间,.do为后缀 上面constant里有配置
       -->
       <action name="login" class="com.Struts2Test.HelloStruts.LoginAction">
           <!--这个标签配置了返回结果页面-->
           <!--这个result标签中的name 对应的是loginAction.java中的返回值-->
           <result name="success">/success.jsp</result>
           <result name="fail">/fail.jsp</result>
       </action>
   </package>

   <!--用于引入其他的xml配置文件-->
   <!--<include file=""/>-->
</struts>

最后添加Struts的web.xml配置

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         version="3.1">
    <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>
</web-app>

Struts2拦截器

这里的拦截器其实本质上就是一个过滤器,说法不同,也是采用了AOP的思想,将业务抽离解耦

拦截器实例
创建LoginAction2.java

package com.Struts2Test.HelloStruts;

import com.opensymphony.xwork2.ActionSupport;

/**
 * Created by elijahliu on 2017/2/22.
 */
public class LoginAction2 extends ActionSupport{
    @Override
    public String execute() throws Exception {
        System.out.println("进入了LoginAction2");
        return SUCCESS;
    }
}

创建拦截器 FirstInterceptor.java

package com.Struts2Test.HelloStruts;


import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor;

/**
 * Created by elijahliu on 2017/2/22.
 */
public class FirstIntercepter implements Interceptor {

    private String someThing;

    @Override
    public void destroy() {

    }

    @Override
    public void init() {//当程序启动的时候 拦截器就被初始化完毕了
        System.out.print("拦截器启动完毕了");

    }

    @Override
    public String intercept(ActionInvocation actionInvocation) throws Exception {

        String returname = actionInvocation.invoke();//该方法让到达拦截器的请求继续前进,访问后面需要访问的
        //运行这个方法就是放过区,类似于filter过滤器中的doFilter()方法,里面又个chain对象用法相同
        return returname;
    }

    public void setSomeThing(String someThing) {
        this.someThing = someThing;
    }

    public String getSomeThing() {
        return someThing;
    }
}

修改struts.xml配置文件

    <package name="com.Struts2Test" namespace="/new" extends="struts-default">
        <interceptors>
            <interceptor name="FirstInterceptor" class="com.Struts2Test.HelloStruts.FirstIntercepter">
                <param name="someThing">test</param>
            </interceptor>
            <interceptor-stack name="AllInterceptor">  <!--这里设置了一个拦截器栈-->
                <interceptor-ref name="FirstInterceptor"/>
                <interceptor-ref name="defaultStack"/>
            </interceptor-stack>
        </interceptors>

        <default-interceptor-ref name="AllInterceptor"/><!--将allinterceptor拦截器设置成默认的系统拦截器,即使action中没有配置 也能访问到-->
        <!--action相当于以前的servlet的概念,对应一个请求name为请求的url地址
        如访问这个 action的话 url为 localhost:8080/项目名/new/login.do
        /new为命名空间,.do为后缀 上面constant里有配置
        -->
        <action name="login" class="com.Struts2Test.HelloStruts.LoginAction">
            <!--这个标签配置了返回结果页面-->
            <!--这个result标签中的name 对应的是loginAction.java中的返回值-->
            <result name="success">/success.jsp</result>
            <result name="fail">/fail.jsp</result>
        </action>

        <action name="LoginInterceptor" class="com.Struts2Test.HelloStruts.LoginAction2">
            <interceptor-ref name="AllInterceptor"/>
            <result name="success">/success.jsp</result>
        </action>
    </package>

添加action LoginAction2,一定要在package下面最开始生命使用的interceptors,这里先声明了一个FirstInterceptor,其中装填了一个参数,也就是someThing装填一个参数,然后声明了一个拦截器栈,里面有刚刚声明的FirstInterceptor,还有一个系统默认的拦截器。
那么在下面的loginaction2中引用了拦截器栈,也就是两个拦截器都引用了。这里一定要引用默认的defaultstack,因为如果你自定义了拦截器,他就不会加载默认拦截器,容易出问题。
default-interceptor-ref标签用于声明一个默认的拦截器,也就是package中的其他拦截器不显示的调用,也会默认调用这个拦截器。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容

  • 概述 什么是Struts2的框架Struts2是Struts1的下一代产品,是在 struts1和WebWork的...
    inke阅读 2,249评论 0 50
  • 详谈 Struts2 的核心概念 本文将深入探讨Struts2 的核心概念,首先介绍的是Struts2 的体系结构...
    可爱傻妞是我的爱阅读 1,117评论 0 2
  • 1、struts2工作流程 Struts 2框架本身大致可以分为3个部分: 核心控制器FilterDispatch...
    重山杨阅读 1,515评论 0 38
  • action中如何接受页面传过来的参数 第一种情况:(同名参数) 例如:通过页面要把id=1 name=tom a...
    清枫_小天阅读 2,946评论 1 22
  • 阅读本身相关 据我所知挺多人(举例说中文的人)看花体字或全大写的字很困难,比如菜单,新闻标题。但字母国家的人似乎没...
    chuva阅读 270评论 0 0