node+express+socket.io製做一個聊天室功能

 

首先是下載包:javascript

npm install expresscss

npm install socket.iohtml

創建文件:java

 

 

服務器端代碼:server.jsexpress

 1 var http=require("http");
 2 var express=require("express");
 3 var sio=require("socket.io");
 4 
 5 var app=express();
 6 app.use(express.static(__dirname+"/"));
 7 
 8 var server=http.createServer(app);
 9 app.get("/", function (req, res) {
10     res.sendFile(__dirname+"/chart.html");
11 });
12 server.listen(1337,"127.0.0.1", function () {
13    console.log("開始監聽");
14 });
15 var io=sio.listen(server);
16 var names=[];
17 io.sockets.on("connection", function (socket) {
18     socket.on("login", function (name) {
19         for(var i=0;i<names.length;i++){
20             if(names[i]==name){
21                 socket.emit("duplicate");
22                 return;
23             }
24         }
25         names.push(name);
26         io.sockets.emit("login",name);
27         io.sockets.emit("sendClients",names);
28     });
29     socket.on("chat", function (data) {
30         io.sockets.emit("chat",data);
31     });
32     socket.on("logout", function (name) {
33         for(var i=0;i<names.length;i++){
34             if(names[i]==name){
35                 names.splice(i,1);
36                 break;
37             }
38         }
39         socket.broadcast.emit("logout",name);
40         io.sockets.emit("sendClients",names);
41     });
42 });

 

靜態頁面 chart.html:npm

 1 <!DOCTYPE html>
 2 <html>
 3 <head lang="en">
 4     <meta charset="UTF-8">
 5     <title>Socket.IO聊天室</title>
 6     <link rel="stylesheet" href="chart.css" />
 7     <script src="/socket.io/socket.io.js"></script>
 8     <script type="text/javascript" src="chart.js"></script>
 9 </head>
10 <body onload="window_onload()">
11 <h1>Socket.IO聊天室</h1>
12 <div id="divContainer1">
13     <table class="tbDlg" border="0" cellpadding="3" cellspacing="0" width="100%">
14         <tr class="trDlg">
15             <td class="tdDlg" width="5">
16                 用戶名:&nbsp;
17                 <input id="tbxUsername" type="text" value="遊客" size="20" />
18                 <input id="btnLogin" type="button" value="登陸" onclick="btnLogin_onclick();" />
19                 <input id="btnLogout" type="button" value="退出" disabled onclick="btnLogout_onclick();" />
20             </td>
21         </tr>
22     </table>
23 </div>
24 <div id="divLeft">
25     <div id="divchat"></div>
26     <div id="divContainer3">
27         <table class="tbDlg" border="0" cellpadding="3" cellspacing="0" width="100%">
28             <tr class="trDlg">
29                 <td valign="top" class="tdDlg" nowrap>對話</td>
30                 <td valign="top" class="tdDlg">
31                     <textarea id="tbxMsg" cols="255" rows="5" style="width: 100%"></textarea>
32                 </td>
33                 <td valign="top" class="tdDlg">
34                     <input id="btnSend" type="button" value="發送" disabled onclick="btnSend_onclick();" />
35                 </td>
36             </tr>
37         </table>
38     </div>
39 </div>
40 <div id="divRight">用戶列表:</div>
41 </body>
42 </html>

 

靜態css文件:瀏覽器

 1 h1{
 2     font-family: Arial,Helvetica,sans-serif;
 3     font-weight: bold;
 4     font-size: 14pt;
 5     color: #006bb5;
 6     background-color: #f0f0f0;
 7     border-radius: 5px;
 8     border: 1px solid #f0f0f0;
 9     padding: 5px;
10     margin: 0 0 18px 0;
11 }
12 div[id^=divContainer]{
13     border: 0;
14     margin: 10px 0;
15     padding: 3px;
16     background-color:#f0f0f0;
17     border-radius: 5px;
18 }
19 div#divLeft{
20     width: 85%;
21     background-color:#f0f0f0;
22     float: left;
23 }
24 div#divRight{
25     width: 15%;
26     background-color:white;
27     float: right;
28     font-weight: bold;
29     font-size: 12px;
30 }
31 div#divchat{
32     border: 0;
33     margin: 10px 0;
34     padding: 3px;
35     background-color:#f0f0f0;
36     border-radius: 5px;
37     position: relative;
38     height: 300px;
39     overflow: auto;
40     font-size: 12px;
41 }
42 table.tbDlg{
43     font-family:Verdana,Helvetica,sans-serif;
44     font-weight: normal;
45     font-size: 12px;
46     background-color: #f0f0f0;
47 }
48 tr.trDlg,td.tdDlg {
49     background-color: #f0f0f0;
50     font-size: 10px;
51 }
52  textarea{
53      font-family: inherit;
54      font-size: 10pt;
55      border:1px solid #444;
56      background-color:white;
57      width: 100%;
58 }
59  input[type="button"]{
60      font-family: inherit;
61      border: 1px solid #808080;
62      border-radius: 10px;
63      margin: 1px;
64      color: white;
65      background-color:#81a0b5;
66      width: 100px;
67  }
68 input[type="button"]:hover{
69     margin: 1px;
70     background-color: #006bb5;
71 }
72 input[type="button"]:active{
73     margin: 1px;
74     font-weight: bold;
75     background-color:#006bb5;
76 }
77 input[type="button"]:focus{
78     margin: 0;
79     font-weight: bold;
80     background-color:#006bb5;
81 }

 

 

靜態js文件服務器

 1 var userName,//用戶登陸到socket.io聊天室中時所使用的用戶名
 2     socket,//與聊天服務器鏈接的socket端口對象
 3     tbxUsername,//用戶名文本框
 4     tbxMsg,//對話文本框
 5     divChat;//頁面中顯示消息區域
 6 function window_onload(){
 7     divChat=document.getElementById("divchat");
 8     tbxUsername=document.getElementById("tbxUsername");
 9     tbxMsg=document.getElementById("tbxMsg");
10     tbxUsername.focus();
11     tbxUsername.select();
12 }
13 
14 function AddMsg(msg){
15     divChat.innerHTML+=msg+"<br>";
16     if(divChat.scrollHeight>divChat.clientHeight)
17         divChat.scrollTop=divChat.scrollHeight-divChat.clientHeight;
18 }
19 function btnLogin_onclick(){
20     if(tbxUsername.value.trim()==""){
21         alert("請輸入用戶名");
22         return;
23     }
24     userName=tbxUsername.value.trim();
25     socket=io.connect();
26     socket.on("connect",function(){
27         AddMsg("與聊天服務器的鏈接已創建.");
28         socket.on("login", function (name) {
29             AddMsg("歡迎用戶"+name+"進入聊天室.");
30         });
31         socket.on("sendClients", function (names) {
32             var divRight=document.getElementById("divRight");
33             var str="";
34             names.forEach(function (name) {
35                 str+=name+"<br />";
36             });
37             divRight.innerHTML="用戶列表<br />";
38             divRight.innerHTML+=str;
39         });
40         socket.on("chat", function (data) {
41             AddMsg(data.user+"說:"+data.msg);
42         });
43         socket.on("disconnect", function () {
44             AddMsg("與聊天服務器的鏈接已斷開.");
45             document.getElementById("btnSend").diabled=true;
46             document.getElementById("btnLogout").disabled=true;
47             document.getElementById("btnLogin").disabled="";
48             var divRight=document.getElementById("divRight");
49             divRight.innerHTML="用戶列表";
50         });
51         socket.on("logout", function (name) {
52             AddMsg("用戶"+name+"已退出聊天室.")
53         });
54         socket.on("duplicate", function () {
55             alert("該用戶名已被使用.");
56             document.getElementById("btnSend").disabled=true;
57             document.getElementById("btnLogout").disabled=true;
58             document.getElementById("btnLogin").disabled="";
59         });
60     });
61 
62     socket.on("error", function (err) {
63         AddMsg("與聊天服務器之間的連接發生錯誤.");
64         socket.disconnect();
65         socket.removeAllListeners("connect");
66         io.sockets={};
67     });
68     socket.emit("login",userName);
69     document.getElementById("btnSend").disabled="";
70     document.getElementById("btnLogout").disabled="";
71     document.getElementById("btnLogin").disabled=true;
72 }
73 
74 function btnSend_onclick(){
75     var msg=tbxMsg.value;
76     if(msg.length>0){
77         socket.emit("chat",{user:userName,msg:msg});
78         tbxMsg.value="";
79     }
80 }
81 function btnLogout_onclick(){
82     socket.emit("logout",userName);
83     socket.disconnect();
84     socket.removeAllListeners("connect");
85     io.sockets={};
86     AddMsg("用戶"+userName+"退出聊天室:");
87     var divRight=document.getElementById("divRight");
88     divRight.innerHTML="用戶列表";
89     document.getElementById("btnSend").disabled="disabled";
90     document.getElementById("btnLogout").disabled="disabled";
91     document.getElementById("btnLogin").disabled="";
92 }

最終界面app

 

能夠多開幾個瀏覽器進行測試.這樣效果更佳.socket

相關文章
相關標籤/搜索