基本上,您需要的是在大气层之上实现发布-订阅。
大气由两部分组成:客户端(基于javascript)和服务器端(基于java)。
首先,您需要配置服务器端:安装大气
即servlet或过滤器,它是必需的,以便它可以将大气资源添加到HttpServletRequest中。
大气资源表示服务器端的单个客户端连接。
Broadcaster 实际上是这些资源的容器,因此当您需要发送到多个连接时,您无需处理查找/迭代/并发。(请注意,单个客户端可以生成多个连接)。
在服务器端,您需要为客户端提供一个终结点来订阅通知。例如,如果您使用的是Spring-MVC,它可以像这样(省略验证/身份验证等):
@RequestMapping(value = "/user-notifications/{userId}")
@ResponseStatus(HttpStatus.OK)
@ResponseBody
public void watch(@PathVariable("userId") String userId,
HttpServletRequest request) throws Exception {
//Atmosphere framework puts filter/servlet that adds ATMOSPHERE_RESOURCE to all requests
AtmosphereResource resource = (AtmosphereResource)request.getAttribute(ApplicationConfig.ATMOSPHERE_RESOURCE);
//suspending resource to keep connection
resource.suspend();
//find broadcaster, second parameter says to create broadcaster if it doesn't exist
Broadcaster broadcaster = BroadcasterFactory.getDefault().lookup(userId,true);
//saving resource for notifications
broadcaster.addAtmosphereResource(resource);
}
当某些事情发生时,你可以像这样通知客户端:
public void notify(User user, Event event){
Broadcaster b = BroadcasterFactory.getDefault().lookup(user.getId());
if (b!=null){
b.broadcast(event);
}
}
在客户端,您需要发送订阅请求并侦听后续事件,如下所示:
var request = new atmosphere.AtmosphereRequest();
request.url = '/user-notifications/'+userId;
request.transport = 'websocket';
request.fallbackTransport = 'streaming';
request.contentType = 'application/json';
request.reconnectInterval = 60000;
request.maxReconnectOnClose = 1000;
request.onMessage = function(response){
console.log(response);
alert('something happend<br>'+response);
};
that.watcherSocket = atmosphere.subscribe(request);
所以,总结一下:
- 客户端发送请求“我想接收此类通知”。
- 服务器接收请求,暂停并保存连接在某个地方(在您的代码中或在广播公司中)。
- 发生某些情况时,服务器会查找挂起的连接并在其中发送通知。
- 客户端收到通知并调用回调。
- 利润!!!
这个wiki解释了大气层背后的一些概念,并链接到其他文档。