package com.huawei.util;
/**
* @ClassName: SessionNullInterceptor
* @Description: TODO(这里用一句话描述这个类的作用)
* @author A18ccms a18ccms_gmail_com
* @date 2010-11-3 下午04:30:10
* @name 何枫
*/
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.apache.struts2.StrutsStatics;
import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
/**
* session为空拦截器
*/
// LoginInterceptor类主要是实现用户的登录拦截,如果session中没有登录的用户名,
// 则将该用户的请求跳转到Action.LOGIN,如果用户已经登录,则执行return ai.invoke();,表示继续执行其他操作。
public class SessionNullInterceptor extends AbstractInterceptor
{
// 拦截Action处理的拦截
@Override
public String intercept(ActionInvocation invocation) throws Exception
{
// 取得请求有联系的ActionContext举例
ActionContext ctx = invocation.getInvocationContext();
Map session = ctx.getSession();
// 取出名为user的session属性
Object obj = session.get("login");
// 假如没有登陆,或者登陆所有的用户名不正确,都返回重新登陆
if (obj != null)
{
System.out.println("拦截器:合法用户登录---");
return invocation.invoke();
}
// 没有登陆,将提示设置成一个的HttpServletRequest属性
HttpServletRequest request = (HttpServletRequest) ctx.get(StrutsStatics.HTTP_REQUEST);
request.setAttribute("loginFlag", "1");
System.out.println("拦截器:用户未登录---");
return Action.LOGIN;
}
}
/////////////////////////////////////////////////////////////////////////////////////////
//用户登录的Action
package com.huawei.action;
import java.util.Map;
import org.apache.struts2.convention.annotation.Action;
import org.apache.struts2.convention.annotation.Result;
import org.apache.struts2.convention.annotation.Results;
import org.apache.struts2.interceptor.SessionAware;
import com.huawei.daoImpl.StudentdaoImpl;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.validator.annotations.RequiredStringValidator;
@Results( {
@Result(name = com.opensymphony.xwork2.Action.SUCCESS, location = "/WEB-INF/content/index.jsp", type = "dispatcher"),
@Result(name = com.opensymphony.xwork2.Action.INPUT, location = "/loginform.jsp") })
public class LoginAction extends ActionSupport implements SessionAware {
private static final long serialVersionUID = 1L;
private String loginName;
private String password;
private String certCode;
private Map<String, Object> session;
// 创建一个对象
StudentdaoImpl stu = new StudentdaoImpl();
@Override
public String execute() throws Exception {
return certCode;
}
public String getCertCode() {
return certCode;
}
@RequiredStringValidator(message = "用户名不能为空!!!")
public String getLoginName() {
return loginName;
}
@RequiredStringValidator(message = "密码不能为空!!!")
public String getPassword() {
return password;
}
public Map<String, Object> getSession() {
return session;
}
@Action(value = "section_list")
public String list() {
String certCodeTemp = (String) session.get("certCode");
if (stu.CheckAccount(loginName, password)&& certCode.equals(certCodeTemp))
{
session.put("login", "login");
return SUCCESS;
}
addActionError("用户名或密码错误 Please try again!");
return INPUT;
}
public void setCertCode(String certCode) {
this.certCode = certCode;
}
public void setLoginName(String loginName) {
this.loginName = loginName;
}
public void setPassword(String password) {
this.password = password;
}
public void setSession(Map<String, Object> session) {
this.session = session;
}
}
////////////////////////////////////////////////////////////////////////////
//在拦截的Action中加入拦截器的注解就可以拦截
// 拦截器的注解
@InterceptorRefs( {
@InterceptorRef("authority"),
@InterceptorRef("defaultStack")
})
//////////////////////////////////////////////////////////////////////////
//struts2的配置文件struts.xml配置如下:
<struts>
<include file="struts-default.xml" />
<package name="struts-interceptor" namespace="/" extends="struts-default" >
<interceptors>
<interceptor name="authority"
class="com.huawei.util.SessionNullInterceptor" />
<interceptor-stack name="annotatedStack">
<interceptor-ref name="authority" />
<interceptor-ref name="defaultStack" />
</interceptor-stack>
</interceptors>
<!-- 定义默认拦截器 -->
<default-interceptor-ref name="mydefault" />
<!-- 定义全局处理结果 -->
<global-results>
<!-- 逻辑名为login的结果,映射到/login.jsp页面 -->
<result name="login">/loginform.jsp</result>
</global-results>
</package>
</struts>
分享到:
相关推荐
2. **拦截器链**:在Struts2中,多个拦截器可以形成一个拦截器链,每个拦截器按照定义的顺序依次执行。如果所有拦截器都允许Action执行,那么Action的结果将被传递到下一个拦截器,直到整个链执行完毕。 ### 二、...
在Struts2中,拦截器(Interceptors)扮演着核心角色,增强了框架的功能和灵活性。这篇文章将深入探讨Struts2拦截器的概念、工作原理以及如何在实际应用中使用它们。 **一、什么是Struts2拦截器** 拦截器是基于AOP...
Struts2拦截器(Interceptor) Struts2拦截器(Interceptor)
拦截器是Struts2框架的核心特性之一,它们扮演着处理请求、增强功能和实现业务逻辑的角色。在Struts2中,拦截器就像过滤器一样工作,通过链式调用在动作执行前后进行预处理和后处理。 首先,我们来理解一下拦截器的...
### Struts2拦截器详解 #### 一、Struts2拦截器概述 Struts2框架作为Java Web开发中的一种流行框架,其核心组件之一便是**拦截器**。拦截器不仅在Struts2中扮演着重要角色,更是整个框架灵活性与扩展性的基石。...
在Struts2中,拦截器(Interceptor)扮演着核心角色,它们允许开发者在Action执行前后插入自定义的逻辑,如日志、权限检查、事务管理等。现在我们将深入探讨Struts2的拦截器机制及其实例应用。 ### 一、Struts2拦截...
在这个“Struts2拦截器实现权限控制demo”中,我们将深入探讨如何利用拦截器来实现细粒度的用户权限管理。 首先,我们需要了解Struts2中的拦截器工作原理。拦截器是基于Java的动态代理模式实现的,它们按照配置的...
### Struts2拦截器的使用方法 #### 一、Struts2拦截器概述 Struts2框架中的拦截器(Interceptor)是一种重要的机制,用于在Action执行前后进行一系列处理,比如参数验证、数据预处理等。它能够帮助开发者更加灵活...
当请求到达控制器时,Struts2会依次调用这个栈中的拦截器,每个拦截器都有机会处理请求,然后决定是否将请求传递给下一个拦截器或直接返回响应。 创建一个简单的Struts2拦截器,你需要遵循以下步骤: 1. 创建拦截...
Struts2拦截器.ppt Struts2拦截器.ppt Struts2拦截器.ppt
拦截器是Struts2框架的核心组成部分,它们在请求处理流程中起到了关键的作用。在本文中,我们将深入探讨Struts2拦截器的工作原理。 ### 一、拦截器概念 拦截器是基于Java的动态代理机制实现的,它允许我们在Action...
拦截器是Struts2框架的一个重要组成部分,能够帮助开发者实现一些在请求处理前后执行的通用逻辑,如日志记录、权限验证、数据校验等。在本场景中,我们将探讨如何使用Struts2拦截器来实现对不文明字迹或者敏感词汇的...
拦截器是Struts2框架的核心组件之一,它允许开发者在动作执行前后插入自定义逻辑,实现如权限验证、日志记录、性能优化等多种功能。在"Struts2 拦截器注解"这个主题中,我们将深入探讨如何利用注解来简化拦截器的...
这篇博客“Struts2 拦截器的执行顺序(二十九)”可能探讨了Struts2拦截器链的工作原理和它们的执行顺序,这对于理解Struts2的内部机制至关重要。 首先,让我们深入理解Struts2的拦截器。拦截器是在Action调用前后...
这篇博客“struts2 拦截器实现登录控制”显然会探讨如何利用拦截器来实现用户登录验证,从而保护应用程序的受保护资源。 首先,我们了解下Struts2拦截器的工作原理。拦截器是基于AOP(面向切面编程)的概念,它位于...
### Struts2 拦截器与验证框架详解 #### 一、Struts2概述 Struts2是一个基于Java的企业级Web应用开发框架,它继承了Struts1的优点,并在此基础上进行了很多改进,使得开发更加灵活高效。Struts2的核心是拦截器...
在Struts2中,拦截器扮演着至关重要的角色,它们是实现MVC(Model-View-Controller)架构的关键组件之一。拦截器允许开发者在动作执行前后插入自定义逻辑,比如日志记录、权限检查、数据验证等,而无需修改核心业务...