Django频道实时聊天保存已发送的消息

时间:2020-06-19 19:57:06

标签: django websocket model channel channels

因此,我有一个Django应用程序,其中使用了渠道来实现实时聊天。我的消费者是这样的:

导入json 从asgiref.sync导入async_to_sync 从channels.generic.websocket导入WebsocketConsumer

$('#photo-uploader').change(function() {
  $('#submit-photo').click()
})

因此,我正在寻找一种保存已发送消息的方法(因为当前它们在刷新时会丢失)。我创建了一个Messages模型,该模型具有用于消息文本的CharField。我想我可以在chat_message函数中保存新消息:

class ChatConsumer(WebsocketConsumer):
    def connect(self):
        self.room_name = self.scope['url_route']['kwargs']['room_name']
        self.room_group_name = 'chat_%s' % self.room_name
        # Join room group
        async_to_sync(self.channel_layer.group_add)(
            self.room_group_name,
            self.channel_name
        )

        self.accept()

    def disconnect(self, close_code):
        # Leave room group
        async_to_sync(self.channel_layer.group_discard)(
            self.room_group_name,
            self.channel_name
        )

    # Receive message from WebSocket
    def receive(self, text_data):
        text_data_json = json.loads(text_data)
        message = text_data_json['message']
        username = self.scope["user"]
        # Send message to room group
        async_to_sync(self.channel_layer.group_send)(
            self.room_group_name,
            {
                'type': 'chat_message',
                'message': message,
                'user': username.username
            }
        )

    # Receive message from room group
    def chat_message(self, event):
        message = event['message']
        user=event['user']
        print(user)
        # Send message to WebSocket
        self.send(text_data=json.dumps({
            'message': message,
            'user':user
        }))

我的问题是,每当用户连接到聊天时,如何预加载最后10条消息?

1 个答案:

答案 0 :(得分:0)

因此,为了做到这一点,我最终在“接收”功能中将消息保存到数据库中(因为如果将其保存在chat_message中,则每个活动用户将保存1次)。然后,为了预加载消息,每次打开websocket时,我都会使用AJAX调用,以便使用python函数获取10条最新消息,然后将消息作为JsonResponse传递回去(https://simpleisbetterthancomplex.com/tutorial/2016/08/29/how-to-work-with-ajax-request-with-django.html向下滚动到AJAX请求本文的一部分,并按此顺序查看signup.html,urls.py和views.py文件以供参考)。