如何基于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風格的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-04
SpringBoot使用token簡單鑒權(quán)的具體實現(xiàn)方法
這篇文章主要介紹了SpringBoot使用token簡單鑒權(quán)的具體實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
mybatis實現(xiàn)批量插入并返回主鍵(xml和注解兩種方法)
這篇文章主要介紹了mybatis實現(xiàn)批量插入并返回主鍵(xml和注解兩種方法),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12

