Nodejs не смог отправить сообщение в онлайновый конкретный soket

Я пытаюсь реализовать простое push-уведомление, основанное на socket.io, в моем простом коде, чтобы практиковать, как я могу это сделать, я написал простой код, в моем коде я не могу отправить сообщение подключенному пользователю, когда используется протокол в систему я хранит socket.io с ключом на redis, но при отправке сообщения пользователю я получаю ключ как имя пользователя из redis и сохраненное значение socket.io из redis и пытаюсь отправить, я получаю тот же socket.io значение, но сообщение не отправлять пользователю

клиентская сторона:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>
        Document
    </title>
    </meta>
    <script src="https://cdn.socket.io/socket.io-1.4.5.js"></script>
    <script src="http://code.jquery.com/jquery-latest.min.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            $('#login').click(function () {
                socket.emit('login', {username: 'a', password: 'a'});
            });

            $('#mesage').click(function () {
                socket.emit('message', 'a');
            });
        });
    </script>
    <script>
        var socket = new io.connect('http://192.168.1.35:3000', {
            port      : 3000,
            transports: ['websocket']
        });

        socket.on('connect', function () {
            console.log('connected!');
        });

        socket.on('login', function (message) {
            console.log(message);
        });

        socket.on('message', function (message) {
            console.log(message);
        });

        socket.on('hello,', function (message) {
            console.log(message);
        });

        socket.on('success', function (data) {
            console.log(data);
        });

    </script>
</head>
<body>
<h3 id="login">
    login
</h3>

<h3 id="mesage">
    mesage
</h3>
</body>
</html>

сторона сервера:

var socket      = require('socket.io'),
    express     = require('express'),
    app         = express(),
    server      = require('http').createServer(app),
    io          = socket.listen(server),
    port        = process.env.PORT || 3000,
    redis       = require("redis"),
    redisClient = redis.createClient();

socket.on('connection', function (socket) {
    socket.on('login', function (data) {
        login(data.username, data.password, function (success, value) {
            if (success) {
                redisClient.exists(data.username, function (err, doesExist) {
                    if (err) return;
                    if (!doesExist) {
                        redisClient.set(data.username, socket.id);
                    }
                    else {
                        redisClient.del(data.username);
                        redisClient.set(data.username, socket.id);
                    }
                    log.info("SOCKET ID: " + socket.id);
                });
                socket.emit('login', {result: success, id: socket.id});
            } else {
                socket.emit('login', {result: false, id: socket.id});
            }
        });
    });
    socket.on('message', function (username) {
        redisClient.get(username, function (err, socketId) {
            if (err)
                socket.emit('message', err);
            io.to(socketid).emit('message', 'for your eyes only');
        });
    });

});

когда я нажимаю login, я получаю этот результат:

 Object { result=true,  id="/#A5sR-Xo-Owo97NvRAAAB"}

и когда я нажимаю на сообщение, я получаю этот результат:

user not connected /#A5sR-Xo-Owo97NvRAAAB

оба из socket.id совпадают, но клиент не получает никаких сообщений, а сервер возвращает это сообщение как user not connected

Ответ 1

Похоже, у вас есть опечатка в этом коде:

redisClient.get(username, function (err, socketId) {
    if (err)
        socket.emit('message', err);
    io.to(socketid).emit('message', 'for your eyes only');
});

Ваш обратный вызов получает socketId как второй аргумент, но при отправке сообщения вы используете socketId (строчный).

Также лучше выйти из функции при отправке сообщения об ошибке:

if (err) return socket.emit('message', err);

или

if (err) {
    socket.emit('message', err);
    return;
}

иначе могут возникнуть непредвиденные ошибки.

Надеюсь, что это поможет.