spring mvc拦截器实现步骤

本文介绍了Spring MVC中实现拦截器的步骤,包括在spring mvc.xml配置文件中的设置,拦截器类的编写,以及controller层的登录处理逻辑。

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

1.spring mvc.xml里面配置:

	<mvc:interceptors>
		<!-- 多个拦截器 -->
		<mvc:interceptor>
		    <!-- 拦截所有的请求 -->
			<mvc:mapping path="/**"/>
			<bean class="...interceptor.Interceptor1"/>
		</mvc:interceptor> 
 	
	</mvc:interceptors>

2.拦截器类

 package com.itheima.springmvc.interceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

public class Interceptor1 implements HandlerInterceptor{

// Controller执行前调用此方法
// 返回true表示继续执行,返回false中止执行
// 这里可以加入登录校验、权限拦截等
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception {
	// TODO Auto-generated method stub
	System.out.println(" preHandle NO.1");
	String requestURI = request.getRequestURI();
	if(!requestURI.contains("/login")){
		String username = (String) request.getSession().getAttribute("USER_SESSION");
		//没有用户信息  未登录状态
		if(null == username){
			response.sendRedirect(request.getContextPath() + "/login.action");
			return false;
		}
	}
	return true;
}
// controller执行后但未返回视图前调用此方法
// 这里可在返回用户前对模型数据进行加工处理,比如这里加入公用信息以便页面显示
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
		throws Exception {
	// TODO Auto-generated method stub
	System.out.println("postHandle NO.2");
	
}
// controller执行后且视图返回后调用此方法
// 这里可得到执行controller时的异常信息
// 这里可记录操作日志
public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
		throws Exception {
	// TODO Auto-generated method stub
	System.out.println("afterCompletion  NO.3");
	
}

3.controller写登录:

 //去登陆的页面
@RequestMapping(value = "/login.action",method = RequestMethod.GET)
public String login(){
	return "login";
}

@RequestMapping(value = "/login.action",method = RequestMethod.POST)
public String login(String username,HttpSession httpSession){
	//登录的XML
	//登录成功
	//把用户信息存放到Session中
	//任务:自定义设置session的过期时间
	httpSession.setAttribute("USER_SESSION", username);
	return "redirect:/item/itemlist.action";
}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT莫染

✨ 您的星光,照亮代码星辰~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值