Symfony2(WebsocketBundle) – 简单的私有(和组)聊天数据库模式和逻辑

前端之家收集整理的这篇文章主要介绍了Symfony2(WebsocketBundle) – 简单的私有(和组)聊天数据库模式和逻辑前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想在一个网站上实现一个非常简单的聊天,在2个注册用户登录用户之间进行私人消息(甚至可能在登录用户之间进行组合消息).
以Whatsup为例,当然我也不会有那么多用户.

资源:Symfony2 WebsocketBundle
https://github.com/GeniusesOfSymfony/WebSocketBundle

两个问题:
你会建议什么数据库模式?
2-如何管理“主题”? (阅读WebsocketBundle教程后,我了解如何订阅/取消订阅/广播一个主题,但我不知道如何管理用户主题之间的关系,如何保护对话等…
我只需要一些关于应用程序逻辑的信息(无代码)…什么信息要保存和在哪里.)

例如,我如何管理频道的名称(将会每次更改,还是将其存储在数据库中,并在下次用户登录时重新使用)?

session.subscribe("acme/channel/id/12345",function(uri,payload){
    console.log("Received message",payload.msg);
});

附:我已经尝试搜索SO和Google,但找不到任何有用的信息.

解决方法

WebsocketBundle为您提供了一种通过套接字编写较少通信的机制.对于聊天/群聊聊天设置,您有多个选项.第一个选项可以是使用一些消息包,并根据需要进行修改.我发现这个捆绑( https://github.com/FriendsOfSymfony/FOSMessageBundle)非常灵活.

但是,如果你想开发自己的这里是从FOSMessageBundle的模式灵感来自一些定制的模式.使用表附加模式,它是列名.人们可以轻松地识别主键和外键.

其余的东西是非常简单的,而不是Thread_group_hash的Thread表中的一个字段.实际上,这个字段的目的是为每个线程唯一的哈希/键.线程意味着一对一聊天或多对多聊天.无论何时有人将人们添加到聊天中,用户都与他们相关联的ID.我按升序或降序对添加用户ID进行排序,并生成md5 / sha1密钥并将其存储在此处.

这也可以用作WebSocketBundle中的主题,因为这是为了我们在此尝试实现的相同目的使用主题.每当同一群人被加入到任何一方的对话中时,通信将转到同一个线程.但是请记住,在插入线程/消息的详细信息之前,您需要使用该哈希来标识它所在的位置,或者它是一个新线程:)

猜你在找的MsSQL相关文章