一. 点睛
在前面的文章SpringMvc4.x高级配置(三):服务器端推送技术之SSE中已经介绍了服务器端推送技术的第一种方案,下面演示第二种服务器端推送技术,基于Servlet3.0+
异步方法处理。
二. 示例
1.开启异步方法支持
在文件WebInitializer
的方法onStartup
末尾增加以下代码开启异步方法支持,代码如下:
servlet.setAsyncSupported(true);//①
添加完成之后的代码如下所示:
Dynamic servlet = servletContext.addServlet("dispatcher", new DispatcherServlet(ctx)); //③
servlet.addMapping("/");
servlet.setLoadOnStartup(1);
servlet.setAsyncSupported(true);//①
代码解释:
① 此句开启异步方法支持。
2. 演示控制器
package org.light4j.springMvc4.web;
import org.light4j.springMvc4.service.PushService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.context.request.async.DeferredResult;
@Controller
public class AysncController {
@Autowired
PushService pushService; //①
@RequestMapping("/defer")
@ResponseBody
public DeferredResult<String> deferredCall() { //②
return pushService.getAsyncUpdate();
}
}
代码解释:
异步任务实现是通过控制器从另外一个线程返回一个
DeferredResult
,这里的DeferredResult
是从pushService
中获得的。
① 定时任务,定时更新DeferredResult
。
② 返回给客户端DeferredResult
。
3. 定时任务
package org.light4j.springMvc4.service;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Service;
import org.springframework.web.context.request.async.DeferredResult;
@Service
public class PushService {
private DeferredResult<String> deferredResult; //①
public DeferredResult<String> getAsyncUpdate() {
deferredResult = new DeferredResult<String>();
return deferredResult;
}
@Scheduled(fixedDelay = 5000)
public void refresh() {
if (deferredResult != null) {
deferredResult.setResult(new Long(System.currentTimeMillis()).toString());
}
}
}
代码解释:
① 在
PushService
里产生DeferredResult
给控制器使用,通过@Scheduled
注解的方法定时更新DeferredResult
4. 演示页面
在src/main/resources
下新建async.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>servlet async support</title>
</head>
<body>
<script type="text/javascript" src="assets/js/jquery.js"></script>
<script type="text/javascript">
deferred();//①
function deferred(){
$.get('defer',function(data){
console.log(data); //②
deferred(); //③
});
}
</script>
</body>
</html>
代码解释:
此处的代码使用的是
JQuery
的Ajax
请求,所以没有浏览器兼容性问题。
① 页面打开就向后台发送请求。
② 在控制台输出服务端推送的数据。
③ 一次请求完成后再向后台推送数据。
5. 配置
在文件MyMvcConfig
上使用注解@EnableScheduling
开启计划任务的支持,代码如下:
@Configuration
@EnableWebMvc// ①
@EnableScheduling
@ComponentScan("org.light4j.springMvc4")
public class MyMvcConfig extends WebMvcConfigurerAdapter {
}
在文件MyMvcConfig
的方法addViewControllers
添加viewController
映射访问演示页面async.jsp
,代码如下:
registry.addViewController("/async").setViewName("/async");
添加完成之后的代码如下所示:
@Override
public void addViewControllers(ViewControllerRegistry registry) {
registry.addViewController("/index").setViewName("/index");
registry.addViewController("/toUpload").setViewName("/upload");
registry.addViewController("/converter").setViewName("/converter");
registry.addViewController("/sse").setViewName("/sse");
registry.addViewController("/async").setViewName("/async");
}
6. 运行
访问http://localhost/springMvc4.x-servlet3/async,可以看到网络不断的在获取服务器端推送的消息,如下图所示:
查看浏览器控制台可以看到不断的在打印消息,如下图所示:
三. 源代码示例:
打赏 欢迎关注人生设计师的微信公众账号
公众号ID:longjiazuoA