- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我目前正在基于此示例开发一个简单的聊天多房间:
https://github.com/Atmosphere/atmosphere-samples/blob/master/samples/chat-multiroom/
我的开发环境:
在解释我的问题之前,这里是我实现的聊天室的全局机制:
用户 A 连接到套接字“chat/all”。该 socket 允许发送或接收他和对话者之间的任何通知。
用户 A 从第一个 Web 应用程序发出聊天请求并等待(弹出旋转窗口)用户 B 的响应。
用户 B 也连接到套接字“chat/all”。用户B检查每次,从第二个网络应用程序,如果有新的聊天请求(来自数据库的 SQL 请求)。如果他发现新的请求,他可以或不接受这个请求。
用户B接受用户A的聊天请求。此时,通过套接字“chat/all”,用户 B 推送一条消息表明他接受了此消息要求。之后,用户B连接到第二个socket“chat/1”(特定聊天室的随机 ID)。他现在正在等待(像用户 B 一样弹出旋转窗口)让用户 A 连接到同一个套接字。
用户 A 收到此消息并连接到套接字“chat/1”。用户 A 现在已从服务器连接到该聊天室。该聊天室中有两个用户,我向其广播消息仅用户B通知用户A已连接并关闭弹出窗口旋转器。
当我只为一个资源广播消息时没有问题。但是当我为两个用户广播消息时,“onMessage”方法被多次调用!
这是我有关管理聊天室的代码:
@ManagedService(path = "/chat/{id_room}")
public final class ChatRoom {
//many static final private attribute
private static final Logger logger = LoggerFactory.getLogger(Chat.class);
@PathParam("id_room")
private String idChatRoom;
private final static String CHAT = "/chat/";
private final HashMap<Integer, List<String>> users = new HashMap<Integer, List<String>>();
private Universe universe;
private BroadcasterFactory broadcasterFactory = Universe.broadcasterFactory();
private AtmosphereResourceFactory resourceFactory = Universe.resourceFactory();
private ChatMessageEncoderDecoder chatEncodeDecode = new ChatMessageEncoderDecoder();
@Message(encoders = { ChatMessageEncoderDecoder.class }, decoders = { ChatMessageEncoderDecoder.class })
public final void onMessage(AtmosphereResource r, final ChatMessage message) throws UnsupportedEncodingException {
Integer chatRoomId = !NOTIFICATION_SOCKET_ALL.equals(idChatRoom) == true ? Integer.parseInt(idChatRoom) : 0;
[...]
if(...) {
[...]
}
else {
roomsList.add(idChatRoom);
boolean messageEmpty = "".equals(message.getMessage());
boolean chatConnectedWithTwoUsers = users.get(chatRoomId).size() > 1;
boolean chatConnectedWithOneUser = users.get(chatRoomId).size() == 1;
if(chatConnectedWithTwoUsers && MESSAGE_EVENT.equals(message.getEvent())) { //communication between two users to the chat room id
Users user = CDIUtil.getBean(RechercheUserService.class).getUserChat(message.getMail());
if(user != null){
try {
List<String> listUsersFromRoom = users.get(chatRoomId);
message.setUsers(listUsersFromRoom);
message.setEvent(MESSAGE_EVENT);
logger.info("{} a envoyé le message {}", message.getAuthor(), message.getMessage());
String messageToSend = chatEncodeDecode.encode(message);
broadcasterFactory.lookup(CHAT + idChatRoom).broadcast(messageToSend);
String messageUtf8 = new String(message.getMessage().getBytes(), "UTF-8");
CDIUtil.getBean(MessageRoomsService.class).createMessageContents(idChatRoom, user, messageUtf8);
} catch (IMException e) {
message.setEvent(MESSAGE_NOT_REGISTER_EVENT);
logger.error("Impossible d'enregistrer le message de l'utilisateur");
}
}
else{
message.setEvent(USER_NOT_EXIST_EVENT);
logger.error("Utilisateur Inconnu");
}
}
else if(chatConnectedWithOneUser) { //two users connected to the chat room id
users.get(chatRoomId).add(r.uuid());
logger.info("L'utilisateur {} a rejoint le chat {}", r.uuid(), idChatRoom);
AtmosphereResource resource = resourceFactory.find(users.get(chatRoomId).get(0)); //get the first user connected to the chat room
List<String> listUsersFromRoom = users.get(chatRoomId);
message.setUsers(listUsersFromRoom);
message.setEvent(CHAT_COMPLETE_EVENT);
String messageToSend = chatEncodeDecode.encode(message);
broadcasterFactory.lookup(CHAT + idChatRoom).broadcast(messageToSend, resource);
}
}
}
}
因此,当广播完成后,在界面用户上,会显示 3 条消息。例如,用户A发送消息“您好,有什么可以为您做的吗?”,用户B看到该消息3次。
我认为存在三个消息,因为三个资源在两个套接字上处于 Activity 状态。事实上,第一个套接字“chat/all”对于一个资源(用户 B)始终处于 Activity 状态,而第二个套接字“chat/1”对于两个资源(用户 A 和用户 B)始终处于 Activity 状态。共有三个资源。
有人已经面临这个问题了吗?或者有人知道如何解决它吗?
最佳答案
我也遇到了同样的问题..我已经解决了阅读此链接Multiple messages arrive as single response body or message received are incomplete的问题:
我已在 Atmosphere Servlet 内的 web.xml 中添加了这个 init-param
<init-param>
<param-name>org.atmosphere.cpr.AtmosphereInterceptor</param-name>
<param-value>org.atmosphere.client.TrackMessageSizeInterceptor</param-value>
</init-param>
在客户端,我在请求中添加了 trackMessageLength : true
:
var request = { url: document.location.toString() + 'chat',
contentType : "application/json",
logLevel : 'debug',
transport : 'long-polling' ,
trackMessageLength : true,
fallbackTransport: 'long-polling'};
正如此链接中报道的那样
If you broadcast multiple messages and the underlying server buffer them in memory, your atmopshere.js callback or function can be invoked with multiple messages instead of a single message. It may not be an issue if you are using text, but if you are using JSON the parsing may fail because your callback/function gets invoked with multiple JSON messages.
我希望这对你也有用!
关于java - Atmosphere 框架 : broadcaster broadcast message multiple times,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34041708/
在尝试 time 的 python 执行时,我发现在一条语句中两次调用 time.time() 时出现奇怪的行为。在语句执行期间获取time.time() 有一个非常小的处理延迟。 例如time.ti
我要疯了。对于我的生活,我无法弄清楚为什么以下代码会导致 Unity 在我按下播放键后立即卡住。这是一个空的项目,脚本附加到一个空的游戏对象。在控制台中,什么也没有出现,甚至没有出现初始的 Debug
我要疯了。对于我的生活,我无法弄清楚为什么以下代码会导致 Unity 在我按下播放键后立即卡住。这是一个空的项目,脚本附加到一个空的游戏对象。在控制台中,什么也没有出现,甚至没有出现初始的 Debug
我不明白为什么下面的结果是一样的。我预计第一个结果是指针地址。 func print(t *time.Time) { fmt.Println(t) // 2009-11-10 23:00:00
Python 3.6.4 (v3.6.4:d48eceb, Dec 19 2017, 06:54:40) [MSC v.1900 64 bit (AMD64)] on win32 Type "help
当我有一个time.Time时: // January, 29th t, _ := time.Parse("2006-01-02", "2016-01-29") 如何获得代表 1 月 31 日的 ti
首先,我意识到不推荐使用 time with time zone。我要使用它是因为我将多个 time with time zone 值与我当前的系统时间进行比较,而不管是哪一天。 IE。用户说每天 0
长期以来,在 Rust 中精确测量时间的标准方法是 time crate 及其 time::precise_time_ns功能。但是,time crate 现在已被弃用,std 库有 std::tim
我正在我学校的一个科学集群上运行我的有限差分程序。该程序使用 openmpi 来并行化代码。 当程序连续运行时,我得到: real 78m40.592s user 78m34.920s s
尽管它们已被弃用并且有比 time 更好的模块(即 timeit),但我想知道这两个函数 time 之间的区别.clock() 和 time.time()。 从后者 (time.time()) 开始,
这个问题在这里已经有了答案: Python's time.clock() vs. time.time() accuracy? (16 个答案) 关闭 6 年前。 我认为两者都衡量时间量?但是他们返回
我正在尝试测试 http 请求处理代码块在我的 Flask Controller 中需要多长时间,这是我使用的示例代码: cancelled = [] t0 = time.time() t1 = ti
运行 python 的计算机时钟(Windows 或 Linux)时会发生什么自动更改并调用 time.time()? 我读到,当时钟手动更改为过去的某个值时,time.time() 的值会变小。 最
我有一个结构可能无法在其字段之一上设置 time.Time 值。测试无效性时,我不能使用 nil 或 0。time.Unix(0,0) 也不相同。我想到了这个: var emptyTime time.
我有一个打算用数据库记录填充的结构,其中一个日期时间列可以为空: type Reminder struct { Id int CreatedAt time.Time
问题陈述:通过匹配其百分比随机执行各种命令。比如执行 CommandA 50% 的时间和 commandB 25% 的时间和 commandC 15% 的时间等等,总百分比应该是 100%。 我的问题
我正在使用 laravel 6。我在同一个应用程序中有类似的 Controller 和类似的 View ,它工作正常。对比之后还是找不到错误。 Facade\Ignition\Exceptions\V
我需要用 ("%m/%d/%Y %H:%M:%S") 格式表示时间,我得到的浮点值是 time.time(). 我已经有了一个 time.time() 形式的值。例如,我已经有一个值,我每 0.3 秒
我正在使用以下方法获取 utc 日期时间: import datetime import time from pytz import timezone now_utc = datetime.datet
我在 Ubuntu 上使用 time.clock 和 time.time 为一段 python 代码计时: clock elapsed time: 8.770 s time elapsed time
我是一名优秀的程序员,十分优秀!