您好,登錄后才能下訂單哦!
這篇文章主要講解了“如何使用Spring的攔截器監(jiān)測(cè)每個(gè)Controller或方法的執(zhí)行時(shí)長(zhǎng)”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“如何使用Spring的攔截器監(jiān)測(cè)每個(gè)Controller或方法的執(zhí)行時(shí)長(zhǎng)”吧!
Spring攔截器監(jiān)測(cè)每個(gè)Controller或方法的執(zhí)行時(shí)長(zhǎng)
首先寫(xiě)一個(gè)類(lèi)(TestInterceptor)
接下來(lái)是spring配置文件
攔截器三個(gè)方法的執(zhí)行時(shí)機(jī)
攔截器三個(gè)方法分別是
讓他繼承HandlerInterceptorAdapter,并重寫(xiě)其中的三個(gè)方法,例如:
package com.wechat.test; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.web.servlet.ModelAndView; import org.springframework.web.servlet.handler.HandlerInterceptorAdapter; import java.util.Calendar; import java.util.Date; /** * Created by lenovo on 2017/3/14. */ public class TestInterceptor extends HandlerInterceptorAdapter { private long time; private int openingTime; private int closingTime; private String mappingURL;//利用正則映射到需要攔截的路徑 public void setOpeningTime(int openingTime) { this.openingTime = openingTime; } public void setClosingTime(int closingTime) { this.closingTime = closingTime; } public void setMappingURL(String mappingURL) { this.mappingURL = mappingURL; } /** * 1.進(jìn)入Controller方法之前執(zhí)行 * @param request * @param response * @param handler * @return 返回值為true時(shí)可繼續(xù)執(zhí)行Controller,preHandle()和afterCompletion(),為false時(shí)停止執(zhí)行任何方法。 * @throws Exception */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { time = System.currentTimeMillis(); String url=request.getRequestURL().toString(); if(mappingURL==null || url.matches(mappingURL)){ Calendar c=Calendar.getInstance(); c.setTime(new Date()); int now=c.get(Calendar.HOUR_OF_DAY); if(now<openingTime || now>closingTime){ request.setAttribute("msg", "注冊(cè)開(kāi)放時(shí)間:" + openingTime + ":00-" + closingTime + ":00"); // request.getRequestDispatcher("/msg.jsp").forward(request, response); return false; } return true; } return true; } /** * 2.Controller方法執(zhí)行完畢但是未進(jìn)行視圖渲染時(shí)執(zhí)行 * @param request * @param response * @param handler * @param modelAndView * @throws Exception */ @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { super.postHandle(request, response, handler, modelAndView); } /** * 3.視圖渲染完成(整個(gè)請(qǐng)求結(jié)束)執(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("請(qǐng)求處理完成啦!用時(shí):"+(System.currentTimeMillis() - time)+"ms"); super.afterCompletion(request, response, handler, ex); } }
<!--攔截器--> <mvc:interceptors> <mvc:interceptor> <!--配置哪些請(qǐng)求會(huì)攔截--> <mvc:mapping path="/**"/> <bean class="com.wechat.test.TestInterceptor"> <!--為這個(gè)類(lèi)中的參數(shù)寫(xiě)入值--> <property name="openingTime" value="16" /> <property name="closingTime" value="18" /> <property name="mappingURL" value=".*/index" /> </bean> </mvc:interceptor> </mvc:interceptors>
1. preHandle
預(yù)處理回調(diào)方法,實(shí)現(xiàn)處理器的預(yù)處理(如登錄檢查),第三個(gè)參數(shù)為響應(yīng)的處理器(如具體的Controller實(shí)現(xiàn));
返回值:true表示繼續(xù)流程(如調(diào)用下一個(gè)攔截器或處理器);false表示流程中斷(如登錄檢查失敗),不會(huì)繼續(xù)調(diào)用其他的攔截器或處理器,此時(shí)我們需要通過(guò)response來(lái)產(chǎn)生響應(yīng);
2. postHandle
后處理回調(diào)方法,實(shí)現(xiàn)處理器的后處理(但在渲染視圖之前),此時(shí)我們可以通過(guò)modelAndView(模型和視圖對(duì)象)對(duì)模型數(shù)據(jù)進(jìn)行處理或?qū)σ晥D進(jìn)行處理,modelAndView也可能為null。
3. afterCompletion
整個(gè)請(qǐng)求處理完畢回調(diào)方法,即在視圖渲染完畢時(shí)回調(diào),如性能監(jiān)控中我們可以在此記錄結(jié)束時(shí)間并輸出消耗時(shí)間,還可以進(jìn)行一些資源清理,類(lèi)似于try-catch-finally中的finally,但僅調(diào)用處理器執(zhí)行鏈中preHandle返回true的攔截器的afterCompletion.
首先用戶(hù)請(qǐng)求到達(dá)前端控制器 DispatcherServlet,前端控制器找到處理器映射器,根據(jù)請(qǐng)求的方法找到對(duì)應(yīng)的處理器handler,生成攔截器和handler執(zhí)行順序的執(zhí)行鏈,交給DispatcherServlet,
dispatcherServlet找到對(duì)應(yīng)的處理器適配器進(jìn)行處理.
prehandler在請(qǐng)求處理之前執(zhí)行.該方法的返回值是布爾值 Boolean 類(lèi)型的,當(dāng)它返回為 false 時(shí),表示請(qǐng)求結(jié)束,后續(xù)的 Interceptor 和 Controller 都不會(huì)再執(zhí)行;當(dāng)返回值為 true 時(shí),就會(huì)繼續(xù)調(diào)用下一個(gè) Interceptor 的 preHandle 方法,如果已經(jīng)是最后一個(gè) Interceptor 的時(shí)候,就會(huì)是調(diào)用當(dāng)前請(qǐng)求的 Controller 中的方法。
postHandler 方法在當(dāng)前請(qǐng)求進(jìn)行處理之后,也就是在 Controller 中的方法調(diào)用之后執(zhí)行,但是它會(huì)在 DispatcherServlet 進(jìn)行視圖返回渲染之前被調(diào)用,所以我們可以在這個(gè)方法中對(duì) Controller 處理之后的 ModelAndView 對(duì)象進(jìn)行操作。
afterCompletion該方法將在整個(gè)請(qǐng)求結(jié)束之后,也就是在 DispatcherServlet 渲染了對(duì)應(yīng)的視圖之后執(zhí)行,這個(gè)方法的主要作用是用于進(jìn)行資源清理的工作。像異常處理資源釋放會(huì)放在這一步.
多個(gè)攔截器的執(zhí)行順序是: 攔截器A的preHandler-->攔截器B的preHandler-->B的postHandler-->A的postHandler-->B的afterCompletion-->A的afterCompletion
感謝各位的閱讀,以上就是“如何使用Spring的攔截器監(jiān)測(cè)每個(gè)Controller或方法的執(zhí)行時(shí)長(zhǎng)”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)如何使用Spring的攔截器監(jiān)測(cè)每個(gè)Controller或方法的執(zhí)行時(shí)長(zhǎng)這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。