环境:
SpringBoot 2.0.0.3 + JDK 1.8 + IDEA + Redis(spring-boot-starter-data-redis) + Nginx1.14
坑点:
- 程序以war包运行。websocket配置问题
- 服务器开启了Nginx代理,导致websocket 404
- websocket 短时间 自动关闭。
- redis 消息发布/订阅模式 发布对象,接受乱码。这个最后也没解决。如果有哪位大佬知道如何解决。请留言。
-
websocket 配置
import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Component; import javax.websocket.*; import javax.websocket.server.PathParam; import javax.websocket.server.ServerEndpoint; import java.io.IOException; import java.util.concurrent.CopyOnWriteArrayList; /** * @description: websocket类 * @create: 2019-11-21 13:56 **/ @Component @Slf4j @ServerEndpoint("/webService/websocket/{userId}") public class WebSocketServer { // 消息会话 private Session session; //消息接收者id private String userId; // 每个客户的WebSocketServer 需要保证线程安全 private static CopyOnWriteArrayList<WebSocketServer> list = new CopyOnWriteArrayList<>(); /** * @Description: 建立连接时调用 * @param session * @param userId * @Date: 2019/11/21 15:11 */ @OnOpen public void onOpen(Session session, @PathParam("userId")String userId){ log.info("【websocket消息推送模块】--用户" + userId +"连接服务。"); this.session = session; this.userId = userId; list.add(this); } /** * @Description: 关闭连接时调用 * @param session * @param userId * @Date: 2019/11/21 15:11 */ @OnClose public void onClose(Session session,@PathParam("userId")String userId){ log.info("【websocket消息推送模块】--用户" + userId +"断开服务。"); list.remove(this); } /** * @Description: 接收到前台推送的消息时调用 * @param message * @param session * @Date: 2019/11/21 15:15 */ @OnMessage public void onMessage(String message, Session session,@PathParam("userId")String userId){ //目前用不到 log.info("【websocket消息推送模块】--接收到用户" + userId +"推送的消息:" + message); //可以根据userId,推送给具体人 sendInfo(message,userId); } @OnError public void onError(Session session,Throwable error){ log.info("【websocket消息推送模块】--用户" + userId +"连接异常。"); error.printStackTrace(); } /** * @Description: 发送消息 * @param message * @Date: 2019/11/21 15:20 */ public void sendMessage(String message) throws IOException {