SseEmitter推送

后端代码SseController.java

package com.theorydance.mywebsocket.server;

import java.util.HashMap;
import java.util.Map;
import java.util.UUID;

import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.mvc.method.annotation.SseEmitter;
import org.springframework.web.servlet.mvc.method.annotation.SseEmitter.SseEventBuilder;

import lombok.extern.slf4j.Slf4j;

@CrossOrigin
@RestController
@Slf4j
public class SseController {
    
    private Map<String,SseEmitter> emitterMap = new HashMap<>();
    
    public SseController() {
        log.info("init sseController");
    }

    @GetMapping("/getData")
    public SseEmitter getData(@RequestParam String id){
        final SseEmitter emitter = new SseEmitter();
        emitter.onCompletion(() -> {
            emitterMap.remove(id);
            log.info("onCompletion");
        });
        
        emitter.onError(e -> {
            emitterMap.remove(id);
            log.info("onError:" + e.getMessage());
        });
        
        emitter.onTimeout(() -> {
            emitterMap.remove(id);
            log.info("onTimeout");
        });
        
        try {
            emitterMap.put(id,emitter);
        }catch (Exception e){
            emitter.completeWithError(e);
        }
        return emitter;
    }
 
    @GetMapping("/payback")
    public String payback(@RequestParam String id){
        SseEmitter emitter = emitterMap.get(id);
        String res = "推送失败,已关闭";
        if(emitter != null){
            try {
                String uuid = UUID.randomUUID().toString();
                SseEventBuilder builder = SseEmitter.event().data(uuid);
                emitter.send(builder);
                res = "ok";
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        return res;
 
    }
}

 

前端代码:

<body>

<script>
/**
 * H5 EventSource 实现web页面推送功能demo
 */
 
var serverData,statusDiv;
var SERVER_URL = "http://localhost:8080/demo/getData?id=11";  //servers Url Adress
 
window.onload = function(){
    startlistenServer();
}
 
function startlistenServer(){
    var es = new EventSource(SERVER_URL);
    //es.addEventListener("newDate",newDateHandler);
    es.onopen =openHandler;
    es.onerror = errorHandler;
    es.onmessage = messageHandler;
}
 
function openHandler(e){
    console.log('openHandler');
}
 
function errorHandler(e){
    console.log('errorHandler');
}
 
function messageHandler(e){
    console.log(e.data);
}
 
function newDateHandler(e){
    serverData.innerHTML = e.data;
}
</script>
</body>

后面贴一个图,我自己的总结,如果发现什么不对的描述,请留言

 

posted @ 2020-04-12 18:32  理舞  阅读(1304)  评论(0编辑  收藏  举报