您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關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的配置文件中配置攔截器(攔截的請求地址,放行的請求地址);
<!-- 配置springmvc攔截器--> <mvc:interceptors> <mvc:interceptor> <!-- 定義需要攔截的請求;/**:表示以/開頭的任意控制層請求; /*:只能攔截一個/的請求--> <mvc:mapping path="/**"/> <!-- 定義不攔截的請求--> <mvc:exclude-mapping path="/admin/login"/> <!-- 配置攔截類--> <bean id="loginInterceptor" class="aop.LoginInterceptor"></bean> </mvc:interceptor> </mvc:interceptors>
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目錄 }
基于ssm框架實現springmvc攔截器的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。