Python如何使用WebSocket实现实时Web应用

 更新时间:2024年08月01日 11:20:54   作者:杰哥在此  
这篇文章主要介绍了Python使用WebSocket实现实时Web应用,Django Channels 提供了强大的功能,使得在 Django 中实现实时功能变得更加容易,你可以在此基础上扩展,添加更多功能和复杂的逻辑,需要的朋友可以参考下

使用 WebSocket 实现实时 Web 应用可以使你的应用程序具备实时双向通信的能力。以下是一个完整的指南,展示如何使用 Django Channels 和 WebSocket 实现一个简单的实时 Web 应用。

环境准备

安装 Django Channels:

pip install channels

创建 Django 项目:

django-admin startproject myproject
cd myproject

创建应用:

python manage.py startapp myapp

配置 Django 项目

添加应用到 INSTALLED_APPS:
myproject/settings.py 中,添加 channels 和你的应用 myapp

INSTALLED_APPS = [
    ...
    'channels',
    'myapp',
]

配置 Channels:
settings.py 中,添加 Channels 配置:

ASGI_APPLICATION = 'myproject.asgi.application'
CHANNEL_LAYERS = {
    "default": {
        "BACKEND": "channels.layers.InMemoryChannelLayer",
    },
}

创建 asgi.py 文件:
myproject 目录下创建一个 asgi.py 文件:

import os
from channels.routing import ProtocolTypeRouter, URLRouter
from django.core.asgi import get_asgi_application
from channels.auth import AuthMiddlewareStack
import myapp.routing
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.settings')
application = ProtocolTypeRouter({
    "http": get_asgi_application(),
    "websocket": AuthMiddlewareStack(
        URLRouter(
            myapp.routing.websocket_urlpatterns
        )
    ),
})

创建 WebSocket 路由

定义 WebSocket 路由:
myapp 目录下创建一个 routing.py 文件:

from django.urls import path
from . import consumers
websocket_urlpatterns = [
    path('ws/chat/', consumers.ChatConsumer.as_view()),
]

创建消费者

定义 WebSocket 消费者:
myapp 目录下创建一个 consumers.py 文件:

import json
from channels.generic.websocket import AsyncWebsocketConsumer
class ChatConsumer(AsyncWebsocketConsumer):
    async def connect(self):
        await self.accept()
    async def disconnect(self, close_code):
        pass
    async def receive(self, text_data):
        text_data_json = json.loads(text_data)
        message = text_data_json['message']
        await self.send(text_data=json.dumps({
            'message': message
        }))

创建前端页面

创建 HTML 页面:
myapp/templates/myapp 目录下创建一个 chat.html 文件:

<!DOCTYPE html>
<html>
<head>
    <title>Chat</title>
</head>
<body>
    <h1>WebSocket Chat</h1>
    <input id="messageInput" type="text" size="100">
    <button onclick="sendMessage()">Send</button>
    <ul id="messages">
    </ul>
    <script>
        const chatSocket = new WebSocket(
            'ws://' + window.location.host + '/ws/chat/'
        );
        chatSocket.onmessage = function(e) {
            const data = JSON.parse(e.data);
            document.querySelector('#messages').innerHTML += '<li>' + data.message + '</li>';
        };
        chatSocket.onclose = function(e) {
            console.error('Chat socket closed unexpectedly');
        };
        function sendMessage() {
            const messageInputDom = document.querySelector('#messageInput');
            const message = messageInputDom.value;
            chatSocket.send(JSON.stringify({
                'message': message
            }));
            messageInputDom.value = '';
        }
    </script>
</body>
</html>

创建视图:
myapp/views.py 中创建一个视图来渲染模板:

from django.shortcuts import render
def chat(request):
    return render(request, 'myapp/chat.html')

配置 URL:
myapp/urls.py 中添加 URL 路由:

from django.urls import path
from . import views
urlpatterns = [
    path('chat/', views.chat, name='chat'),
]

运行服务器

启动开发服务器:

python manage.py runserver

测试 WebSocket:
访问 http://127.0.0.1:8000/chat/,在输入框中输入消息并点击 “Send” 按钮,你应该会看到消息实时显示在页面上。

总结

通过上述步骤,你可以使用 Django Channels 和 WebSocket 创建一个简单的实时 Web 应用。Django Channels 提供了强大的功能,使得在 Django 中实现实时功能变得更加容易。你可以在此基础上扩展,添加更多功能和复杂的逻辑。

到此这篇关于Python使用WebSocket实现实时Web应用的文章就介绍到这了,更多相关Python使用WebSocket内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python如何读取指定csv单元格

    python如何读取指定csv单元格

    这篇文章主要介绍了python如何读取指定csv单元格方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-02-02
  • 如何使用django-treebeard实现树类型存储与编辑

    如何使用django-treebeard实现树类型存储与编辑

    这篇文章主要介绍了使用django-treebeard实现树类型存储与编辑的宣相关操作代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-08-08
  • 初次部署django+gunicorn+nginx的方法步骤

    初次部署django+gunicorn+nginx的方法步骤

    这篇文章主要介绍了初次部署django+gunicorn+nginx的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • python删除服务器文件代码示例

    python删除服务器文件代码示例

    这篇文章主要介绍了python删除服务器文件代码示例,列举了两个实例,分享了相关代码示例,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下
    2018-02-02
  • Python爬虫技术

    Python爬虫技术

    本文将要介绍的是python爬虫基础知识,感兴趣的小伙伴一起来学习吧
    2021-08-08
  • python下如何让web元素的生成更简单的分析

    python下如何让web元素的生成更简单的分析

    做web不简单,特别是当你需要使用一些web效果的时候, 比如显示个圆角矩形,提示框之类的,也许你认为很简单,好让我们分析一下:
    2008-07-07
  • Python+MySQL随机试卷及答案生成程序的示例代码

    Python+MySQL随机试卷及答案生成程序的示例代码

    这篇文章主要介绍了Python+MySQL随机试卷及答案生成程序的示例代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • 使用PYTHON解析Wireshark的PCAP文件方法

    使用PYTHON解析Wireshark的PCAP文件方法

    今天小编就为大家分享一篇使用PYTHON解析Wireshark的PCAP文件方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-07-07
  • django数据库自动重连的方法实例

    django数据库自动重连的方法实例

    这篇文章主要给大家介绍了关于django数据库自动重连的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用django具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • python使用dabl几行代码实现数据处理分析及ML自动化

    python使用dabl几行代码实现数据处理分析及ML自动化

    这篇文章主要为大家分享一个名为 dabl 的开源 Python 工具包,它可以自动化机器学习模型开发,包括数据预处理、特征可视化和分析、建模
    2021-11-11

最新评论