拦截器是Struts2最强大的特性之一,它是一种可以让用户在Action执行之前和Result执行之后进行一些功能处理的机制。

  说到拦截器interceptor,就会想到过滤器filter:

  过滤器filter是对所有的东西进行过滤,包括.css,.js,.jpg等这些内容都过滤;

  拦截器interceptor是对action进行拦截,是属于struts的工具。

这里以实现登录验证为例来进行拦截器的使用

首先创建一个Login类:

package com.dao;

public class Login {
private String username;
private String password;
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;
}
}

然后配置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> <constant name="struts.enable.DynamicMethodInvocation" value="false" />
<constant name="struts.devMode" value="false" /> <package name="default" namespace="/" extends="struts-default">
<interceptors>
<interceptor name="myin" class="com.util.Interceptor"></interceptor>
<interceptor name="login" class="com.util.SuccessInterceptor"></interceptor>
<interceptor-stack name="newStack">
<interceptor-ref name="login"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors> <global-results>
<result name="nologin">/Login/login.jsp</result>
</global-results>
<action name="Login_login" class="com.controller.LoginAction" method="login">
<result>/Login/login.jsp</result>
</action>
<action name="Login_success" class="com.controller.LoginAction" method="success">
<result>/Login/success.jsp</result>
</action>
<action name="*_*" class="com.controller.{1}Action" method="{2}">
<interceptor-ref name="newStack"></interceptor-ref> <result>
{1}/{2}.jsp
</result>
</action>
</package> </struts>

配置LoginAction.java:

package com.controller;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map; import javax.servlet.http.HttpSession; import org.apache.struts2.ServletActionContext;
import org.apache.struts2.interceptor.SessionAware;
import org.apache.tomcat.jni.User; import com.dao.Login;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven; public class LoginAction extends ActionSupport implements ModelDriven<Login>,SessionAware {
private Map<String,Object> session ;
private Login user = new Login(); public String login(){
return SUCCESS;
}
public String success(){
java.util.List<String> uid = new ArrayList<String>();
uid.add("admin");
uid.add("zhangsan");
uid.add("lisi");
uid.add("wangwu");
ActionContext context=ActionContext.getContext();
session=context.getSession();
Object obj = session.get("user");
if(obj==null){ if(uid.contains(user.getUsername())){
session.put("user", user.getUsername());
return SUCCESS;
}
else{
return "nologin";
} }
else{
return SUCCESS;
} }
@Override
public void setSession(Map<String, Object> arg0) {
// TODO 自动生成的方法存根
this.session=arg0; }
@Override
public Login getModel() { return user;
}
}

配置SuccessInterceptor.java:

package com.util;

import java.util.Map;

import javax.servlet.http.HttpSession;

import org.apache.struts2.ServletActionContext;

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor; public class SuccessInterceptor extends AbstractInterceptor {
private Map<String,Object> session ;
@Override
public String intercept(ActionInvocation arg0) throws Exception {
System.out.println("asdasdas");
session= ActionContext.getContext().getSession();
if(session.get("user")==null){
return "nologin";
}
return arg0.invoke();
} }

实现login.jsp页面:

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!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=ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<h2>Login</h2>
<form action="Login_success">
username:<input type="text" name="username" ><br>
password:<input type="text" name="password" ><br>
<input type="submit" value="go" >
</form>
</body>
</html>

实现success.jsp页面:

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<!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=ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<h2>success</h2>
username:<s:property value="#session.user" /><br>
password:<s:property value="password" /> <s:debug></s:debug>
</body>
</html>

一、拦截器的配置

1.SuccessInterceptor.java文件为拦截器的配置,继承自AbstractInterceptor接口。

2.配置struts.xml文件

<package name="default" namespace="/" extends="struts-default">
<interceptors>
<interceptor name="myin" class="com.util.Interceptor"></interceptor>
<interceptor name="login" class="com.util.SuccessInterceptor"></interceptor>//自己定义的一个名为login的拦截器,调用自com.util.SuccessInterceptor
<interceptor-stack name="newStack">
<interceptor-ref name="login"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>//自定义一个名为newStack的拦截器,里面包含login的拦截器和defaultStack默认的拦截器
</interceptors> <global-results>
<result name="nologin">/Login/login.jsp</result>
</global-results>//通用走nologin的时候都走此处
<action name="Login_login" class="com.controller.LoginAction" method="login">
<result>/Login/login.jsp</result>
</action>
<action name="Login_success" class="com.controller.LoginAction" method="success">
<result>/Login/success.jsp</result>
</action>
<action name="*_*" class="com.controller.{1}Action" method="{2}">
<interceptor-ref name="newStack"></interceptor-ref> //调用自定义的拦截器 <result>
{1}/{2}.jsp
</result>
</action>
</package>

二、在拦截器中使用内置对象

1.ActionContext 获取Map.

2.ServletActionContext 获取HttpSession

3.实现SessionAware接口

这三种形式详见http://www.cnblogs.com/claricre/p/6548874.html

这样定义完毕后的登录并不完善,没有跳转404界面,以及没有验证用户名密码同时正确的情况,仅作为例子参考。

最新文章

  1. WP8下实现刮刮乐(橡皮擦)功能
  2. Qt 程序访问 sqlite 权限错误
  3. play for scala 在模板中格式化Date
  4. ruby语言是什么东西
  5. Android实现网络访问
  6. 小白日记25:kali渗透测试之提权(五)--利用配置不当提权
  7. openstack组件手动部署整合
  8. SQL Server FileStream优点与不足
  9. SAP自带的创建报表工具
  10. 谈谈单元測试之(二):測试工具 JUnit 3
  11. HDU 1312 Red and Black(DFS,板子题,详解,零基础教你代码实现DFS)
  12. 02基于注解开发SpringMVC项目(jar包,异步,request,参数传递,多选的接收,Model传参,map传参,model传参,ajax,重定向,时间日期转换)
  13. python安装第三方库的最简单方式
  14. js_ajax模拟form表单提交_多文件上传_支持单个删除
  15. C# 实现身份验证之WebApi篇
  16. linux OS与SQL修改时区,系统时间
  17. mysql Communication link failure, message from server: &quot;Can&#39;t get hostname for your address&quot;
  18. Haskell语言学习笔记(54)Data.Set
  19. 2018.10.05 NOIP模拟 阶乘(简单数论)
  20. asp.net简述WP开发模式

热门文章

  1. CentOS-语言设置
  2. 使用ErrorProvider组件验证文本框输入
  3. jQuery JavaScript Library v3.2.1
  4. java abstraction and encapsulation
  5. key directories in the linux file system
  6. 通过存储过程批量生成spool语句
  7. c3p0,dbcp和proxool
  8. oc中将CGRect、CGSize、CGPoint等结构体转换为字符串
  9. Keras预训练模型下载后保存路径
  10. CentOs 6.5设置使用私钥登录关闭ssh的密码登录修改ssh默认端口