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中,拦截器(Interceptor)扮演着至关重要的角色,它允许开发者在动作执行前后插入自定义逻辑,如日志记录、权限验证等。在本案例中,我们将深入探讨如何使用Struts2拦截器实现登录权限验证,同时结合...
Struts2自定义拦截器的配置是Struts2框架中一个非常重要的功能,它允许开发者在Action执行前后插入自定义的逻辑,以实现如权限验证、日志记录、性能监控等多种需求。以下是对标题和描述中涉及的知识点的详细说明: ...
在添加自定义拦截器时,可以将其插入到默认拦截器栈中,也可以创建自定义的拦截器栈。 ### 五、测试与优化 完成上述步骤后,你可以通过访问受保护的URL来测试拦截器的效果。如果用户未登录,系统应重定向到登录页面...
总的来说,“Struts2_自定义拦截器_用户权限验证”项目旨在教授开发者如何在Struts2环境中创建自定义拦截器,以实现用户权限验证,同时展示如何控制Action间的跳转。通过这个实践,开发者能够更好地理解和运用Struts...
在Struts2中,自定义拦截器是实现业务逻辑控制、数据验证、权限管理等功能的重要手段。下面将详细探讨如何在Struts2中实现自定义拦截器来完成权限拦截。 首先,我们需要了解Struts2拦截器的工作原理。拦截器是在...
在深入探讨自定义拦截器之前,我们先理解一下Struts2拦截器的基本概念。 拦截器(Interceptor)是基于Java的动态代理机制实现的,它可以拦截用户的请求,对请求进行预处理,并且在Action执行后进行后处理。通过在...
本文将深入探讨Struts2的内建自定义拦截器及其配置。 首先,让我们理解什么是拦截器。拦截器是基于AOP(面向切面编程)思想的,它们在Action调用前后执行,形成一个拦截器链。每个拦截器都可以执行特定的任务,并且...
不过,为了实现更复杂的权限控制,通常需要自定义拦截器来实现具体的业务逻辑,例如检查用户的角色、权限编码或者当前请求的资源是否在用户的权限范围内。 在开发过程中,可以结合使用Spring Security或Apache ...
自定义拦截器是Struts2框架中扩展功能的重要手段,让我们深入探讨如何在Struts2中实现自定义拦截器。 首先,创建一个Web项目是基础步骤,这可以通过IDE如Eclipse或IntelliJ IDEA来完成。确保你的项目包含了Struts2...
本示例将聚焦于如何在Struts2中实现一个自定义拦截器。 首先,我们需要了解拦截器在Struts2中的作用。拦截器是AOP(面向切面编程)的一个核心概念,它允许开发者在动作执行前后插入额外的逻辑,如日志记录、权限...
SSH2 框架中的 Struts2 拦截器功能允许开发者在特定操作执行前或执行后进行自定义处理,例如登录验证、权限检查等。在本文中,我们将探讨如何使用 Struts2 的拦截器来实现登录验证功能。 首先,我们需要了解 Struts...
本篇文章将深入探讨如何实现自定义拦截器及其在Struts2中的详细配置。 首先,我们来了解自定义拦截器的基本步骤: 1. **创建拦截器类**:自定义拦截器需要继承Struts2提供的`Interceptor`接口或实现`intercept()`...
通过下载的源代码,你可以看到具体的实现细节,包括`struts2.xml`和`web.xml`的配置,以及自定义拦截器类的代码。通过阅读和理解这些代码,你可以更好地掌握Struts2拦截器的工作原理,并在实际项目中灵活运用。 ...
自定义拦截器是扩展Struts2功能的重要手段,允许开发者根据项目需求实现特定的行为。 在Struts2中,拦截器是基于责任链模式实现的,它们按照注册的顺序依次执行。拦截器栈是Struts2中拦截器的集合,每个拦截器都...
在`Struts2_Authority`压缩包文件中,可能包含了实现上述功能的示例代码,包括自定义拦截器的实现、配置文件以及相关的Action和视图文件,供开发者参考学习。通过深入理解和实践这些代码,可以更好地掌握在Struts2...
本文将深入探讨如何使用Struts2实现拦截器,以及如何配置拦截器来实现用户权限拦截。 首先,我们需要了解拦截器的工作原理。在Struts2中,拦截器是基于Java的动态代理机制实现的,它们按照预定义的顺序形成一个拦截...
Struts2框架提供了一种灵活的方式来实现这一功能:通过自定义拦截器来控制用户的访问权限。下面我们将详细介绍如何利用Struts2的拦截器来实现用户登录权限的验证。 #### 概念理解 - **拦截器(Interceptor)**:在...
自定义拦截器是Struts2中的一个重要特性,允许我们扩展框架的功能,以实现诸如日志记录、权限检查、性能监控等通用任务。在本文中,我们将深入探讨如何创建和使用自定义拦截器。 首先,了解拦截器的基本概念。在...