ไม่สำคัญว่าโทเค็นถูกสร้างขึ้นบนเซิร์ฟเวอร์อื่นหรือไม่ คุณยังคงสามารถยืนยันได้หากคุณมีคีย์ลับและอัลกอริทึมที่ถูกต้อง
ลูกค้า
const {token} = sessionStorage;
const socket = io.connect('http://localhost:3000', {
query: {token}
});
เซิร์ฟเวอร์
const io = require('socket.io')();
const jwt = require('jsonwebtoken');
io.use(function(socket, next){
if (socket.handshake.query && socket.handshake.query.token){
jwt.verify(socket.handshake.query.token, 'SECRET_KEY', function(err, decoded) {
if (err) return next(new Error('Authentication error'));
socket.decoded = decoded;
next();
});
}
else {
next(new Error('Authentication error'));
}
})
.on('connection', function(socket) {
socket.on('message', function(message) {
io.emit('message', message);
});
});
โมดูลนี้ทำให้การพิสูจน์ตัวตนง่ายขึ้นมากทั้งในฝั่งไคลเอ็นต์และเซิร์ฟเวอร์ เพียงตรวจสอบตัวอย่างของพวกเขา
ลูกค้า
const {token} = sessionStorage;
const socket = io.connect('http://localhost:3000');
socket.on('connect', function (socket) {
socket
.on('authenticated', function () {
})
.emit('authenticate', {token});
});
เซิร์ฟเวอร์
const io = require('socket.io')();
const socketioJwt = require('socketio-jwt');
io.sockets
.on('connection', socketioJwt.authorize({
secret: 'SECRET_KEY',
timeout: 15000
})).on('authenticated', function(socket) {
console.log(`Hello! ${socket.decoded_token.name}`);
});