update 优化 sse 如果获取token列表为空 删除userid对应的存储
This commit is contained in:
parent
c2746c2392
commit
a7b83672ba
@ -1,5 +1,6 @@
|
|||||||
package org.dromara.common.sse.core;
|
package org.dromara.common.sse.core;
|
||||||
|
|
||||||
|
import cn.hutool.core.map.MapUtil;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.dromara.common.redis.utils.RedisUtils;
|
import org.dromara.common.redis.utils.RedisUtils;
|
||||||
import org.dromara.common.sse.dto.SseMessageDto;
|
import org.dromara.common.sse.dto.SseMessageDto;
|
||||||
@ -65,7 +66,7 @@ public class SseEmitterManager {
|
|||||||
*/
|
*/
|
||||||
public void disconnect(Long userId, String token) {
|
public void disconnect(Long userId, String token) {
|
||||||
Map<String, SseEmitter> emitters = USER_TOKEN_EMITTERS.get(userId);
|
Map<String, SseEmitter> emitters = USER_TOKEN_EMITTERS.get(userId);
|
||||||
if (emitters != null) {
|
if (MapUtil.isNotEmpty(emitters)) {
|
||||||
try {
|
try {
|
||||||
SseEmitter sseEmitter = emitters.get(token);
|
SseEmitter sseEmitter = emitters.get(token);
|
||||||
sseEmitter.send(SseEmitter.event().comment("disconnected"));
|
sseEmitter.send(SseEmitter.event().comment("disconnected"));
|
||||||
@ -73,6 +74,8 @@ public class SseEmitterManager {
|
|||||||
} catch (Exception ignore) {
|
} catch (Exception ignore) {
|
||||||
}
|
}
|
||||||
emitters.remove(token);
|
emitters.remove(token);
|
||||||
|
} else {
|
||||||
|
USER_TOKEN_EMITTERS.remove(userId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -93,7 +96,7 @@ public class SseEmitterManager {
|
|||||||
*/
|
*/
|
||||||
public void sendMessage(Long userId, String message) {
|
public void sendMessage(Long userId, String message) {
|
||||||
Map<String, SseEmitter> emitters = USER_TOKEN_EMITTERS.get(userId);
|
Map<String, SseEmitter> emitters = USER_TOKEN_EMITTERS.get(userId);
|
||||||
if (emitters != null) {
|
if (MapUtil.isNotEmpty(emitters)) {
|
||||||
for (Map.Entry<String, SseEmitter> entry : emitters.entrySet()) {
|
for (Map.Entry<String, SseEmitter> entry : emitters.entrySet()) {
|
||||||
try {
|
try {
|
||||||
entry.getValue().send(SseEmitter.event()
|
entry.getValue().send(SseEmitter.event()
|
||||||
@ -103,6 +106,8 @@ public class SseEmitterManager {
|
|||||||
emitters.remove(entry.getKey());
|
emitters.remove(entry.getKey());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
USER_TOKEN_EMITTERS.remove(userId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user