IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> websocket搭建简易的聊天室--勿喷 -> 正文阅读

[网络协议]websocket搭建简易的聊天室--勿喷

因为本人做了信息的存储所以还用到的mysql,如果不做存储的话只能吧相应的代码注释即可。

node初始化 npm init 安装以下两个依赖

"mysql": "^2.18.1",
"nodejs-websocket": "^1.7.2"

建立一个app.js

var ws = require("nodejs-websocket");
console.log("开始建立连接...")


var mysql = require('mysql');
console.log('开始连接数据库.....');
var connection = mysql.createConnection({
  host: '127.0.0.1',
  user: 'root',
  password: '123456',
  database: 'socker',
  port: '3306'
});
connection.connect();
console.log('连接数据库成功!');

var [user1, user2, user1Ready, user2Ready] = [null, null, false, false];
var count1 = 0
var count2 = 0

ws.createServer(function (conn) {
  conn.on("text", function (str) {
    console.log("收到的信息为:" + str)

    var obj = {}
    if (str.indexOf('mes') != -1) {
      obj = JSON.parse(str)
    }

    if (str === "user1") {
      user1 = conn;
      user1Ready = true;
    }
    if (str === "user2") {
      user2 = conn;
      user2Ready = true;
    }


    if (user2Ready) {
      // 查历史记录
      if (count2 == 0) {
        count2++
        let sql = 'SELECT * FROM message';
        connection.query(sql, function (err, result) {
          if (err) {
            console.log('[SELECT ERROR] - ', err.message);
            return;
          }

          console.log('--------------------------SELECT2222222222----------------------------');
          console.log(result);
          console.log('------------------------------------------------------------\n\n');
          for (let i in result) {
            let user = new String(result[i].user)
            let msg = new String(result[i].message)
            let defaultObj = { name: user, mes: msg }
            user2.sendText(JSON.stringify(defaultObj));
          }
        });
      } else {
        user2.sendText(str);
      }
    }

    if (user1Ready) {
      // 查历史记录
      if (count1 == 0) {
        count1++
        let sql = 'SELECT * FROM message';
        connection.query(sql, function (err, result) {
          if (err) {
            console.log('[SELECT ERROR] - ', err.message);
            return;
          }

          console.log('--------------------------SELECT11111111111----------------------------');
          console.log(result);
          console.log('------------------------------------------------------------\n\n');
          for (let i in result) {
            let user = new String(result[i].user)
            let msg = new String(result[i].message)
            let defaultObj = { name: user, mes: msg }
            user1.sendText(JSON.stringify(defaultObj));
          }
        });
      } else {
        user1.sendText(str);
      }
    }



    // 数据库存谁发的信息
    if (user1Ready && user2Ready) {
      if (str.indexOf('mes') != -1) {
        mysqlMessage(obj.name, obj.mes)
      }
    }
  })
  conn.on("close", function (code, reason) {
    connection.end();
    console.log("关闭连接")
  });
  conn.on("error", function (code, reason) {
    connection.end();
    console.log("异常关闭")
  });
}).listen(8001)


// 插入数据库数据
function mysqlMessage (name, message) {
  var addSql = 'INSERT INTO message(id,message,user) VALUES(0,?,?)';
  var addSqlParams = [message, name];
  connection.query(addSql, addSqlParams, function (err, result) {
    if (err) {
      console.log('[INSERT ERROR] - ', err.message);
      return;
    }

    console.log('--------------------------INSERT----------------------------');
    console.log('INSERT ID:', result);
    console.log('-----------------------------------------------------------------\n\n');
  });

}
console.log("WebSocket建立完毕")

建立两个页面

user1.html

<!doctype html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>user1</title>
  <style>
    #mes {
      width: 300px;
      height: 300px;
      border: 1px solid #666;
      overflow: auto;
      margin-bottom: 10px;
      padding: 5px;
    }

    li {
      text-decoration: none;
      background: #f4f4f4;
      padding: 5px;
      margin-top: 5px;
    }

    .tl {
      color: red;
      text-align: left;
    }

    .tr {
      color: green;
      text-align: right;
    }
  </style>
</head>

<body>
  <ul id="mes"></ul>
  <div class="kuang">
    <input type="text" value="" class="int">
    <button class="send">发送</button>
  </div>
  <script>
    var mes = document.getElementById("mes");
    if (window.WebSocket) {
      var ws = new WebSocket('ws://localhost:8001');

      ws.onopen = function (e) {
        console.log("连接服务器成功");
        ws.send("user1");
      }

      ws.onmessage = function (e) {
        console.log(e);
        if (e.data !== "user1" && e.data !== "user2") {
          console.log(e);
          var newData = JSON.parse(e.data);
          var node = document.createElement("LI");
          var textnode = document.createTextNode(newData.mes);
          node.appendChild(textnode);
          if (newData.name === "user2") {
            node.classList.add("tl")
            mes.appendChild(node);
          } else {
            node.classList.add("tr")
            mes.appendChild(node);
          }
        }
        document.querySelector(".send").onclick = function (e) {
          var obj = {
            name: "user1",
            mes: document.querySelector(".int").value
          }
          ws.send(JSON.stringify(obj));
          document.querySelector(".int").value = "";
        }
        // 回车事件
        document.onkeydown = function (event) {
          var e = event || window.event || arguments.callee.caller.arguments[0];
          if (e && e.keyCode == 13) { // enter 键
            var obj = {
              name: "user1",
              mes: document.querySelector(".int").value
            }
            ws.send(JSON.stringify(obj));
            document.querySelector(".int").value = "";
          }
        }

        ws.onclose = function (e) {
          console.log("服务器关闭");
        }

        ws.onerror = function () {
          console.log("连接出错");
        }
      }
    }
  </script>
</body>

</html>

user2.html

<!doctype html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>user2</title>
  <style>
    #mes {
      width: 300px;
      height: 300px;
      border: 1px solid #666;
      overflow: auto;
      margin-bottom: 10px;
      padding: 5px;
    }

    li {
      text-decoration: none;
      background: #f4f4f4;
      padding: 5px;
      margin-top: 5px;
    }

    .tl {
      color: red;
      text-align: left;
    }

    .tr {
      color: green;
      text-align: right;
    }
  </style>
</head>

<body>
  <ul id="mes"></ul>
  <div class="kuang">
    <input type="text" value="" class="int">
    <button class="send">发送</button>
  </div>
  <script>
    var mes = document.getElementById("mes");
    if (window.WebSocket) {
      var ws = new WebSocket('ws://10.238.91.55:8001');
      ws.onopen = function (e) {
        console.log("连接服务器成功");
        ws.send("user2");
      }

      ws.onmessage = function (e) {
        if (e.data !== "user1" && e.data !== "user2") {
          console.log(e);
          var newData = JSON.parse(e.data);
          var node = document.createElement("LI");
          var textnode = document.createTextNode(newData.mes);
          node.appendChild(textnode);
          if (newData.name === "user1") {
            node.classList.add("tl")
            mes.appendChild(node);
          } else {
            node.classList.add("tr")
            mes.appendChild(node);
          }
        }
        document.querySelector(".send").onclick = function (e) {
          var obj = {
            name: "user2",
            mes: document.querySelector(".int").value
          }
          ws.send(JSON.stringify(obj));
          document.querySelector(".int").value = "";
        }
        // 回车事件
        document.onkeydown = function (event) {
          var e = event || window.event || arguments.callee.caller.arguments[0];
          if (e && e.keyCode == 13) { // enter 键
            var obj = {
              name: "user2",
              mes: document.querySelector(".int").value
            }
            ws.send(JSON.stringify(obj));
            document.querySelector(".int").value = "";
          }
        }
      }

      ws.onclose = function (e) {
        console.log("服务器关闭");
      }

      ws.onerror = function () {
        console.log("连接出错");
      }
    }
  </script>
</body>

</html>

演示截图
user1 视角
在这里插入图片描述
user2视角

在这里插入图片描述
数据库简单的设计
在这里插入图片描述

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-02-19 01:33:50  更:2022-02-19 01:34:38 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 20:20:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码