Struts2拦截器和标签

一、struts2拦截器

  1、struts2是框架,封装了很多的功能,struts2里面封装的功能都是在拦截器里面。

  2 struts2里面封装了很多的功能,有很多拦截器,不是每次这些拦截器都执行,每次执行默认的拦截器。

  3 struts2里面默认拦截器位置,在struts2-core.jar jar包里面有一个struts-default.xml文件,在里面配置了默认拦截器。

    

  4拦截器在action被创建之后,方法执行之前执行。

  5拦截器的底层使用的两个原理

    (1)aop思想:struts2的拦截器底层使用了aop的思想,aop是面向切面(方面)编程,

             aop的思想是不通过修改源代码而去增强功能,通过使用配置文件来完成。

    (2)责任链模式:责任链模式是一种设计模式。在责任链中要执行多个操作,比如添加、修改、删除三个操作。

             首先执行添加操作,添加操作执行之后 做类似于放行操作,执行修改操作,修改操作执行之后做类似于放行操作,执行删除操作。

  6、aop和责任链在struts2拦截器中的应用。

    (1)在action方法执行之前执行默认拦截器,执行过程使用aop思想,在action没有直接调用拦截器的方法,使用配置文件方式进行操作

     (2)在执行拦截器时候,执行很多的拦截器,这个过程使用责任链模式

         假如执行三个拦截器,执行拦截器1,执行拦截器1之后做放行操作,执行拦截器2,执行拦截器2之后做放行,执行拦截器3,

         行拦截器3之后放行,执行action的方法。

  7、两个不同点:

    (1)action和Servlet的不同点:

        servlet:默认第一次访问servlet时创建,只创建一次,属于单实例对象。

        action:默认每次访问action都会创建,属于多实例对象。

    (2)过滤器和拦截器的不同:

        过滤器:理论上可以过滤任何内容。比如html、jsp、Servlet、文件路径等。

        拦截器:struts独有概念,只能过滤action。

二、自定义拦截器

  1、虽然在struts2里面已经封装了很多的过滤器,但是有时我们需要使用没有的拦截器,这时候就需要自己创建拦截器。

  2创建自定义拦截器的步骤:

    (1)先写一个类来继承MethodFilterInterceptor类。

    (2)重写该类的doIntercept方法。

    (3)在方法中写处理逻辑

    (4)如果成功则返回 invocation.invoke();

      (5)如果失败则返回要到的result标签中的name属性值。

    (6)在xml文件中注册该拦截器,将拦截器和action关联起来。

  3、示例:

    (1)首先写一个登录的页面和action方法。

页面:login.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib uri="/struts-tags" prefix="s"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>登录</h1>
    <form action="${pageContext.request.contextPath}/demo_login.action" method="post">
        username:<input name="username"><br/>
        password:<input name="password"><br/>
        <br/>
        <input type="submit" value="提交">
    </form>
</body>
</html>

action:

public String login(){
        
        HttpServletRequest request =ServletActionContext.getRequest();
        String name =request.getParameter("username");
        String pwd =request.getParameter("password");
        
        if("admin".equals(name) && "123".equals(pwd)){
            //将username放到session中保持登录的状态,在拦截器中通过该session判断是否登录
            request.getSession().setAttribute("username", name);
            return "loginsucess";
        }else{
            return "login";
        }
    }

    (2)在写一个登录成功的页面

success.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
    <%--要使用struts2标签,必须要引入struts2标签库 --%>
<%@ taglib uri="/struts-tags" prefix="s"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
    <h1>用户名:${sessionScope.username}</h1>
    <%--跳转Action,验证拦截器 --%>
    <a href="${pageContext.request.contextPath}/demo_add.action">添加</a>
</body>
</html>

    (3)在写一个增加的页面和action方法

add.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
    <%--要使用struts2标签,必须要引入struts2标签库 --%>
<%@ taglib uri="/struts-tags" prefix="s"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>添加</h1>
    <input type="text" name="username"><br/>
    <input type="password" name="password"><br/>
    <input type="submit" value="提交">
</body>
</h

action

public String add(){
            
            HttpServletRequest request =ServletActionContext.getRequest();
            String name =request.getParameter("username");
            String pwd =request.getParameter("password");
            
            return "add";
        }

    (4)写拦截器

//自定义拦截器,继承MethodFilterInterceptor类
//拦截器只能拦截action
public class LoginInterpret extends MethodFilterInterceptor{

    //2重写doIntercept方法
    protected String doIntercept(ActionInvocation invocation) throws Exception {
    
        //3写内部逻辑
        HttpServletRequest request =ServletActionContext.getRequest();
        
        Object object = request.getSession().getAttribute("username");
        
        if(object != null){
            //通过拦截器
            return invocation.invoke();
        }
        //不通过,返回值写xml配置文件中的result里面的值
        return "login";
        
    }
    

}

    (5)注册拦截器

    (6)配置拦截器不拦截的方法

<struts>
        <package name="ValueStackDemoAction" extends="struts-default" namespace="/">
           <!-- 
                   声明拦截器
                   name:拦截器的个名称,自定义
                   class:拦截器类的全路径
            -->
           <interceptors>
               <interceptor name="logininterceptor" class="com.jack.interpret.LoginInterpret"></interceptor>
           </interceptors>
            
            <action name="demo_*" class="com.jack.value.ValueStackDemoAction" method="{1}">
              <!-- 
                      2使用声明的拦截器
                      name:上一步声明中的name属性值
               -->
              <interceptor-ref name="logininterceptor">
                  <!-- 
                          3不予拦截的方法
                          name:固定值:excludeMethods
                          值:Action中不予拦截的方法名称
                   -->
                  <param name="excludeMethods">login</param>
              </interceptor-ref>
               
                <result name="loginsucess">/jsp/success.jsp</result>
                <result name="login">/jsp/login.jsp</result>
                <result name="add">/jsp/add.jsp</result>
            </action>
        </package>
    </struts>

三、struts2的标签

1表单标签

<%--struts2标签只能用在jsp中,不能在html中使用 --%>
    
    <%--表单标签 --%>
    <s:form action="" method="" enctype="" target="" theme="">
        <%--普通文本标签 --%>
        <s:textfield name="name" label="用户名"></s:textfield>
        <%--密码标签--%>
        <s:password name="password" label="密码"></s:password>
        <%--1、单选标签     value属性值和显示值一致 --%>
        <s:radio list="{'男','女'}" name="sex" label="性别"></s:radio>
        <%--2、单选标签     value属性值和显示值不一致 --%>
        <s:radio list="#{'0':'男','1':'女'}" name="sex1" label="性别"></s:radio>
        <%--1 多选标签 --%>
        <s:checkboxlist list="{'吃饭','睡觉','玩手机'}" name="aihao" label="爱好"></s:checkboxlist>
        <%--2 多选标签 --%>
        <s:checkboxlist list="#{'0':'吃饭','1':'睡觉','2':'玩手机'}" name="aihao1" label="爱好"></s:checkboxlist>
        <%--1下拉框标签 --%>
        <s:select list="{'初中','高中','大专','本科'}" name="college" label="学历"></s:select>
        <%--2下拉框标签 --%>
        <s:select list="#{'1':'初中','2':'高中','3':'大专','4':'本科'}" name="college1" label="学历"></s:select>
        <%--文件标签 --%>
        <s:file name="file" label="文件上传"></s:file>
        <%--隐藏标签 --%>
        <s:hidden name="hidden" value="隐藏项"></s:hidden>
        <%--文本域标签 --%>
        <s:textarea name="jianli" label="简介"></s:textarea>
        <%--提交标签 --%>
        <s:submit name="submit" label="提交"></s:submit>
        <%--重置标签 --%>
        <s:reset name="set" label="重置"></s:reset>
    </s:form>

2、控制标签<s:if>、<s:elseif>、<s:else>标签

<s:if test="表达式一">
        标签体
    </s:if>
    <s:elseif test="表达式二">
        标签体
    </s:elseif>
    <s:else>
        标签体
    </s:else>
posted @ 2017-06-10 15:48  一条路上的咸鱼  阅读(788)  评论(0编辑  收藏  举报