javascript - Socket.io 随机聊天

标签 javascript node.js sockets express

我使用:node.js、socket.io 1.37、express.io

我的index.html:

<!doctype html>
<html>
<head>
    <title>Socket.IO chat</title>
    <style>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }
        body {
            font: 13px Helvetica, Arial;
        }
        form {
            background: #000;
            padding: 3px;
            position: fixed;
            bottom: 0;
            width: 100%;
        }
        form input {
            border: 0;
            padding: 10px;
            width: 90%;
            margin-right: .5%;
        }
        form 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 action="">
        <input id="m" autocomplete="off" />
        <button>Send</button>
    </form>
    <script src="/socket.io/socket.io.js"></script>

    <script src="https://cdn.socket.io/socket.io-1.2.0.js"></script>
    <script src="http://code.jquery.com/jquery-1.11.1.js"></script>

    <script>
        var socket = io();
        $('form').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>

我的server.js:

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);

app.get('/', function(req, res) {
    res.sendfile('index.html');
});

io.on('connection', function(socket) {
    socket.on('chat message', function(msg) {
        io.emit('chat message', msg);
    });
});

http.listen(3000, function() {
    console.log('listening on *:3000');

});

io.on('connect', function(socket) {
    console.log('a user connected');

    socket.on('disconnect', function() {
        console.log('user disconnected');
    });
});

我想创建类似 chatrandom 的东西 随机的人( socket )在私有(private)房间连接(一个房间只能有两个 socket )

我需要做什么?我有这段代码,我认为开始很好,但我不知道下一步是什么。 你能给点建议,解释一下吗?

最佳答案

在向用户显示聊天框之前,您需要让他们选择一个唯一的用户名(并分配一个 ID)或类似的名称。

然后你将他们与没有聊天伙伴的其他人配对(查看你当前所有聊天的列表,让程序选择一个没有与之关联的两个 ID),并保存他们的互动在某种轻量级数据库中(Google“NoSQL for JavaScript”,MongoDB 很受欢迎)。

关于javascript - Socket.io 随机聊天,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34344290/

相关文章:

Javascript点击按钮改变背景颜色

node.js - 使用requirejs优化器时是否可以配置html文件中的内容?

c++ - 通过 Socket Creation/getsockname 查找本地 IP

javascript - 在字符串任务中查找最长的单词时出错(javascript)

javascript - 理解函数的原型(prototype)属性

node.js - Express:如何将变量传递给挂载的中间件

javascript - 如何在我的 React 应用程序中包含 "redux-file-upload"

sockets - 寻找 "hung socket simulator"以测试套接字超时

c - 如何以编程方式从 Web 下载文件?

javascript - 如何获取pdf文件中文本的坐标