1. 程式人生 > >python + django + dwebsocket 實現簡單的聊天室

python + django + dwebsocket 實現簡單的聊天室

使用庫dwebsocket,具體參考此處

views.py:

from dwebsocket.decorators import accept_websocket,require_websocket
from collections import defaultdict
# 儲存所有接入的使用者地址
allconn = defaultdict(list)
@accept_websocket
def echo(request, userid):
    allresult = {}
    # 獲取使用者資訊
    userinfo = request.user
    allresult[
'userinfo'] = userinfo # 宣告全域性變數 global allconn if not request.is_websocket():#判斷是不是websocket連線 try:#如果是普通的http方法 message = request.GET['message'] return HttpResponse(message) except: return render(request, 'myproject/chat.html', allresult)
else: # 將連結(請求?)存入全域性字典中 allconn[str(userid)] = request.websocket # 遍歷請求地址中的訊息 for message in request.websocket: # 將資訊發至自己的聊天框 request.websocket.send(message) # 將資訊發至其他所有使用者的聊天框 for i in allconn:
if i != str(userid): allconn[i].send(message)

chat.html :

<!DOCTYPE html>
<html>
<head>
    <title>django-websocket</title>
    <script src="http://code.jquery.com/jquery-1.11.1.min.js"></script>
    <script type="text/javascript">
    $(document).ready(function () {
        // 獲取當前時間的函式
        function getNowFormatDate() {
            var date = new Date();
            var seperator1 = "-";
            var seperator2 = ":";
            var month = date.getMonth() + 1;
            var strDate = date.getDate();
            if (month >= 1 && month <= 9) {
                month = "0" + month;
            }
            if (strDate >= 0 && strDate <= 9) {
                strDate = "0" + strDate;
            }
            var currentdate = date.getFullYear() + seperator1 + month + seperator1 + strDate
                    + " " + date.getHours() + seperator2 + date.getMinutes()
                    + seperator2 + date.getSeconds();
            return currentdate;
        }
 
        $('#connect_websocket').click(function () {
            if (window.s) {
                window.s.close()
            };
            /*建立socket連線*/
            var socket = new WebSocket("ws://" + window.location.host + "/myproject/echo/" + $('#userid').val());
            socket.onopen = function () {
                console.log('WebSocket open');//成功連線上Websocket
            };
            socket.onmessage = function (e) {
                console.log('message: ' + e.data);//打印出服務端返回過來的資料
                $('#messagecontainer').prepend('<p>' + e.data + '</p>');
            };
            // Call onopen directly if socket is already open
            if (socket.readyState === WebSocket.OPEN) socket.onopen();
            window.s = socket;
        });
        $('#send_message').click(function () {
            //如果未連線到websocket
            if (!window.s) {
                alert("websocket未連線.");
            } else {
                window.s.send($('#username').val() + ' ' + getNowFormatDate() + ':<br>' + $('#message').val());//通過websocket傳送資料
            }
        });
        $('#close_websocket').click(function () {
            if (window.s) {
                window.s.close();//關閉websocket
                console.log('websocket已關閉');
            }
        });
 
    });
    </script>
</head>
<body>
<br>
<input type="hidden" id="userid" value="{{ userinfo.id }}"/>
<input type="hidden" id="username" value="{{ userinfo.username }}"/>
<input type="text" id="message" value="Hello, World!"/>
<button type="button" id="connect_websocket">連線 websocket</button>
<button type="button" id="send_message">傳送 message</button>
<button type="button" id="close_websocket">關閉 websocket</button>
<h1>Received Messages</h1>
<div id="messagecontainer">
 
</div>
</body>
</html>

urls.py :

url(r'^echo/(?P<userid>[0-9]+)$', views.echo, name='echo'),

 

閱讀原文

Django WebSocket Redis 線上聊天室

https://github.com/huguodong/dj_dwebsocket(demo程式碼)