`
- 浏览:
112702 次
- 性别:
- 来自:
杭州
-
假设有一个web应用,就是简单的有一个简单的登陆页面和登陆成功页面。但是登陆成功页面只允许已经登陆的用户看到。在一个项目中,会有许多这种页面,只允许登陆之后的用户才能访问,如果在每个action中都写上检验用户是否已登陆将会编写大量的重复代码,所以可以定义一个拦截器用来验证用户是否已经登陆成功(通过检验sesison中user的值,前提是每个页面都通过一个action链接)
下面是定义一个拦截器类的方法
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
/**
* 通常我们自定义一个拦截器类需要实现Interceptor接口
* 这个接口中有三个方法void destroy();
void init();
String intercept(ActionInvocation invocation);
* 一般只需实现第三个接口即可
* 所以我们可以继承AbstractInterceptor类
* 这个类是实现了这三个接口,同时将第三个接口实现为抽象方法
*/
public class AuthenticationInterceptor extends AbstractInterceptor{
public String intercept(ActionInvocation invocation) throws Exception {
//判断session里user属性是否null
if(invocation.getInvocationContext().getSession().get("User")!=null){
//如果验证通过则继续程序的正常流程
return invocation.invoke();
}
else{
//如果验证失败,返回name为input的result
return "input";
}
}
}
在struts.xml中配置拦截器如下
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd" >
<struts>
<package name="default" extends="struts-default">
<interceptors>
<!--用户验证拦截器-->
<interceptor name="authentication" class="interceptor.AuthenticationInterceptor"/>
<!--定义一个带用户验证的拦截器栈-->
<interceptor-stack name="user">
<interceptor-ref name="authentication"/>
<interceptor-ref name="defaultStack"/>
</interceptor-stack>
</interceptors>
<!--全局result,登陆页面-->
<global-results>
<result name="input">index.jsp</result>
</global-results>
<!--根据表单提交数据判断用户是否是授权用户,通过则定向到欢迎aciton-->
<action name="login" class="action.LoginAction">
<result type="redirectAction">welcome</result>
</action>
<!--为登陆成功页面设置用户验证拦截器,防止非法访问-->
<action name="welcome" class="action.WelcomeAction">
<result>welcome.jsp</result>
<interceptor-ref name="user"/>
</action>
</package>
</struts>
下面是用户验证的action
import java.util.Map;
//引入action基础类
import com.opensymphony.xwork2.ActionSupport;
/**
* 该接口是一个声明性质接口,内部无任何内容
* 如果一个类实现了这个接口,在该类里定义一个Map型session变量
* 则类似控制反转,可以在需要的时候直接使用该变量作为当前session进行操作、
* 类似的还有ApplicationAware ParameterAware RequestAware ServletRequestAware ServletResponseAware
* 以后我会总结一篇关于这个的文章
*/
import org.apache.struts2.interceptor.SessionAware;
/**
*
* @author zhiweiv
*/
public class LoginAction extends ActionSupport implements SessionAware{
//对应表单的用户名
private String userName;
private Map session;
//省略set和get方法
@Override
public String execute() {
//模拟实现,假设用户名为zhiweiv则为认证用户
if (this.getUserName().equals("zhiweiv")){
//如果认证通过则将用户名存入session
this.getSession().put("User", userName);
return SUCCESS;
}
else{
//没认证通过则返回输入页面
return INPUT;
}
}
}
代码我传到csdn上了,是用netbeans6.5所写。
http://download.csdn.net/source/638901
分享到:
Global site tag (gtag.js) - Google Analytics
相关推荐
简单的struts2自定义拦截器 很适合web初学者
Struts2自定义拦截器的配置是Struts2框架中一个非常重要的功能,它允许开发者在Action执行前后插入自定义的逻辑,以实现如权限验证、日志记录、性能监控等多种需求。以下是对标题和描述中涉及的知识点的详细说明: ...
在深入探讨自定义拦截器之前,我们先理解一下Struts2拦截器的基本概念。 拦截器(Interceptor)是基于Java的动态代理机制实现的,它可以拦截用户的请求,对请求进行预处理,并且在Action执行后进行后处理。通过在...
自定义拦截器是Struts2框架中一个非常重要的特性,允许开发者扩展和定制框架的行为,以满足特定的业务需求。这篇博客文章可能是关于如何在Struts2中创建和使用自定义拦截器的教程。 在Struts2中,拦截器是基于责任...
Struts2自定义拦截器实现防止重复提交
自定义拦截器是Struts2框架中扩展功能的重要手段,让我们深入探讨如何在Struts2中实现自定义拦截器。 首先,创建一个Web项目是基础步骤,这可以通过IDE如Eclipse或IntelliJ IDEA来完成。确保你的项目包含了Struts2...
Struts2默认提供了一些拦截器来帮助处理这个问题,但如题目所述,由于性能考虑,项目组决定不使用Struts2的标签,因此需要自定义拦截器来实现防止重复提交的功能。 自定义拦截器的实现主要分为以下几个步骤: 1. *...
本文将深入探讨Struts2的内建自定义拦截器及其配置。 首先,让我们理解什么是拦截器。拦截器是基于AOP(面向切面编程)思想的,它们在Action调用前后执行,形成一个拦截器链。每个拦截器都可以执行特定的任务,并且...
在Struts2中,拦截器(Interceptor)扮演着至关重要的角色,它允许开发者在动作执行前后插入自定义逻辑,如日志记录、权限验证等。在本案例中,我们将深入探讨如何使用Struts2拦截器实现登录权限验证,同时结合...
"struts2自定义拦截器的示例代码" 以下是 Struts2 自定义拦截器的示例代码的知识点总结: Struts2 拦截器 소개 Struts2框架提供了拦截器机制,以便在Action执行前后进行拦截和处理。拦截器可以实现各种功能,如...
在这个实例中,我们将探讨如何创建一个自定义拦截器来处理未登录用户的非法请求。 首先,我们需要理解Struts2拦截器的工作原理。拦截器是基于Java的动态AOP(面向切面编程)实现的,它们按照配置的顺序组成一个链,...
自定义拦截器是Struts2中的一个重要特性,允许我们扩展框架的功能,以实现诸如日志记录、权限检查、性能监控等通用任务。在本文中,我们将深入探讨如何创建和使用自定义拦截器。 首先,了解拦截器的基本概念。在...
Struts2学习教程之拦截器机制与自定义拦截器 Struts2框架中,拦截器机制是其重要组成部分,不夸张的说,没有拦截器体系,也就没有这么好用的Struts2框架了。在Struts2框架中,大量的拦截器完成了很多基础的功能,...
本示例将聚焦于如何在Struts2中实现一个自定义拦截器。 首先,我们需要了解拦截器在Struts2中的作用。拦截器是AOP(面向切面编程)的一个核心概念,它允许开发者在动作执行前后插入额外的逻辑,如日志记录、权限...
本项目“Struts2_自定义拦截器_用户权限验证”将深入探讨如何在Eclipse开发环境中,利用Struts2框架自定义拦截器进行用户权限的验证,并处理各个Action之间的跳转。 首先,我们来看自定义拦截器的创建。在Struts2中...
在这个"struts2的自定义拦截器例子"中,我们将深入探讨如何创建和使用自定义拦截器。 首先,拦截器的本质是Java的面向切面编程(AOP)思想在Struts2中的体现。它们允许开发者在动作执行前后插入自定义的逻辑,例如...
本篇将深入讲解如何在Struts2中自定义拦截器,并通过提供的源代码进行分析。 拦截器是Struts2框架的核心组件之一,它允许我们在请求到达Action之前或离开Action之后执行一些额外的操作,如日志记录、权限验证、性能...
自定义拦截器是扩展Struts2功能的重要手段,允许开发者根据项目需求实现特定的行为。 在Struts2中,拦截器是基于责任链模式实现的,它们按照注册的顺序依次执行。拦截器栈是Struts2中拦截器的集合,每个拦截器都...