一、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>

Struts2拦截器和标签的更多相关文章

  1. Struts2拦截器总结

    拦截器的本质: 拦截器就是一个类,一个实现了超级接口Interceptor的类.Interceptor接口里定义了三个方法 init(),destory(),intercept().其中inercep ...

  2. 从struts2拦截器到自定义拦截器

    拦截器可谓struts2的核心了,最基本的bean的注入就是通过默认的拦截器实现的,一般在struts2.xml的配置中,package内直接或间接继承了struts-default.xml,这样st ...

  3. Struts2拦截器配置实例

    拦截器介绍 拦截器 的使用 ,源自Spring AOP(面向切面编程)思想 拦截器 采用 责任链 模式 * 在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链. * 责任链每一个节 ...

  4. struts2拦截器interceptor的配置方法及使用

    转: struts2拦截器interceptor的配置方法及使用 (2015-11-09 10:22:28) 转载▼ 标签: it 365 分类: Struts2  NormalText Code  ...

  5. Struts2拦截器详解

    一.Struts2拦截器原理: Struts2拦截器的实现原理相对简单,当请求struts2的action时,Struts 2会查找配置文件,并根据其配置实例化相对的    拦截器对象,然后串成一个列 ...

  6. Struts框架笔记04_拦截器_标签库

    目录 1. Struts2的拦截器 1.1 拦截器概述 1.2 拦截器的实现原理 1.3 Struts的执行流程 1.4 拦截器入门 1.4.1 环境搭建 1.4.2 编写拦截器 1.4.3 配置拦截 ...

  7. Struts2 拦截器配置以及实现

    @(Java ThirdParty)[Struts|Interceptor] Struts2 拦截器配置以及实现 Struts2的拦截器应用于Action,可以在执行Action的方法之前,之后或者两 ...

  8. struts2 拦截器

    拦截器:对Action的访问.可以拦截到Action中某个方法.与过滤器不同,过滤器过滤的是请求.过滤JSP.html.但是拦截器不能拦截jsp.html的访问. Struts2 拦截器在访问某个 A ...

  9. Struts2拦截器的使用 (详解)

    Struts2拦截器的使用 (详解) 如何使用struts2拦截器,或者自定义拦截器.特别注意,在使用拦截器的时候,在Action里面必须最后一定要引用struts2自带的拦截器缺省堆栈default ...

随机推荐

  1. ibatis 参数之 String

    <select id="query_cust_name" resultClass="_custForm" parameterClass="Str ...

  2. 为微软ContosoUniversity例子加上学生自选课程计划

    把ContosoUniversity例子过了一遍,好象还是有很多东西未能理解,决定自己随便加个功能看可以自己完成不.... 从github的例子中clone下来ContosoUniversity项目, ...

  3. [Maven实战-许晓斌]-[第二章]-2.2基于UNIX系统安装maven

    >> >> >>3  

  4. Access MongoDB Data with Entity Framework 6

    This article shows how to access MongoDB data using an Entity Framework code-first approach. Entity ...

  5. Ionic2的CLI的命令行

    http://blog.csdn.net/qq_33315185/article/details/68067747 在我们开发Ionic app的时候 CLI 是一个非常重要的工具.CLI包含了很多开 ...

  6. TCP的超时与重传

    一.引言 对于每个TCP连接,TCP管理4个不同的定时器 重传定时器用于当希望收到另一端的确认. 坚持 (persist) 定时器使窗口大小信息保持不断流动,即使另一端关闭了其接收窗口. 保活 (ke ...

  7. [转]Java 内存溢出(java.lang.OutOfMemoryError)的常见情况和处理方式总结

    原文地址: http://outofmemory.cn/c/java-outOfMemoryError java.lang.OutOfMemoryError这个错误我相信大部分开发人员都有遇到过,产生 ...

  8. supervisor 使用

    cat /etc/supervisord.conf https://www.cnblogs.com/yuzhoushenqi/p/6825204.html http://127.0.0.1:1001/ ...

  9. POJ1591 M*A*S*H (JAVA)

    这水题,真的坑 测试数据最后有空行,如果用sc.hasNextLine()判断,会RE 要改为sc.hasNext() 搞了我一上午,烦死 import java.util.*; public cla ...

  10. OpenFire 安装及配置

    下载 添加的属性为:EXE4J_JAVA_HOME,其属性的值为32位的JDK的所在位置.   2,openfire的启动路径中不能含有中文,好多java写的都是这个样.   3,如果安装的了 Jav ...