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

熱點內容
奇跡13單機系統找不到指定文件 瀏覽:719
flyme魅藍3以前的版本 瀏覽:318
安卓文件管理哪些文件夾可以刪除 瀏覽:290
安卓車載導航沒有聲音是怎麼回事 瀏覽:810
cjson數組格式 瀏覽:159
vb文件在哪裡 瀏覽:215
工廠里都招什麼編程人員 瀏覽:932
jspsql登錄 瀏覽:981
網路用語粉絲閱讀什麼意思 瀏覽:333
紅頭文件怎麼列印 瀏覽:94
熱血江湖130刺客升級 瀏覽:106
jsp頁面放大鏡技術介紹 瀏覽:101
網路編程udp 瀏覽:148
加密壓縮文件如何打開 瀏覽:56
微軟編程軟體有哪些 瀏覽:736
linux目錄中創建文件夾許可權設置密碼 瀏覽:759
word文檔正式文件模版 瀏覽:247
linux文件系統的類型是 瀏覽:111
蘋果的無線傳輸文件找不到了 瀏覽:102
密件文件名能出現在通知嗎 瀏覽:832

友情鏈接