SpringMVC的處理攔截器相似於Servlet開發中的過濾器Filter,用於對處理器進行預處理和後處理。開發者能夠本身定義一些攔截器來實現攔截器實現特定的功能。css
自定義攔截器,必須實現HandleIntercepter接口html
添加web支持java
配置web.xml和springmvc-servlet.xml文件web
package com.star.config; import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class MyInterceptor implements HandlerInterceptor { //return true; 執行 //return false; 攔截 public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("===========執行前==========="); return false; } //執行後的日誌 無攔截做用 public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { System.out.println("===========執行後==========="); } //清理日誌 無攔截做用 public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { System.out.println("===========清理==========="); } }
package com.star.controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class ControllerTest { @RequestMapping("/t1") public String test(){ System.out.println("執行了test方法!"); return "OK!"; } }
<!--將攔截器注入容器--> <mvc:interceptors> <mvc:interceptor> <!--處理全部的請求--> <mvc:mapping path="/**"/> <bean class="com.star.config.MyInterceptor"/> </mvc:interceptor> </mvc:interceptors>
當咱們改成return fals時的結果:spring
能夠看到攔截器攔截了 /t1 這個請求即對應的test()方法!bootstrap
咱們設置一個未登陸的狀況下不能進入首頁的攔截器session
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>$Title$</title> <style type="text/css"> a { text-decoration: none; color: black; font-size: 18px; } h3 { width: 180px; height: 38px; margin: 100px auto; text-align: center; line-height: 38px; background: deepskyblue; border-radius: 4px; } </style> </head> <body> <h3> <a href="${pageContext.request.contextPath}/user/toLogin">點擊進入登陸頁面</a> </h3> <h3> <a href="${pageContext.request.contextPath}/user/main">點擊進入首頁</a> </h3> </body> </html>
package com.star.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import javax.servlet.http.HttpSession; @Controller @RequestMapping("/user") public class loginController { @RequestMapping("/main") public String main(){ return "main"; } @RequestMapping("/toLogin") public String toLogin(){ return "toLogin"; } }
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>首頁</title> <link href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"> <style type="text/css"> a { text-decoration: none; color: black; font-size: 18px; } h3 { width: 180px; height: 38px; margin: 100px auto; text-align: center; line-height: 38px; background: deepskyblue; border-radius: 4px; } </style> </head> <body> <div class="container"> <div class="row clearfix"> <div class="col-md-12 column"> <div class="page-header"> <h1> <small style="padding-left: 535px">首頁</small> </h1> </div> </div> </div> <span> <h3> <p>${usernameInfo}</p> </h3> </span> <h3> <a href="${pageContext.request.contextPath}/user/goOut">註銷用戶</a> </h3> </div> </body> </html>
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>登陸頁面</title> <link href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"> </head> <body> <div class="container"> <div class="row clearfix"> <div class="col-md-12 column"> <div class="page-header"> <h1> <small style="padding-left: 535px">登陸頁面</small> </h1> </div> </div> </div> <form action="${pageContext.request.contextPath}/user/login" method="post" style="padding-left: 300px; margin-top: 50px;" class="form-horizontal" role="form"> <div class="form-group"> <label class="col-sm-2 control-label">用戶名</label> <div class="col-sm-10"> <input type="text" class="form-control" style="width: 300px" name="username"> </div> </div> <div class="form-group"> <label class="col-sm-2 control-label">密碼</label> <div class="col-sm-10"> <input type="password" class="form-control" style="width: 300px" name="password"> </div> </div> <div class="form-group"> <div class="col-sm-offset-2 col-sm-10"> <div class="checkbox"> <label> <input type="checkbox"> 記住我 </label> </div> </div> </div> <div class="form-group"> <div class="col-sm-offset-2 col-sm-10"> <button style="width: 300px" type="submit" class="btn btn-primary">登陸</button> </div> </div> </form> </div> </body> </html>
@PostMapping("/login") public String login(String username, HttpSession session){ session.setAttribute("usernameInfo",username); return "redirect:/user/main"; }
@RequestMapping("/goOut") public String goOut(HttpSession session){ session.removeAttribute("usernameInfo"); return "redirect:/"; }
package com.star.config; import org.springframework.web.servlet.HandlerInterceptor; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; public class loginInterceptor implements HandlerInterceptor { public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { HttpSession session = request.getSession(); //有session信息即已經登陸了 不攔截 if(session.getAttribute("usernameInfo")!=null){ return true; } //請求路徑包含ogin的即/toLogin和/login 不攔截 if(request.getRequestURI().contains("ogin")){ return true; } //其餘狀況下重定向到登陸頁面 request.getRequestDispatcher("/user/toLogin").forward(request,response); return false; } }
<!--將攔截器注入容器--> <mvc:interceptors> <mvc:interceptor> <!--處理/user下的全部的請求--> <mvc:mapping path="/user/**"/> <bean class="com.star.config.loginInterceptor"/> </mvc:interceptor> </mvc:interceptors>
OK!測試登陸攔截功能無誤!架構