激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

香港云服务器
服務器之家 - 編程語言 - Java教程 - springmvc處理異步請求的示例

springmvc處理異步請求的示例

2020-08-01 15:31liuxg2013 Java教程

這篇文章主要介紹了springmvc處理異步請求的示例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

springmvc 3.2開始就支持servlet3.0的異步請求。平常我們請求一個controller一般都是同步的,如果在代碼執行中,遇到耗時的業務操作,那servlet容器線程就會被鎖死,當有其他請求進來的時候就會受堵了。

springmvc3.2之后支持異步請求,能夠在controller中返回一個Callable或者DeferredResult。當返回Callable的時候,大概的執行過程如下:

  • 當controller返回值是Callable的時候,springmvc就會啟動一個線程將Callable交給TaskExecutor去處理
  • 然后DispatcherServlet還有所有的spring攔截器都退出主線程,然后把response保持打開的狀態
  • 當Callable執行結束之后,springmvc就會重新啟動分配一個request請求,然后DispatcherServlet就重新調用和處理Callable異步執行的返回結果,然后返回視圖

DeferredResult的執行過程和Callable差不多,唯一不同的時候,DeferredResult是由應用程序其他線程執行返回結果,而Callable是由TaskExecutor執行返回結果。

springmvc配置異步請求

1.需要在web.xml加上servlet3.0的scheme庫

?
1
2
3
4
5
6
7
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
version="3.0">
...
</web-app>

2.在web.xml的servlet還有filter添加<asyncsupported>true</async-supported>子節點

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<!-- springMVC的Servlet配置 -->
<servlet>
  <servlet-name>dispatcher</servlet-name>
  <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  <init-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath*:META-INF/dispatcher-context.xml</param-value>
  </init-param>
  <load-on-startup>1</load-on-startup>
  <async-supported>true</async-supported>
</servlet>
 
<!-- 編碼攔截 -->
<filter>
  <filter-name>CharacterEncodingFilter</filter-name>
  <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
  <async-supported>true</async-supported>
  <init-param>
    <param-name>encoding</param-name>
    <param-value>UTF-8</param-value>
  </init-param>
  <init-param>
    <param-name>forceEncoding</param-name>
    <param-value>true</param-value>
  </init-param>
</filter>

3.然后就可以在controller中執行異步請求了

利用Callable執行異步請求,并返回視圖

?
1
2
3
4
5
6
7
8
9
10
11
12
@RequestMapping("/mvc25")
public Callable<String> mvc25() {
 
  return new Callable<String>() {
    @Override
    public String call() throws Exception {
       Thread.sleep(2000);
       return "task/task";
    }
  };
 
}

利用Callable執行異步請求,并把請求結果通過@response由httpmessageconverter進行轉化返回客戶端

?
1
2
3
4
5
6
7
8
9
10
11
12
13
@RequestMapping("/mvc26")
@ResponseBody
public Callable<String> mvc26() {
 
  return new Callable<String>() {
    @Override
    public String call() throws Exception {
      Thread.sleep(2000);
      return "hello task";
    }
  };
 
}

可以自定義客戶端超時間

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
@RequestMapping("/mvc27")
@ResponseBody
public WebAsyncTask<String> mvc27() {
 
  Callable<String> callable = new Callable<String>() {
    @Override
    public String call() throws Exception {
      Thread.sleep(10000);
      return "hello task";
    }
  };
 
  return new WebAsyncTask<String>(10000, callable);
}

如果在線程的執行過程中,遇到異常,處理過程和普通請求的一樣,你可以用@ExceptionHandler來處理或者定義全局的HandlerExceptionResolver來處理

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
@RequestMapping("/mvc28")
@ResponseBody
public Callable<String> mvc28() {
 
  Callable<String> callable = new Callable<String>() {
    @Override
    public String call() throws Exception {
      Thread.sleep(2000);
      throw new RuntimeException();
    }
  };
 
  return callable;
 
}
 
@ExceptionHandler(RuntimeException.class)
@ResponseBody
public JSONObject handlerException(){
 
  JSONObject jsonObject = new JSONObject();
  jsonObject.put("aaa", 123);
 
  return jsonObject ;
}

還可以通過返回DeferredResult返回,DeferredResult的作用是返回一個實例給其他線程來處理這個異步請求。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
@RequestMapping("/mvc29")
@ResponseBody
public DeferredResult<String> mvc29() {
 
  DeferredResult<String> deferredResult = new DeferredResult<String>();
  dealInOtherThread(deferredResult);
  return deferredResult;
 
}
 
private void dealInOtherThread(DeferredResult<String> deferredResult) {
  try {
    Thread.sleep(2000);
  } catch (InterruptedException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
  }
 
  deferredResult.setResult("hello task");
}

dealInOtherThread處理完成,setResult的時候就會觸發springmvc分配一個request到DispatcherServlet,然后DispatcherServlet處理DeferredResult的返回結果,并返回視圖。

DeferredResult還提供了其他返回來處理線程請求,例如onTimeout(Runnable) 還有onCompletion(Runnable),onTimeout可以注冊一個線程回調,當請求延時的時候的回調函數,onCompletion可以注冊一個請求完成的回調函數。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:http://blog.csdn.net/yingxiake/article/details/51193319

延伸 · 閱讀

精彩推薦
619
主站蜘蛛池模板: 久久99亚洲精品久久99果 | 毛片免费看电影 | 免费一级a毛片免费观看 | 久久精品79国产精品 | 一级做a爱片久久毛片a高清 | 亚洲经典视频 | 亚洲成人国产综合 | av电影免费观看 | 毛片在哪里看 | 在线看毛片的网站 | jizzjizzjizzjizz国产 | 国产一区二区三区四 | 久久综合一区 | 国产精品久久久久av | 精品国产一区二区三区在线观看 | 国产中出视频 | 成人短视频在线观看 | 超碰97最新 | 国产精品久久久久久久久久久久午夜 | 午夜精品福利影院 | 亚洲精品aa | 国产精品成人一区二区三区电影毛片 | 欧日一级片| 伊人成人免费视频 | 国产日产精品久久久久快鸭 | 久久手机在线视频 | 成人在线免费观看小视频 | 色播久久 | 91精品国产91久久久久久不卞 | 国产精品99久久99久久久二 | 337p粉嫩大胆噜噜噜亚瑟影院 | 妇女毛片 | 韩国十九禁高潮床戏在线观看 | 国产精品999在线观看 | 国产精品久久久久久久久久久久久久久 | 黄色免费观看网站 | 日韩一级免费 | 精品国产一区二区三区在线观看 | 亚洲黑人在线观看 | 国产瑟瑟视频 | 一级免费视频 |