如何在socket.io/node.js/Express生成器聊天中添加用户名

时间:2021-02-09 19:42:44

How can I add usernames for each person that joins the chat with my express generator (ejs) chat? I have been able to set up socket io but I am struggling to add different usernames.

如何为每个与我的快速生成器(ejs)聊天加入聊天的人添加用户名?我已经能够设置socket io,但我正在努力添加不同的用户名。

index.ejs:

<!doctype html>
<html>

<head>
    <title>Socket.IO chat</title>
    <style>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }
        /*body { font: 13px Helvetica, Arial; }*/
        /*body { font: 13px Helvetica, Arial; background-color: red;}*/

        #sendme {
            background: #000;
            padding: 3px;
            position: fixed;
            bottom: 0;
            width: 100%;
        }

        #sendme input {
            border: 0;
            padding: 10px;
            width: 90%;
            margin-right: .5%;
        }

        #sendme button {
            width: 9%;
            background: rgb(130, 224, 255);
            border: none;
            padding: 10px;
        }

        #messages {
            list-style-type: none;
            margin: 0;
            padding: 0;
        }

        #messages li {
            padding: 5px 10px;
        }

        #messages li:nth-child(odd) {
            background: #eee;
        }
    </style>
</head>

<body>
    <ul id="messages"></ul>
    <form id="sendme" action="">
        <input id="m" autocomplete="off" /><button>Send</button>
    </form>
    <div class="span5 offset2" id="login">
        <form class="form-inline">
            <input type="text" class="input-small" placeholder="Your name" id="name">
            <input type="button" name="join" id="join" value="Join" class="btn btn-primary">
        </form>
        <script src="/socket.io/socket.io.js"></script>
        <script src="http://code.jquery.com/jquery-1.11.1.js"></script>
        <script>
            var socket = io();
            $("#sendme").submit(function() {
                socket.emit('chat message', $('#m').val());
                $('#m').val('');
                return false;
            });

            socket.on('chat message', function(msg) {
                $('#messages').append($('<li>').text(msg));
            });
        </script>
</body>

</html>

index.js:

var express = require('express');
var router = express.Router();

/* GET home page. */
router.get('/', function(req, res, next) {
    res.render('index', {
        title: 'Express'
    });
});

module.exports = function(io) {
    var app = require('express');
    //var router = app.Router();

    io.on('connection', function(socket) {
        console.log('a user connected');
        io.emit('chat message', "A user connected.");
        socket.on('chat message', function(msg) {
            console.log('message: ' + msg);
            io.emit('chat message', msg);
        });

        socket.on('disconnect', function() {
            console.log('user disconnected');
            io.emit('chat message', "A user disconnected.");
        });
    });

    return router;
}

1 个解决方案

#1


0  

An event connect is fired upon connecting and you can and should add socket.on('connect') to your index.html file and you can send the username in it:

连接时会触发事件连接,您可以并且应该将socket.on('connect')添加到index.html文件中,然后您可以在其中发送用户名:

index.html

socket.on('connect', function() {
  socket.emit('newuser', 'Marchhill');
};

sockets are objects so you can then add socket.username in the index.js:

套接字是对象,因此您可以在index.js中添加socket.username:

index.js

socket.on('newuser', function(username) {
  socket.username = username;
  console.log( socket.username + ' has connected');
};

#1


0  

An event connect is fired upon connecting and you can and should add socket.on('connect') to your index.html file and you can send the username in it:

连接时会触发事件连接,您可以并且应该将socket.on('connect')添加到index.html文件中,然后您可以在其中发送用户名:

index.html

socket.on('connect', function() {
  socket.emit('newuser', 'Marchhill');
};

sockets are objects so you can then add socket.username in the index.js:

套接字是对象,因此您可以在index.js中添加socket.username:

index.js

socket.on('newuser', function(username) {
  socket.username = username;
  console.log( socket.username + ' has connected');
};