使用consumers.py 之外的渠道,但在consumer 中的功能没有触发

时间:2021-07-27 14:18:10

标签: django-channels

我试图在用户登录后将消息从一个用户发送到另一个用户到另一个用户。但是,chat_message 函数似乎没有使用我在视图中的登录函数中编写的代码触发.py 作为“ccc”而不是在服务器端打印。 Django 频道的新手在这里。感谢您对我的这个问题的任何意见。

consumers.py

class OnlineFriends(AsyncWebsocketConsumer):
    async def connect(self):
        self.room_name = self.scope["user"]
        print(self.room_name)
        print(self.channel_layer)
        self.room_group_name = 'chat_' + str(self.room_name)
        print(self.room_group_name)
        # Join room group
        await self.channel_layer.group_add(
            self.room_group_name,
            self.channel_name
        )

        await self.accept()

    async def disconnect(self, close_code):
        print("aa")

        message = self.channel_name.split("-")
        await self.send(text_data=json.dumps({
                'message': message
            }))

    async def receive(self, text_data):
        text_data_json = json.loads(text_data)
        message = text_data_json['message']

        # Send message to room group
        await self.channel_layer.group_send(
            self.room_group_name,
            {
                'type': 'chat_message',
                'message': message
            }
        )

    async def chat_message(self, event):
        print("ccc")
        message = event['message']

        # Send message to WebSocket
        await self.send(text_data=json.dumps({
            'message': message
        }))

users.views.py *已更新

class Login(View):
    form_class = LoginForm
    template = 'login.html'

    def get(self, request):
        form=self.form_class(None)
        return render(request, self.template, {'form':form})

    def post(self, request):
        form = self.form_class(request.POST)
        if form.is_valid():
            username = form.cleaned_data.get("username")
            password = form.cleaned_data.get("password")
            user = authenticate(username=username, password=password)
            if user is not None:
                if user.is_active:
                    login(request, user)
                    user.onlinestatus = True
                    user.save()
                    for obj in user.friends.all():
                        print( user.friends.all())
                        if obj.onlinestatus == True:                       
                            print("obj: "+ str(obj.username))
                            channel_layer = get_channel_layer()
                            print("channel_layer: "+ str(channel_layer))
                            room_name = "chat_" + str(obj.username)
                            print("room_name: "+ str(room_name))
                            print(obj.channel_name)
                            async_to_sync(channel_layer.group_send(
                                room_name, {
                                "type": "chat.message",
                                "message": room_name,
                            }))
                            
                    return redirect('home')
            else:
                return HttpResponse("No such user.")
        else:
            return render(request, 'login.html', {'form':form})

回溯更新

WebSocket HANDSHAKING /friendslist/ [127.0.0.1:49751]        ****loading home page on browser****
foonghanyao                    ****output from consumers.OnlineFriends.connect****
RedisChannelLayer(hosts=[{'address': ('127.0.0.1', 6379)}])
chat_foonghanyao
WebSocket CONNECT /friendslist/ [127.0.0.1:49751]
HTTP GET /static/songs/images/favicon.png 200 [0.02, 127.0.0.1:61225]
<QuerySet [<User: foonghanyao>]>         ****output from Login class in views.py****
obj: foonghanyao
channel_layer: RedisChannelLayer(hosts=[{'address': ('127.0.0.1', 6379)}])
room_name: chat_foonghanyao
specific.45d45ec67e0a4282b2066d67847e4bab!8ab6617c8be94d0dabefadf636ba886e
HTTP POST /accounts/login/ 302 [0.88, 127.0.0.1:60752]
<QuerySet [<Tag: apple>, <Tag: bee>]> 
HTTP GET /home/ 200 [0.16, 127.0.0.1:60752]
WebSocket DISCONNECT /friendslist/ [127.0.0.1:55762]       ****Disconnecting from websockets in login page****
aa
WebSocket HANDSHAKING /friendslist/ [127.0.0.1:58978]       ****new page loading after being redirected following log in****
brandonfoong
RedisChannelLayer(hosts=[{'address': ('127.0.0.1', 6379)}])
chat_brandonfoong
WebSocket CONNECT /friendslist/ [127.0.0.1:58978]

sync.routing.py 已更新

websocket_urlpatterns = [
    re_path(r"^friendslist/$", consumers.OnlineFriends.as_asgi(), name='friendslist'),
]

mainapp.asgi.py 更新

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "music.settings")

application = ProtocolTypeRouter({
  "http": get_asgi_application(),
  "websocket": AuthMiddlewareStack(
        URLRouter(
            sync.routing.websocket_urlpatterns,
        )
    ),
})

0 个答案:

没有答案