Nodejs+Socket.io+Web端完成聊天

前言

源碼獲取:node+express+socket.io+web: 聊天demo (gitee.com)

目錄結構

后端依賴

啟動方式

前端是html正常啟動

后端是node app.js

后端app.js核心代碼

const express = require('express')
const app = express()
var http = require('http').Server(app)
var io = require('socket.io')(http, { cors: true })
var name = ""
var count = 0
app.all('*', function(req, res, next) {  res.header("Access-Control-Allow-Origin", "*");  res.header("Access-Control-Allow-Headers", "X-Requested-With");  res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");  res.header("X-Powered-By",' 3.2.1')  res.header("Content-Type", "application/json;charset=utf-8");  next();  
});   
app.get('/',(req,res)=>{// 保存用戶的名稱name = req.query.username// 返回狀態碼,通過狀態碼執行客戶端頁面跳轉res.send({state:200})// res.sendFile(__dirname + '/index.html')
})
//入口函數,連接進程
io.on('connection', function (socket) {// 每建立連接一次,在線人數減一count++//這里是發送消息// on用來監聽客戶端message事件,回調函數處理。socket.on('message', function (msg) {// 如果在這里通過url解析的username來改變下面33行即將渲染的name,會出現異步問題。name還沒有賦值就被傳到客戶端// 所以通過ajax請求,先讓后端拿到username,然后再做提示信息的渲染console.log(msg.username+':'+ msg.inpval);// 將客戶端發送來的消息中轉給所有客戶端io.emit('message', msg)});// loginin是自定義事件,第二個參數返回數據對象用于渲染,用于登陸后向客戶端發送用戶登錄信息io.emit('loginin',{count,des:'溫馨提示:'+name+'加入聊天室'})//登陸后向客戶端發送用戶退出信息socket.on('disconnect', function () {// loginout是自定義事件,第二個參數返回數據對象用于渲染count--io.emit('loginout',{count,des:'溫馨提示:'+name+'用戶退出聊天室'})// 連接每斷開一次,在線人數減一})
});
http.listen(3000, function () {console.log('listening:3000')
})

html部分

<!doctype html>
<html><head><title>Socket.IO chat</title><style>* {margin: 0;padding: 0;box-sizing: border-box;}.chat {width: 400px;margin: 0 auto;border: 1px solid #333;}.title {line-height: 30px;color: black;border-bottom: 1px solid #999;text-align: center;}.content {width: 100%;overflow: auto;height: 500px;}#messages li {list-style: none;padding: 5px;}#m {width: 80%;height: 30px;outline: none;color: #666}#btn {width: 20%;height: 30px;cursor: pointer;}.tips {width: 50%;margin: 4px auto;padding: 2px 5px;text-align: center;font-size: 8px;border-radius: 10px;background-color: #cfcfcf;color: #fff}.title #people {font-size: 8px;color: #999;}</style>
</head><body><div class="chat"><div class="title"><h3>聊天室<span id="people">(0)</span></h3></div><div class="content"><ul id="messages"></ul></div><input id="m" autocomplete="off" /><button id="btn">Send</button></div>
</body>
<script src="./static/dist/socket.io.js"></script>
<script>// 通過url獲取usernamevar test = window.location.href;var username = decodeURI(test.split("?username=")[1]);// 做個判斷if (localStorage.getItem('username') != '') {var socket = io('http://localhost:3000/')var btn = document.getElementById('btn')var ul = document.getElementById('messages')let cxt = document.getElementById('m')let people = document.getElementById('people')// 點擊send按鈕,把消息發送給服務器btn.onclick = function () {// 把登錄的用戶名和輸入框內容全部發送給服務器,讓服務器做一次廣播,才能同步用戶信息。socket.emit('message', { username, inpval: cxt.value })return false}//監聽服務器的廣播消息,同步用戶信息,msg就是點擊發送按鈕發送的用戶信息socket.on('message', function (msg) {// 每個客戶端將用戶的消息渲染var newli = document.createElement("li")newli.innerHTML = msg.username + ':' + msg.inpvalul.appendChild(newli)cxt.value = ''})// 服務器端監聽服務端建立連接發來的信息,用于渲染溫馨提示信息,msg是服務器返回廣播的用戶對象數據socket.on("loginin", function (msg) {// 生成用戶進入房間提示信息標簽let tip = document.createElement("p")tip.innerHTML = msg.des// 設置樣式tip.className = "tips"ul.appendChild(tip)// people是顯示當前聊天室人數people.innerHTML = '(' + msg.count + ')'})//服務器端監聽服務端建立連接發來的信息,msg是服務器返回廣播的用戶對象數據socket.on("loginout", function (msg) {// 生成用戶退出提示信息let tip = document.createElement("p")tip.innerHTML = msg.destip.className = "tips"ul.appendChild(tip)people.innerHTML = '(' + msg.count + ')'})} else {window.location.href = "/login.html"}</script></html>

聯系方式

v:13053025350,歡迎詢問,也歡迎接單選手>>>>>

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/15593.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/15593.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/15593.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

掌握C++回調:按值捕獲、按引用捕獲與弱引用

文章目錄 一、按引用捕獲和按值捕獲1.1 原理1.2 案例 二、弱引用2.1 原理2.2 案例一2.3 案例二&#xff1a;使用base庫的弱引用 三、總結 在C回調中&#xff0c;當使用Lambda表達式捕獲外部變量時&#xff0c;有兩種捕獲方式&#xff1a;按值捕獲和按引用捕獲。 一、按引用捕獲…

Matlab自學筆記三十:元胞數組的修改、添加、刪除和連接

1.說明 元胞數組的子數組或元素也是元胞型的&#xff0c;其元素內容&#xff08;值&#xff09;是本身類型&#xff0c;因此&#xff0c;在添、刪、改和連接處理時&#xff0c;必須明確每個元素的值的類型和大小&#xff0c;否則&#xff0c;編程報錯是不可避免的了。看本文前…

Python 點云裁剪

點云裁剪 一、介紹1.1 概念1.2 函數講解二、代碼示例2.1 代碼實現2.2 代碼講解三、結果示例一、介紹 1.1 概念 點云裁剪 :根據待裁剪對象的多邊形體積(json文件)實現點云的裁剪。 1.2 函數講解 下面代碼示例中主要用到了兩個函數。 讀取待裁剪對象的多邊形體積信息(json文…

淺談C++函數

目錄 一、函數的概念二、調用函數的兩個前提三、函數傳參的三種形式四、函數返回類型 一、函數的概念 函數是C程序的基本模塊&#xff0c;通常一個C程序由一個或多個函數組成。函數可以完成用戶指定的任務&#xff0c;一般分為庫函數和用戶自定義的函數。函數由函數頭和函數體…

先進制造aps專題六 aps軟件開發最大的難點,設備甘特圖開發

aps軟件開發最大的難點&#xff0c;設備甘特圖開發 一般認為&#xff0c;aps軟開發中&#xff0c;算法是難的&#xff0c;排程算法難&#xff0c;優化算法更難&#xff0c;但其實最大的難點是設備甘特圖開發 aps軟件設備甘特圖開發的幾個難點如下 1 和項目甘特圖一行顯示一個…

02. Flink 快速上手

02. Flink 快速上手 1、創建項目導入依賴 pom文件&#xff1a; <properties><flink.version>1.17.0</flink.version> </properties><dependency><groupId>org.apache.flink</groupId><artifactId>flink-streaming-java<…

k8s配置pods滾動發布

背景 采用微服務架構部署的應用&#xff0c;部署方式都要用到容器化部署k8s容器編排&#xff0c;最近我在公司負載的系統也是用的上述架構部署&#xff0c;但是隨著系統的運行&#xff0c;用戶提的需求就會越多&#xff0c;每次更新的話都要停機發布&#xff0c;最用戶側來說就…

【C語言刷題系列】求一個數組中兩個元素a和b的和最接近整數m

&#x1f493; 博客主頁&#xff1a;倔強的石頭的CSDN主頁 &#x1f4dd;Gitee主頁&#xff1a;倔強的石頭的gitee主頁 ? 文章專欄&#xff1a;C語言刷題系列 目錄 一、問題描述 二、解題思路 解題思路&#xff1a; 解題步驟: 三、C語言代碼實現及測試 一、問題描述 給定一…

指北者智能音樂學習機隆重亮相廣州國際樂器展

2024年5月23-26日廣州國際樂器展覽會在廣交會展館B區隆重開幕&#xff0c;本屆展會開設5大展廳、50000平方米的主題展區&#xff0c;吸引了700多家國內外參展商參展&#xff0c;打造集展示、商貿、文化交流、文娛于一體的廣闊平臺。深圳市指北科技有限公司也攜旗下品牌指北者智…

AWS云服務器每月費用高昂,如何優化達到節省目的?

AWS云服務器每月費用可能因不同的使用情況和配置而有所不同。為了優化并節省AWS云服務器的費用&#xff0c;aws的合作伙伴九河云提供了一些建議&#xff1a; &#xff08;1&#xff09;調整實例大小&#xff1a;確保你使用的實例大小與你的工作負載相匹配。實例的容量每增加一倍…

Gopeed的高級用法

Gopeed是一個開源全平臺下載器&#xff0c;具體簡介請參考&#xff1a; “狗屁下載器”&#xff1f;Gopeed - 開源全平臺下載器 (免費輕量 / 比 Aria2 好用 / 遠程下載) - 異次元軟件世界 (iplaysoft.com) 這里主要介紹下自己摸索出來的 Gopeed 的高級做法。 有的網站添加的…

時政|醫療結果互認

背景&#xff08;存在的問題&#xff09; 看同一種病&#xff0c;換一家醫院甚至換一個院區、換一個科室&#xff0c;檢查檢驗還得再來一遍&#xff0c;費錢又費時。開展檢查檢驗結果互認&#xff0c;可以明顯減輕患者就醫負擔。患者不用做重復檢查&#xff0c;也可節約就醫時…

基于JSP/Servlet校園二手交易平臺(二)

目錄 2 開發技術及開發環境 2.1 Java語言簡介 2.2 J2EE技術介紹 2.3 Servlet/JSP技術 2.4 MVC 簡介 2.5 Struts 技術 2.6 Hibernate 技術 2.6.1 應用程序的分層體系結構 2.6.2 Hibernate的應用及API簡介 2.7 開發環境及環境配置 2.7.1 Java/JSP系統環境 2.7.2 JSP環…

D365 SysDictTable\SysDictField

文章目錄 前言一、示例 前言 SysDictField 和 SysDictTable 用于訪問表和字段的元數據信息。 一、示例 循環表&#xff0c;使對應數據源的字段禁止編輯 public void fieldNoAllowEdit(Common _common,formDataSource fds,boolean aE false){TableId tab…

小程序-購物車-基于SKU電商規格組件實現

SKU 概念&#xff1a; 存貨單位&#xff08; Stock Keeping Unit &#xff09;&#xff0c; 庫存 管理的最小可用單元&#xff0c;通常稱為“單品”。 SKU 常見于電商領域&#xff0c;對于前端工程師而言&#xff0c;更多關注 SKU 算法 &#xff0c;基于后端的 SKU 數據…

(二)vForm 動態表單設計器之下拉、選擇

系列文章目錄 &#xff08;一&#xff09;vForm 動態表單設計器之使用 目錄 系列文章目錄 前言 一、后端需提供接口 二、組件配置 總結 前言 動態表單下拉、選擇等組件&#xff0c;大概率要使用數據庫中的數據&#xff0c;那么vForm如何拿到數據庫中的數據呢&#xff1f;跟隨…

僵尸進程、孤兒進程、守護進程

【一】僵尸進程和孤兒進程 【1】引入 我們知道在unix/linux中&#xff0c;正常情況下&#xff0c;子進程是通過父進程創建的&#xff0c;子進程在創建新的進程。 子進程的結束和父進程的運行是一個異步過程,即父進程永遠無法預測子進程 到底什么時候結束。 當一個 進程完成它…

動物合并消除休閑游戲源碼 Animal Merge 益智游戲

一款動物合并消除休閑游戲源碼&#xff0c;Animal Merge是一款引人入勝的益智游戲&#xff0c;玩家的任務是合并方塊&#xff0c;創造出可愛的動物&#xff0c;這些動物的體型會逐漸變大。游戲玩法包括將方塊放到網格上&#xff0c;并戰略性地將它們合并以形成更大的動物形狀。…

作文筆記9 描寫方法

動態描寫&#xff1a; 威尼斯小艇&#xff0c;窗外的風景飛快的后退。 靜態描寫&#xff1a; 牧場之國&#xff0c;牛不再哞哞&#xff0c;馬忘記了踢馬房的擋板。 動靜結合&#xff1a; 火車進站&#xff0c;人聲鼎沸&#xff0c;叫賣聲&#xff0c;廣播聲&#xff0c;人…

【408精華知識】主存相關解題套路大揭秘!

講完了Cache&#xff0c;再來講講主存是怎么考察的&#xff0c;我始終認為&#xff0c;一圖勝千言&#xff0c;所以對于很多部件&#xff0c;我都是通過畫圖進行形象的記憶&#xff0c;那么接下來我們對主存也畫個圖&#xff0c;然后再來詳細解讀其考察套路~ 文章目錄 零、主存…