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

熱點內容
水準測量平差程序 瀏覽:78
cf如何解決網路誤封 瀏覽:952
折疊式文件夾是什麼意思 瀏覽:796
js彈窗登錄注冊 瀏覽:563
怎麼把游戲數據備份到另一個手機 瀏覽:361
微信封殺搶紅包神器破解教程 瀏覽:536
帶貨數據什麼時候更新 瀏覽:500
微信通訊錄復制到手機 瀏覽:498
編程貓怎麼連接音響 瀏覽:589
有沒有什麼app在家點餐 瀏覽:501
win10視頻文件看不到縮略圖注冊表 瀏覽:238
請上傳文件和視頻英語 瀏覽:413
win10拷貝文件失敗拒絕訪問 瀏覽:189
什麼叫app推廣報備 瀏覽:414
win10的文件查找在哪裡設置密碼 瀏覽:617
蘋果6plusitunesstore 瀏覽:971
qqiphone6在線手機軟體 瀏覽:407
文件怎麼轉發 瀏覽:94
數控機床編程與操作怎麼啟動 瀏覽:636
linux查找c文件是否存在 瀏覽:150

友情鏈接