導航:首頁 > 編程語言 > 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相關的資料

熱點內容
ipad怎麼看密碼是多少錢 瀏覽:678
qq2014表情在哪個文件夾 瀏覽:115
iphone6s下載的文件在哪裡 瀏覽:332
網站怎麼查詢真假 瀏覽:507
視頻文件沒有圖標 瀏覽:944
文件圖標上有個鎖 瀏覽:87
ios9appstore空白 瀏覽:744
htmljs是什麼 瀏覽:852
win10自帶軟體卸載軟體卸載 瀏覽:552
蘋果刷機好多錢 瀏覽:275
mac怎麼滾動截屏網站 瀏覽:619
mtkflashtool教程 瀏覽:176
unicode代碼表 瀏覽:520
蘋果app為什麼搜不到仙劍奇俠傳了 瀏覽:198
c程序數組內存 瀏覽:589
數據線的水晶頭怎麼拆 瀏覽:462
學習編程可以干什麼兼職 瀏覽:920
linux開機啟動sh 瀏覽:133
微信網名獨立 瀏覽:607
城中村網路 瀏覽:272

友情鏈接