Spring interceptor攔截器配置及用法解析
阿新 • • 發佈:2020-10-16
fifter、servlet、interceptor
fifter用來處理請求頭、請求引數、編碼的一些設定,然後轉交給servlet,處理業務,返回
servlet現在常用的spring,servlet攔截/到DispatcherServlet,交由spring管理
interceptor,servlet請求之後可以實現HandlerInterceptor做到preHandle、postHandle、afterCompletion在controller之前、之後、渲染之後
登陸
業務中常用的登陸、註冊,大部分用cookie、session來做,這時候就涉及到攔截判斷使用者是否登陸、是否有許可權?至此引出interceptor:
package com.bs.interceptor; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; import com.bs.controller.BaseController; import com.bs.entity.Member; public class LoginInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request,HttpServletResponse response,Object handler) throws Exception { Member member = BaseController.getMemberByCookie(request); System.out.println(member); if(member == null){ response.sendRedirect("/officialweb/login.html"); } return false; } @Override public void postHandle(HttpServletRequest request,Object handler,ModelAndView modelAndView) throws Exception { // TODO Auto-generated method stub } @Override public void afterCompletion(HttpServletRequest request,Exception ex) throws Exception { // TODO Auto-generated method stub } }
java程式碼如上,然後在servlet.xml中配置如下:
<!-- 攔截器 --> <!-- 多個攔截器,順序執行 --> <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**"/> <mvc:exclude-mapping path="/**/cloud/**" /> <mvc:exclude-mapping path="/**/login/**" /> <bean class="com.bs.interceptor.LoginInterceptor"></bean> </mvc:interceptor> </mvc:interceptors>
mvc:mapping攔截的path地址,mvc:exclude-mapping不攔截的path地址,比如一些登陸、註冊、驗證碼、和可以不登入操作的介面。
至此結束。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。