如何基于ssm框架实现springmvc拦截器

网友投稿 246 2022-12-02


如何基于ssm框架实现springmvc拦截器

Springmvc拦截器用来拦截Controller层请求,可以在Controller方法执行前后做一些特定的业务逻辑处理。类似于AOP中的环绕通知。常用来做登录拦截,权限控制等。

1)写一个类,实现HandlerIntercept接口;

/**

* 登录拦截器

*/

public class LoginInterceptor implements HandlerInterceptor {

/**

* 在控制层方法请求之前调用,返回一个boolean类型值

* 如果返回的true则放行,如果返回false,则不继续往后执行

* @param request

* @param response

* @param handler

* @return

* @throws Exception

*/

@Override

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

String requestURI = request.getRequestURI();

System.out.println("拦截到请求:"+requestURI);

Admin admin = (Admin) request.getSession().getAttribute("admin");

//如果admin为空,说明没有登录

if (admin==null){

response.sendRedirect(request.getContextPath()+"/login.jsp");

return false;//不继续往后执行

}

return true;

}

/**

* 在控制层方法执行返回之后执行,通常可以做一些全局的数据返回等

* @param request

* @param response

* @param handler

* @param modelAndView 控制层方法返回的结果

* @throws Exception

*/

@Override

public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {

System.out.println("进入拦截器postHandle方法");

//ajax请求时,modelView为null

if (modelAndView!=null){

System.out.println("获取到控制层方法返回结果:"+modelAndView.getModelMap()

+"view:"+modelAndView.getViewName());

}

}

/**

* 视图解析之后执行,通常用来做一些清理工作

* @param request

* @param response

* @param handler

* @param ex

* @throws Exception

*/

@Override

public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {

System.out.println("进入afterCompletion方法");

}

}

2)在springmvc的配置文件中配置拦截器(拦截的请求地址,放行的请求地址);

3)在控制层方法中写登录条件;

//在方法参数中定义HttpSession,HttpServletRequest,HttpServletResponse等对象,springmvc会自动注入该对象

@RequestMapping("/login")

public String login(String account, String password, HttpSession session){

//根据用户名查询是否存在该用户

Admin admin = adminService.selectByAccount(account);

if (admin!=null && admin.getPassword().equals(password)){

//将用户信息放入session

session.setAttribute("admin",admin);

return "redirect:list";

}

return "/login.jsp";//以/开头为绝对路径,/对应webapp目录

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java Comparable及Comparator接口区别详解
下一篇:SpringBoot整合Redis正确的实现分布式锁的示例代码
相关文章

 发表评论

暂时没有评论,来抢沙发吧~