`

Struts2 自定义拦截器实现权限验证

阅读更多
java代码
package com.zhy.framework.core.server.interceptor;

import java.util.Map;

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;

/**
* 该拦截器是校验用户是否登录
* @author zhy
*
*/
public class ValidateUserIsLoginInterceptor extends BaseInterceptor {

private static final long serialVersionUID = -424883620258961724L;

/**
*  1.通过invocation获取getInvocationContext,返回的是{@1}ActionContext实例
*    然后通过ActionContext就可以获取对应的session
*  2.invocation.getAction()获取的是request请求action实例,因此可以通过该实例
*  是那个action类的,来判断是否需要权限验证
*   
*/
public String intercept(ActionInvocation invocation) throws Exception {
//因为用户的信息都保存在session中,因此首先获取服务器端对应的session
ActionContext actionContext = invocation.getInvocationContext();
Map session = actionContext.getSession();

//对于登陆请求的action不需要进行sesion的校验,因此获取action
Object action = invocation.getAction();
boolean flag = validateSessionAction(action);
if(!flag){
return invocation.invoke();
}
//需要校验是否登录
Object user = session.get(USER);
if(user != null){
return invocation.invoke();
}else{
return LOGIN;
}
}

}


/**
* {@1}ActionContext介绍
*  前言: struts2 帮我们完成了将请求参数直接配置到action的字段中
*      但是有时我们需要直接获取请求的参数或是会话中的数据,或是直接对httpRequest和httpResponse操作
*      因此ActionContext的出现是必要的
*   首先看看ActionContext如何获取httpRequest中的参数
*   ActionContext context = ActionContext.getContext();
*   (注意:上面的context 是通过 return (ActionContext)actionContext.get();返回的
*   actionContext是一个static ThreadLocal actionContext = new ThreadLocal();)
*   Map params = context.getParameters();//获取请求参数,返回的是一个map
*   String paramValue = (String)params.get("paramName");//返回参数的值
*   (ActionContext内部维护了一个Map<String, Object> context,所有的session,parameters都是放到这个map里面的
*    这个context是在请求时生成的,并放到静态的额ThreadLocal中进行维护,ThreadLocal可以保证线程安全
*   )
*   接下来获取session
*   Map session = ActionContext.getContext().getSession();//返回请求的session,这个session是map类型的。
*   (因为struts2的所有请求(request),session参数都是放到一个context的map中维护的,所以需要依靠actionContext返回对应的paramter和session
*   )
*   如果想要获取原生的httpRequest怎么办?
*   使用ServletActionContext,该context是继承至ActionContext的
*   获取原生的HttpServletRequest
*   HttpServletRequest request = ServletActionContext.getRequest();
*   获取原生的HttpSession
*   HttpSession httpSession = request.getSession();
*  
*   实际开发中的选择(使用ActionContext还是ServletActionContext?)
*   对于这个问题应尽量使用ActionContext,降低对servlet的依赖。可以根据实际需要进行选择,
*   如果方便使用IOC的方式(通过struts2完成属性的注入),则使用ActionContext。如果没有使用IOC,那么只能
*   通过获取原生的HttpServletRequest   
*
* */

package com.zhy.framework.core.server.interceptor;

import com.opensymphony.xwork2.interceptor.AbstractInterceptor;

/**
* 自定义拦截器的基类
* @author zhy
*
*/
public abstract class BaseInterceptor extends AbstractInterceptor {

public static String[] notNeedValidateActions = {"LoginAction"};
//用户登录的session Key
public static final String USER="user";

//返回结果
public static final String LOGIN = "login";//表示需要登录

/**
* 校验action是否需要session验证
* @return true 需要
*         false 不需要
*/
public boolean validateSessionAction(Object action){
if(action instanceof Object){//真正环境时需要把Object替换成具体的action类
return false;
}else{
return true;
}
}

}

struts.xml中需要配置的
<interceptors> 
       <interceptor name="permission" class="com.zhy.framework.core.server.interceptor.ValidateUserIsLoginInterceptor" /> //声明自定义拦截器
       <interceptor-stack name="permissionStack"> 
              <interceptor-ref name="permission" /> 
              <interceptor-ref name="defaultStack" /> 
       </interceptor-stack> //定义拦截器栈
</interceptors>
指定默认拦截器使用自定义的拦截器栈
<default-interceptor-ref name="permissinStack"/> 
分享到:
评论

相关推荐

    使用struts2拦截器对登陆权限验证

    在Struts2中,拦截器(Interceptor)扮演着至关重要的角色,它允许开发者在动作执行前后插入自定义逻辑,如日志记录、权限验证等。在本案例中,我们将深入探讨如何使用Struts2拦截器实现登录权限验证,同时结合...

    struts2自定义拦截器配置心得

    Struts2自定义拦截器的配置是Struts2框架中一个非常重要的功能,它允许开发者在Action执行前后插入自定义的逻辑,以实现如权限验证、日志记录、性能监控等多种需求。以下是对标题和描述中涉及的知识点的详细说明: ...

    struts2 用拦截器 实现用户权限登录

    在添加自定义拦截器时,可以将其插入到默认拦截器栈中,也可以创建自定义的拦截器栈。 ### 五、测试与优化 完成上述步骤后,你可以通过访问受保护的URL来测试拦截器的效果。如果用户未登录,系统应重定向到登录页面...

    Struts2_自定义拦截器_用户权限验证

    总的来说,“Struts2_自定义拦截器_用户权限验证”项目旨在教授开发者如何在Struts2环境中创建自定义拦截器,以实现用户权限验证,同时展示如何控制Action间的跳转。通过这个实践,开发者能够更好地理解和运用Struts...

    struts2自定义拦截器

    在Struts2中,自定义拦截器是实现业务逻辑控制、数据验证、权限管理等功能的重要手段。下面将详细探讨如何在Struts2中实现自定义拦截器来完成权限拦截。 首先,我们需要了解Struts2拦截器的工作原理。拦截器是在...

    Struts2自定义拦截器

    在深入探讨自定义拦截器之前,我们先理解一下Struts2拦截器的基本概念。 拦截器(Interceptor)是基于Java的动态代理机制实现的,它可以拦截用户的请求,对请求进行预处理,并且在Action执行后进行后处理。通过在...

    JSP 开发之Struts2内建自定义拦截器.docx

    本文将深入探讨Struts2的内建自定义拦截器及其配置。 首先,让我们理解什么是拦截器。拦截器是基于AOP(面向切面编程)思想的,它们在Action调用前后执行,形成一个拦截器链。每个拦截器都可以执行特定的任务,并且...

    struts2拦截器实现权限控制

    不过,为了实现更复杂的权限控制,通常需要自定义拦截器来实现具体的业务逻辑,例如检查用户的角色、权限编码或者当前请求的资源是否在用户的权限范围内。 在开发过程中,可以结合使用Spring Security或Apache ...

    struts2自定义拦截器.pdf

    自定义拦截器是Struts2框架中扩展功能的重要手段,让我们深入探讨如何在Struts2中实现自定义拦截器。 首先,创建一个Web项目是基础步骤,这可以通过IDE如Eclipse或IntelliJ IDEA来完成。确保你的项目包含了Struts2...

    struts2的一个自定义拦截器小例子

    本示例将聚焦于如何在Struts2中实现一个自定义拦截器。 首先,我们需要了解拦截器在Struts2中的作用。拦截器是AOP(面向切面编程)的一个核心概念,它允许开发者在动作执行前后插入额外的逻辑,如日志记录、权限...

    基于ssh拦截器框架Struts2拦截器的登录验证实现

    SSH2 框架中的 Struts2 拦截器功能允许开发者在特定操作执行前或执行后进行自定义处理,例如登录验证、权限检查等。在本文中,我们将探讨如何使用 Struts2 的拦截器来实现登录验证功能。 首先,我们需要了解 Struts...

    自定义拦截器的实现以及拦截器的详细配置

    本篇文章将深入探讨如何实现自定义拦截器及其在Struts2中的详细配置。 首先,我们来了解自定义拦截器的基本步骤: 1. **创建拦截器类**:自定义拦截器需要继承Struts2提供的`Interceptor`接口或实现`intercept()`...

    自定义拦截器struts2源代码

    通过下载的源代码,你可以看到具体的实现细节,包括`struts2.xml`和`web.xml`的配置,以及自定义拦截器类的代码。通过阅读和理解这些代码,你可以更好地掌握Struts2拦截器的工作原理,并在实际项目中灵活运用。 ...

    Struts2_自定义拦截器

    自定义拦截器是扩展Struts2功能的重要手段,允许开发者根据项目需求实现特定的行为。 在Struts2中,拦截器是基于责任链模式实现的,它们按照注册的顺序依次执行。拦截器栈是Struts2中拦截器的集合,每个拦截器都...

    Struts2利用拦截器实现权限控制

    在`Struts2_Authority`压缩包文件中,可能包含了实现上述功能的示例代码,包括自定义拦截器的实现、配置文件以及相关的Action和视图文件,供开发者参考学习。通过深入理解和实践这些代码,可以更好地掌握在Struts2...

    struts2实现拦截器、

    本文将深入探讨如何使用Struts2实现拦截器,以及如何配置拦截器来实现用户权限拦截。 首先,我们需要了解拦截器的工作原理。在Struts2中,拦截器是基于Java的动态代理机制实现的,它们按照预定义的顺序形成一个拦截...

    struts2拦截器实现用户登录权限的验证

    Struts2框架提供了一种灵活的方式来实现这一功能:通过自定义拦截器来控制用户的访问权限。下面我们将详细介绍如何利用Struts2的拦截器来实现用户登录权限的验证。 #### 概念理解 - **拦截器(Interceptor)**:在...

    Struts2--自定义拦截器

    自定义拦截器是Struts2中的一个重要特性,允许我们扩展框架的功能,以实现诸如日志记录、权限检查、性能监控等通用任务。在本文中,我们将深入探讨如何创建和使用自定义拦截器。 首先,了解拦截器的基本概念。在...

Global site tag (gtag.js) - Google Analytics