拦截器对session验证的实现

本文介绍如何在Struts2框架中实现自定义拦截器,通过示例代码展示拦截器的具体实现方式及其配置方法。文章还展示了如何根据不同场景使用拦截器进行权限验证。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

自定义一个拦截器

package com.Hanb.fly.interceptor;

import java.util.Map;

import com.Hanb.fly.model.User;
import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor;

public class AuthorInterceptor implements Interceptor {

	@Override
	public void destroy() {
		// TODO Auto-generated method stub

	}

	@Override
	public void init() {
		// TODO Auto-generated method stub

	}

	@Override
	public String intercept(ActionInvocation actionInvocation) throws Exception {
		// TODO Auto-generated method stub
		Map session=actionInvocation.getInvocationContext().getSession();
		User user=(User)session.get("user");
		if(user==null)
		{
		System.out.println("拦截器起作用1");
		return Action.INPUT;
		}
		else
		{
		System.out.println("拦截器起作用2");
	    return actionInvocation.invoke();
		}
	}

}

在struts中配置拦截器

<?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="inter" extends="struts-default">

	<interceptors>

    <interceptor name="authenticationInterceptor" 

class="com.Hanb.fly.interceptor.AuthorInterceptor" />

    <interceptor-stack name="myStack">

      <interceptor-ref name="authenticationInterceptor" />

      <interceptor-ref name="defaultStack" />

    </interceptor-stack>

  </interceptors>

	    <action name="login" class="com.Hanb.fly.action.LoginAction" method="check">
	    	<result>/index1.jsp</result>
	    	<result name="input">/index2.jsp</result>
		</action>
	    <action name="show" class="com.Hanb.fly.action.LoginAction" method="show">
	    	<result>/index1.jsp</result>
	    	<result name="input">/error.jsp</result>
	    	<interceptor-ref name="myStack"></interceptor-ref>
		</action>
  </package>
</struts>
index.jsp为登录页面,登录成功,在session中设置user,并跳转到index1.jsp

若失败,跳转到index2.jsp。

当请求show.action时,若session中没有设置user,即没有登录,拦截器将返回input,页面跳转入error.jsp。若session中设置user了,拦截器将请求放给show.action。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值