首先是下載包: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 用戶名: 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