亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

spring mvc 源碼要點1

發布時間:2020-07-07 13:49:10 來源:網絡 閱讀:457 作者:zzhuwanpeng 欄目:開發技術
  1. 前置 : 版本4.1.2

  2. 請求如何定位到對應的處理方法?

    a. 入口   DispatcherServlet的 doService方法      

            doDispatch(request, response);

        b.   解析路徑

    protected void doDispatch(HttpServletRequest request, HttpServletResponse response) throws Exception {
        HttpServletRequest processedRequest = request;
        HandlerExecutionChain mappedHandler = null;
        boolean multipartRequestParsed = false;

        WebAsyncManager asyncManager = WebAsyncUtils.getAsyncManager(request);

        try {
            ModelAndView mv = null;
            Exception dispatchException = null;

            try {
                processedRequest = checkMultipart(request);
                multipartRequestParsed = (processedRequest != request);

                // Determine handler for the current request.
                mappedHandler = getHandler(processedRequest);               ----------------步驟1
                if (mappedHandler == null || mappedHandler.getHandler() == null) {
                    noHandlerFound(processedRequest, response);
                    return;
                }

                // Determine handler adapter for the current request.
                HandlerAdapter ha = getHandlerAdapter(mappedHandler.getHandler());   ---------步驟2

                // Process last-modified header, if supported by the handler.
                String method = request.getMethod();
                boolean isGet = "GET".equals(method);
                if (isGet || "HEAD".equals(method)) {
                    long lastModified = ha.getLastModified(request, mappedHandler.getHandler());
                    if (logger.isDebugEnabled()) {
                        logger.debug("Last-Modified value for [" + getRequestUri(request) + "] is: " + lastModified);
                    }
                    if (new ServletWebRequest(request, response).checkNotModified(lastModified) && isGet) {
                        return;
                    }
                }

                if (!mappedHandler.applyPreHandle(processedRequest, response)) {
                    return;
                }

                // Actually invoke the handler.
                mv = ha.handle(processedRequest, response, mappedHandler.getHandler());   -----  步驟3

                if (asyncManager.isConcurrentHandlingStarted()) {
                    return;
                }

                applyDefaultViewName(request, mv);
                mappedHandler.applyPostHandle(processedRequest, response, mv);
            }
            catch (Exception ex) {
                dispatchException = ex;
            }
            processDispatchResult(processedRequest, response, mappedHandler, mv, dispatchException);
        }
        catch (Exception ex) {
            triggerAfterCompletion(processedRequest, response, mappedHandler, ex);
        }
        catch (Error err) {
            triggerAfterCompletionWithError(processedRequest, response, mappedHandler, err);
        }
        finally {
            if (asyncManager.isConcurrentHandlingStarted()) {
                // Instead of postHandle and afterCompletion
                if (mappedHandler != null) {
                    mappedHandler.applyAfterConcurrentHandlingStarted(processedRequest, response);
                }
            }
            else {
                // Clean up any resources used by a multipart request.
                if (multipartRequestParsed) {
                    cleanupMultipart(processedRequest);
                }
            }
        }
    }

  步驟1,點入內部,最終在AbstractHandlerMethodMapping的lookupHandlerMethod找到匹配方法

                                先完整匹配url,不行則正則匹配

  注意步驟1中 返回的是HandlerExecutionChain , 在getHandler里同時也放入了攔截器鏈


 步驟2    找到合適的處理請求的適配器

              debug 得到是RequestMappingHandlerAdapter

 步驟3    RequestMappingHandlerAdapter的handler在AbstractHandlerMethodAdapter類種

             

    public final ModelAndView handle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
        return handleInternal(request, response, (HandlerMethod) handler);

      里面的復雜邏輯目前不關心,只關注如何調用實際的方法


3.   返回值的處理

       RequestMappingHandlerAdapter的invokeHandleMethod方法中,找到

     

requestMappingMethod.invokeAndHandle(webRequest, mavContainer);
        --》 進入
                 -- 》 Object returnValue = invokeForRequest(webRequest, mavContainer, providedArgs);

       這里方法里包含了我們在controller里寫的方法:

 

    public final Object invokeForRequest(NativeWebRequest request, ModelAndViewContainer mavContainer,
            Object... providedArgs) throws Exception {

        Object[] args = getMethodArgumentValues(request, mavContainer, providedArgs);
        if (logger.isTraceEnabled()) {
            StringBuilder sb = new StringBuilder("Invoking [");
            sb.append(getBeanType().getSimpleName()).append(".");
            sb.append(getMethod().getName()).append("] method with arguments ");
            sb.append(Arrays.asList(args));
            logger.trace(sb.toString());
        }
        Object returnValue = invoke(args);
        if (logger.isTraceEnabled()) {
            logger.trace("Method [" + getMethod().getName() + "] returned [" + returnValue + "]");
        }
        return returnValue;
    }

  回到invokeAndHandle方法,看這句話:

this.returnValueHandlers.handleReturnValue(returnValue, getReturnValueType(returnValue), mavContainer, webRequest);

  RequestResponseBodyMethodProcessor 負責處理


 

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

周至县| 方城县| 石棉县| 龙泉市| 崇义县| 扶沟县| 吉水县| 万全县| 深水埗区| 前郭尔| 陆良县| 永城市| 灵台县| 雅江县| 宁河县| 五莲县| 印江| 宜丰县| 阆中市| 循化| 郁南县| 宁安市| 昌乐县| 特克斯县| 饶阳县| 抚远县| 柏乡县| 伊吾县| 丁青县| 都江堰市| 潮安县| 浠水县| 兰考县| 清河县| 贵德县| 定安县| 上高县| 惠水县| 德州市| 会理县| 米脂县|