首页 > 编程语言 > 详细

利用spring框架提供的HandlerInterceptorAdapter,实现自定义拦截器

时间:2020-10-31 16:26:31      阅读:36      评论:0      收藏:0      [点我收藏+]
package com.utils;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
/**
 * @description 利用spring框架提供的HandlerInterceptorAdapter,实现自定义拦截器
 */
public class UserLoginInterceptorBySpring extends HandlerInterceptorAdapter {
    // 在业务处理器处理请求之前被调用
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        //把登录的用户名放到Session会话里,用户登录时通过获取会话username对象判断用户之前有没有登录系统
        String username = (String) request.getSession().getAttribute("username");
        if (null == username) {
            // 跳转到登录页面
            request.getRequestDispatcher("/login").forward(request, response);
            return false;
        } else {
            return true;
        }
    }

    // 在业务处理器处理请求完成之后,生成视图之前执行
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("postHandle...");

    }

    // 在DispatcherServlet完全处理完请求之后被调用,可用于清理资源
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("afterCompletion...");
    }
}

**********************
xml配置文件

    <mvc:interceptors>
        <mvc:interceptor>
            <!-- 定义拦截的路由,com.controller包下的所有Controller -->
            <mvc:mapping path="/**" />
            <mvc:exclude-mapping path="/login" />
            <mvc:exclude-mapping path="/reg" />
            <mvc:exclude-mapping path="/register" />
            <!-- 拦截方法 -->
            <bean class="com.utils.UserLoginInterceptorBySpring"/>
        </mvc:interceptor>
    </mvc:interceptors>


************************
//登录时的控制器
package com.controller;

import com.dao.Sys_userDAO;
import com.model.Sys_user;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;

/**
 * Create with IntelliJ iDEA.
 *
 * @Auther:哈
 * @Date:2020/9/23 9:30
 * 接收前端的用户名和密码,并进行判断,然后把用户名放到Session会话里
 */
@Controller
public class Login_checkController {

    @RequestMapping("/login")
    public String login(String userName, String nuse, HttpServletRequest req){
        String username = userName;//接收用户名
        String password = nuse;//接收密码
        Sys_user result = dao.loginCheck(username,password);//调用方法,校验用户名密码是否正确
       if (result!=null){
           req.getSession().setAttribute("username",username);//把用户名放到Session会话作用域中
            return "main";
       }else {
           return "redirect:/index.jsp";
       }
    }
}

利用spring框架提供的HandlerInterceptorAdapter,实现自定义拦截器

原文:https://www.cnblogs.com/beliveme/p/13906014.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!