導航:首頁 > 編程語言 > nodejssocketio

nodejssocketio

發布時間:2024-11-02 10:49:42

❶ Vue.js如何使用Socket.IO的示例代碼



在很多需求業務中,都需要瀏覽器和伺服器實時通信來實現功能,比如:掃碼登錄(掃碼後,手機確認登錄,PC網頁完成登錄並跳轉)、訂單語言提醒等,這些都是建立在兩端實時通信的基礎上的。對前端而言,來實現瀏覽器和伺服器實時通信,最好的選擇就是Socket.IO庫,能夠快速的實現兩端實時通信功能。



1、什麼是 Socket.IO?

Socket.IO 是一個WebSocket庫,可以在瀏覽器和伺服器之間實現實時,雙向和基於事件的通信。它包括:Node.js伺服器庫、瀏覽器的javascript客戶端庫。它會自動根據瀏覽器從WebSocket、AJAX長輪詢、Iframe流等等各種方式中選擇最佳的方式來實現網路實時應用,非常方便和人性化,而且支持的瀏覽器最低達IE5.5

2、Socket.IO 主要特點



(1)、支持瀏覽器/Nodejs環境 (2)、支持雙向通信 (3)、API簡單易用 (4)、支持二進制傳輸 (5)、減少傳輸數據量

3、Vue.js 中 Socket.IO的使用



(1)客戶端

npm install vue-socket.io --save
main.js添加下列代碼

import VueSocketIO from 'vue-socket.io'

Vue.use(new VueSocketIO({
debug: true,
// 伺服器端地址
connection: 'http://localhost:3000',
vuex: {
}
}))
發送消息和監聽消息

//發送信息給服務端
this.$socket.emit('login',{
username: 'username',
password: 'password'
});
//接收服務端的信息
this.sockets.subscribe('relogin', (data) => {
console.log(data)
})
(2)服務端



服務端,我們基於express搭建node伺服器。

npm install --save express
npm install --save socket.io
index.js文件

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
app.get('/', function(req, res){
res.send('<h1>你好web秀</h1>');
});

io.on('connection',function(socket) {
//接收數據
socket.on('login', function (obj) {
console.log(obj.username);
// 發送數據
socket.emit('relogin', {
msg: `你好${obj.username}`,
code: 200
});
});
});

http.listen(3000, function(){
console.log('listening on *:3000');
});
然後啟動服務端服務

node index.js
客戶端即可查看效果。

4、Socket.IO有哪些事件



io.on('connect', onConnect);
function onConnect(socket){
// 發送給當前客戶端
socket.emit(
'hello',
'can you hear me?',
1,
2,
'abc'
);
// 發送給所有客戶端,除了發送者
socket.broadcast.emit(
'broadcast',
'hello friends!'
);
// 發送給同在 'game' 房間的所有客戶端,除了發送者
socket.to('game').emit(
'nice game',
"let's play a game"
);
// 發送給同在 'game1' 或 'game2' 房間的所有客戶端,除了發送者
socket.to('game1').to('game2').emit(
'nice game',
"let's play a game (too)"
);
// 發送給同在 'game' 房間的所有客戶端,包括發送者
io.in('game').emit(
'big-announcement',
'the game will start soon'
);
// 發送給同在 'myNamespace' 命名空間下的所有客戶端,包括發送者
io.of('myNamespace').emit(
'bigger-announcement',
'the tournament will start soon'
);
// 發送給指定 socketid 的客戶端(私密消息)
socket.to(<socketid>).emit(
'hey',
'I just met you'
);
// 包含回執的消息
socket.emit(
'question',
'do you think so?',
function (answer) {}
);
// 不壓縮,直接發送
socket.compress(false).emit(
'uncompressed',
"that's rough"
);
// 如果客戶端還不能接收消息,那麼消息可能丟失
socket.volatile.emit(
'maybe',
'do you really need it?'
);
// 發送給當前 node 實例下的所有客戶端(在使用多個 node 實例的情況下)
io.local.emit(
'hi',
'my lovely babies'
);
};

❷ java怎樣抓取網頁代碼中動態顯示的數據

不用Java去抓取啊,讓頁面將數據發送到後台不就好了??
如果是從別人的網站上抓取的話,應該也是可以的,好像用socketio可以的。看看nodejs是否可以搞定。

❸ 如何用websocket+nodejs實現web即時通信服務端

用websocket+nodejs實現web即時通信服務端,Socketio和nodejs配的不錯,建立了socket就可以listen和broadcast。

閱讀全文

與nodejssocketio相關的資料

熱點內容
iphone解鎖macbook 瀏覽:409
能用手機打開的腳本文件格式 瀏覽:19
win10的畫圖怎麼保存 瀏覽:933
糖果小號密碼轉換工具 瀏覽:805
mac雙系統win10ghost嗎 瀏覽:588
如何刪除光碟上的文件 瀏覽:900
maclinux開發 瀏覽:327
2014蘋果增產 瀏覽:701
數據線兩芯與五芯如何連 瀏覽:715
linux光碟文件 瀏覽:902
微信公眾號使用權歸誰 瀏覽:296
b250主板無法安裝win10 瀏覽:65
為什麼有的人可以做網站 瀏覽:390
桌面文件太多好嗎 瀏覽:209
引用外部css文件路徑 瀏覽:217
微信文章源碼 瀏覽:382
sqlqq資料庫代碼怎麼寫 瀏覽:965
tcs文件怎麼打開 瀏覽:102
沉迷網路對自己有哪些傷害 瀏覽:288
idf文件如何打開 瀏覽:806

友情鏈接