如何基于ssm框架實現(xiàn)springmvc攔截器
Springmvc攔截器用來攔截Controller層請求,可以在Controller方法執(zhí)行前后做一些特定的業(yè)務(wù)邏輯處理。類似于AOP中的環(huán)繞通知。常用來做登錄攔截,權(quán)限控制等。
1)寫一個類,實現(xiàn)HandlerIntercept接口;
/** * 登錄攔截器 */ public class LoginInterceptor implements HandlerInterceptor { /** * 在控制層方法請求之前調(diào)用,返回一個boolean類型值 * 如果返回的true則放行,如果返回false,則不繼續(xù)往后執(zhí)行 * @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;//不繼續(xù)往后執(zhí)行 } return true; } /** * 在控制層方法執(zhí)行返回之后執(zhí)行,通常可以做一些全局的數(shù)據(jù)返回等 * @param request * @param response * @param handler * @param modelAndView 控制層方法返回的結(jié)果 * @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("獲取到控制層方法返回結(jié)果:"+modelAndView.getModelMap() +"view:"+modelAndView.getViewName()); } } /** * 視圖解析之后執(zhí)行,通常用來做一些清理工作 * @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)在控制層方法中寫登錄條件;
//在方法參數(shù)中定義HttpSession,HttpServletRequest,HttpServletResponse等對象,springmvc會自動注入該對象 @RequestMapping("/login") public String login(String account, String password, HttpSession session){ //根據(jù)用戶名查詢是否存在該用戶 Admin admin = adminService.selectByAccount(account); if (admin!=null && admin.getPassword().equals(password)){ //將用戶信息放入session session.setAttribute("admin",admin); return "redirect:list"; } return "/login.jsp";//以/開頭為絕對路徑,/對應(yīng)webapp目錄 }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- java開發(fā)SSM框架具有rest風(fēng)格的SpringMVC
- SpringMVC 整合SSM框架詳解
- Spring+SpringMVC+MyBatis整合實戰(zhàn)(SSM框架)
- SSM框架整合之Spring+SpringMVC+MyBatis實踐步驟
- ssm框架Springmvc文件上傳實現(xiàn)代碼詳解
- 使用IDEA搭建SSM框架的詳細教程(spring + springMVC +MyBatis)
- Java SSM框架(Spring+SpringMVC+MyBatis)搭建過程
- 一步步教你整合SSM框架(Spring MVC+Spring+MyBatis)詳細教程
- Spring MVC 擴展和 SSM 框架整合步驟詳解
相關(guān)文章
spring-boot-maven-plugin未指定版本導(dǎo)致的編譯錯誤問題
這篇文章主要介紹了spring-boot-maven-plugin未指定版本導(dǎo)致的編譯錯誤問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04SpringBoot使用token簡單鑒權(quán)的具體實現(xiàn)方法
這篇文章主要介紹了SpringBoot使用token簡單鑒權(quán)的具體實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11mybatis實現(xiàn)批量插入并返回主鍵(xml和注解兩種方法)
這篇文章主要介紹了mybatis實現(xiàn)批量插入并返回主鍵(xml和注解兩種方法),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12解決idea中@Data標(biāo)簽getset不起作用的問題
這篇文章主要介紹了解決idea中@Data標(biāo)簽getset不起作用的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02