亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue+node+socket io實現(xiàn)多人互動并發(fā)布上線全流程

 更新時間:2021年09月26日 11:49:18   作者:牛頓頓的apple  
這篇文章主要介紹了vue+node+socket io實現(xiàn)多人互動并發(fā)布上線全流程,本文給大家提到了socket.io相關(guān)用法概覽及開發(fā)流程,需要的朋友可以參考下

一、背景

 1. 前端使用vue + vuex + socket.io-client

npm install socket.io-client --save-dev

2. 后端使用node + express + socketio

1.搭建node開發(fā)環(huán)境

npm init -y

安裝所需依賴

npm install express --save-dev
npm install socket.io-client --save-dev

二、 socket.io相關(guān)用法概覽

1. 發(fā)送事件

socket.emit('事件名', data => {
	// data為要傳輸?shù)臄?shù)據(jù),可以為boolean, string, number, object等
})

2. 監(jiān)聽事件

socket.on('發(fā)送時的事件名', data => {
	// data發(fā)送事件傳過來的數(shù)據(jù)
})

3. 廣播事件

// 發(fā)送給其他用戶 (不對本身發(fā)送)
socket.broadcast.emit('事件名',  data => {
	// data為要傳輸?shù)臄?shù)據(jù),可以為boolean, string, number, object等
})

三、開發(fā)流程

1. 前端新建一個socket.js文件, 用于接收socket相關(guān)事件,具體如下

// 引入socket.io-client
import io from 'socket.io-client'

// 創(chuàng)建鏈接
const socket = io()

// 監(jiān)聽
socket.on('connect', () => {
  console.log('和服務(wù)器連接成功??!')
})

> =============中間部分用于監(jiān)聽后端發(fā)送的socket事件,例如:=====================
// 進入房間
socket.on('enter_room', (data) => {
  // 必要數(shù)據(jù)可存storage
  localStorage.setItem('counts', JSON.stringify(data))
  store.commit('setData', JSON.parse(localStorage.getItem('data')))
})

// 處理服務(wù)失去連接
socket.on('disconnect', () => {
  console.log('disconnect')
})

2. 后端部分相關(guān)代碼

const app = require('express')()
const http = require('http').Server(app)
var io = require('socket.io')(http)

let onlineUsers = {}
let users = []
let onlineCounts = 0

io.on('connection', socket => {
	// 用戶進入游戲
	socket.on('enter', (data) => 
		// 添加用戶信息
		const sid = socket.id
		socket.name = data.name

		// 添加新用戶
		if(!onlineUsers.hasOwnProperty(data.name)) {
			onlineUsers[data.name] = sid
			onlineCounts++
		}
		if (!users.length) {
			users.push({
				name: onlineUsers[sid]
			})
		}

		// 當(dāng)前人數(shù)
		let clientsCount = io.sockets.server.engine.clientsCount

		// 發(fā)送用戶列表給當(dāng)前用戶(對應(yīng)前端監(jiān)聽enter_room部分代碼)
		io.emit('enter_room', {
			role: data.role,
			users,
			onlineCounts
		})
		// 發(fā)送新進用戶給其他用戶 (不對本身發(fā)送)
		socket.broadcast.emit('user_enter', data.name)
	})
})

// 后端開啟監(jiān)聽端口, 前端通過配置proxyTable處代理到后端服務(wù)器,即可進行前后端數(shù)據(jù)對接
http.listen(port, () => {
	console.log('后端服務(wù)器啟動成功?。?!')
})

四、發(fā)布上線

1.前端:

1)安裝http-server,然后鏈接服務(wù)器,進入服務(wù)器后拉取遠(yuǎn)程倉庫的前端代碼(一般在服務(wù)器www目錄下拉?。绻麤]有克隆過代碼,需要在服務(wù)器配置公鑰,才能進行下載

公鑰配置

ssh-keygen -t rsa -C "你的郵箱"

生成公鑰后,進入公鑰生成的文件目錄,復(fù)制到代碼托管平臺,添加公鑰后就可以克隆代碼咯

2)打包前端代碼,生成dist文件

npm run build

3)進入dist,執(zhí)行命令,即可啟動前端

pm2 start http-server -- -p 指定端口號

4)前端訪問,服務(wù)器地址+端口號

2.后端:

1)和前端一樣(不用安裝http-server),進入服務(wù)器后拉取遠(yuǎn)程倉庫的前端代碼(一般在服務(wù)器www目錄下拉?。?,如果沒有克隆過代碼,需要在服務(wù)器配置公鑰,才能進行下載
2)執(zhí)行命令

pm2 start index.js(文件入口,如果你的是app.js為文件入口,就執(zhí)行app.js) -- -p 指定端口號

注意點:

socket.io在發(fā)布線上的時候前端得修改socket.io代理地址端口為后端端口,否則會報404,修改位置如下(這里我的后端端口為3000)

在這里插入圖片描述

2. nginx需要修改socket.io的代理轉(zhuǎn)發(fā)地址,否則也會報404

在這里插入圖片描述 

補充 1.pm2 常用指令

pm2 list // 查看pm2啟動列表
pm2 stop 指定端口號 // 停止當(dāng)前端口下的pm2
pm2 restart 指定端口號 // 重啟指定端口的pm2
pm2 delete 指定端口號 // 刪除當(dāng)前窗口下的pm2
pm2 start http-server / index.js -- -p  指定端口號 // 啟動對應(yīng)的前后端

2. nginx在命令行中的相關(guān)指令

cd /nginx指定目錄
cat nginx.conf // 查看nginx文件內(nèi)容
vim nginx.conf // 編輯nginix,注意進入后使用 "i"進行編輯模式;"u"撤銷上一步編輯;"esc"退出編輯模式;"shift + :"保存并退出

至此,按照上述步驟,就可以進行socket相關(guān)的任何類型開發(fā)拉,快去試試吧,有問題的小伙伴記得留言哦_

到此這篇關(guān)于vue+node+socketio實現(xiàn)多人互動并發(fā)布上線全流程的文章就介紹到這了,更多相關(guān)vue socketio實現(xiàn)多人互動內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 如何解決element-ui中多個table在tab切換時出現(xiàn)寬度縮小問題

    如何解決element-ui中多個table在tab切換時出現(xiàn)寬度縮小問題

    這篇文章主要介紹了如何解決element-ui中多個table在tab切換時出現(xiàn)寬度縮小問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue使用Pinia輕松實現(xiàn)狀態(tài)管理

    Vue使用Pinia輕松實現(xiàn)狀態(tài)管理

    pinia,一個基于Vue3的狀態(tài)管理庫,它可以幫助開發(fā)人員管理Vue應(yīng)用程序的狀態(tài),本文主要為大家介紹了Pinia的用法,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-06-06
  • VUE使用vue?create命令創(chuàng)建vue2.0項目的全過程

    VUE使用vue?create命令創(chuàng)建vue2.0項目的全過程

    vue-cli是創(chuàng)建Vue項目的一個腳手架工具,vue-cli提供了vue create等命令,下面這篇文章主要給大家介紹了關(guān)于VUE使用vue?create命令創(chuàng)建vue2.0項目的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • vue處理emoji表情占位符的操作方法

    vue處理emoji表情占位符的操作方法

    在計算字符數(shù)時,一般情況下,英文字符、數(shù)字和大部分符號都可以被視為占一個字符長度,因為它們是單個字節(jié),然而,對于某些特殊字符,如表情符號和部分非英文字符,會被認(rèn)為占據(jù)了多個字符長度,本文給介紹了vue處理emoji表情占位符的操作方法,需要的朋友可以參考下
    2024-06-06
  • Vue Router去掉url中默認(rèn)的錨點#

    Vue Router去掉url中默認(rèn)的錨點#

    vue-router默認(rèn)hash模式——使用URL的hash來模擬一個完整的URL,于是當(dāng)URL改變時,頁面不會重新加載。這篇文章主要介紹了Vue Router去掉url中默認(rèn)的錨點#,需要的朋友可以參考下
    2018-08-08
  • vue3 vite pinia配置動態(tài)路由、解決刷新頁面路由消失的問題

    vue3 vite pinia配置動態(tài)路由、解決刷新頁面路由消失的問題

    這篇文章主要介紹了vue3 vite pinia配置動態(tài)路由、解決刷新頁面路由消失的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue使用axios引起的后臺session不同操作

    Vue使用axios引起的后臺session不同操作

    這篇文章主要介紹了Vue使用axios引起的后臺session不同操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue前端重構(gòu)computed及watch組件通信等實用技巧整理

    vue前端重構(gòu)computed及watch組件通信等實用技巧整理

    這篇文章主要為大家介紹了vue前端重構(gòu)computed及watch組件通信等實用技巧整理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • Vue移動端下拉加載更多數(shù)據(jù)onload實現(xiàn)方法淺析

    Vue移動端下拉加載更多數(shù)據(jù)onload實現(xiàn)方法淺析

    這篇文章主要介紹了Vue移動端下拉加載更多數(shù)據(jù)onload實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • vant/vue跨域請求解決方案

    vant/vue跨域請求解決方案

    這篇文章主要介紹了vant/vue跨域請求解決方案,需要的朋友可以參考下
    2022-12-12

最新評論