Java使用拦截器的方式(代码详细步骤)

本文介绍如何在SpringMVC项目中实现登录拦截器,包括配置拦截器及编写相关逻辑代码,确保未登录用户无法访问受保护资源。

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

博主自己写的小demo微信支付有兴趣的可以看一下

https://blog.youkuaiyun.com/weixin_39592397/article/details/85242287

1.先在springmvc_servlet.xml中配置拦截器

<mvc:interceptors>
<!-- 按照配置的顺序执行 -->

<mvc:interceptor>

//**是拦截所有请求  注意:拦截器只会拦截你的action请求。如果也想拦截jsp请求就用过滤器

<mvc:mapping path="/**"/>
<bean class="你的拦截器的class类"></bean>
</mvc:interceptor>

</mvc:interceptors>

2.在类中编写如下代码 我这个是登录案例

package com.demand.util;


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


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


public class LoginInterceptor implements HandlerInterceptor{

       //该方法在进入Handler方法执行之前执行此方法

       //应用场景:如身份认证,身份授权。

public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception {
}

       //该方法在进入Handler方法之后,返回ModelAndView之前执行

       //应用场景从modelAndView出发,将公用模型数据(如菜单导航)在这里传到视图,也可以在这里统一制定视图

public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
throws Exception {
// TODO Auto-generated method stub
}

  //该方法在handler方法执行完之后执行

 //应用场景:统一日志处理,统一异常处理

public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception {

//return true;

        //获取登录请求的路径

String uri = request.getRequestURL().toString();

        //判断请求中是否包含login 如果包含就放行 return true 否则就return false 拦截

    if(uri.contains("login")||uri.contains("inputInfo")) {
  return true;
}
// a)拦截用户请求,判断用户是否登录
HttpSession session = request.getSession();
Object username = session.getAttribute("user");
if (username != null) {
// b)如果用户已经登录。放行
return true;
}
response.sendRedirect(request.getContextPath() + "/login/index.action");
return false;
}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值