Python中怎么使用dwebsocket实现后端数据实时刷新
时间:2023-05-10 21:02
执行定时任务的时候,我们需要了解执行百分比或者实时数据返回,这时候可以采用的方法 1.ajax请求后端服务器,然后前端页面局部渲染获取百分比 2.使用webscoket进行长连接交流刷新 ajax使用方法使用interval函数来实现定时请求,本次这里不做说明 views.py文件添加如下内容 settings.py文件增加dwebsocket INSTALLED_APPS = [ urls.py文件添加相关链接 直接上html代码 然后我们运行程序 十秒之后断开连接得到了我们想要的结果 业务需求的话,可以在我们的test_websocket 修改我们的逻辑然后根据返回的结果进行渲染 以上就是Python中怎么使用dwebsocket实现后端数据实时刷新的详细内容,更多请关注Gxl网其它相关文章!from django.shortcuts import render,HttpResponsefrom dwebsocket.decorators import accept_websocketimport time,randomimport uuidimport json@accept_websocketdef test_websocket(request): cnt=1 if request.is_websocket(): while True: messages = { 'time': time.strftime('%Y.%m.%d %H:%M:%S', time.localtime(time.time())), 'server_msg': 'hello%s'%time.time(), 'client_msg': 'msg%s'%time.time() } time.sleep(1) cnt+=1 if cnt<=10: request.websocket.send(json.dumps(messages)) else: breakdef test_websocket_client(request): return render(request,'websocket_client.html',locals())
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'dwebsocket'
]urlpatterns = [ path('test_websocket', views.test_websocket, name='test_websocket'), path('test_websocket_client', views.test_websocket_client, name='test_websocket_client'),]
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>dwebsocket实践</title> <script src="http://code.jquery.com/jquery-1.11.1.min.js"></script> <script type="text/javascript"> $(function () { // $('#send_message').click( // function() { var socket = new WebSocket("ws://" + window.location.host + "/test_websocket"); socket.onopen = function () { console.log('WebSocket open');//成功连接上Websocket // socket.send($('#message').val());//发送数据到服务端 }; socket.onmessage = function (e) { // console.log('message: ' + e.data);//打印服务端返回的数据 $('#messagecontainer').text('<p>' + JSON.parse(e.data).client_msg + '</p>'+'<p>' + JSON.parse(e.data).server_msg + '</p>'); // $('#messagecontainer').text('<p>' + JSON.parse(e.data).server_msg + '</p>'); }; socket.onclose=function () { console.log("连接已关闭") } // }); }); </script></head><body> <input type="text" id="message" value="请输入发送消息!" /> <button type="button" id="send_message">send message</button> <h2>接受到消息</h2> <div id="messagecontainer"> </div></body></html>