• Express+Socket.IO 实现简易聊天室


    代码地址如下:
    http://www.demodashi.com/demo/12477.html

    logo

    闲暇之余研究了一下 Socket.io,搭建了一个简易版的聊天室,如有不对之处还望指正,先上效果图:
    首先是登录页面:

    login

    接下来就是聊天页面:

    chatmsg1
    chatmsg2

    Socket.IO是Node.js的一个模块,它提供通过WebSocket进行通信的一种简单方式,WebSocket协议很复杂,但是Socket.IO提供了服务器和客户端双方的组件,所以只需要一个模块就可以给应用程序加入对WebSocket的支持,而且还能支持不同的浏览器哦。关于其详细介绍请参考官网SocketIO 官网,这里呢我们还是直接上代码。

    首先是创建 Socket 服务, 我们的项目启动文件 bin/www,我们就来修改它:

    // bin/www
    var app = require('../app');
    var debug = require('debug')('websocket:server');
    var http = require('http');
    
    /**
     * Get port from environment and store in Express.
     */
    
    var port = normalizePort(process.env.PORT || '3070');
    app.set('port', port);
    
    /**
     * Create HTTP server.
     */
    
    var server = http.createServer(app);
    var io = require('socket.io').listen(server);   //创建 socket 服务
    io.on('connection',function(socket){            //监听客户端的连接请求
      socket.emit('connected',"连接成功");
      socket.on('message',function(msg){            //监听客户端发送的消息
        console.log(msg);   
        socket.emit('content',msg);                 // 向客户端发送反馈消息
        socket.broadcast.emit('content',msg);       // 向所有的已连接客户端进行广播消息
      });
    });
    /**
     * Listen on provided port, on all network interfaces.
     */
    
    server.listen(port);
    server.on('error', onError);
    server.on('listening', onListening);
    ...
    ...
    

    在这里我做了一个小的登录控制,也就是 session 的简单使用,具体看下边的路由控制:

    //  routes/index.js
    var express = require('express');
    var router = express.Router();
    
    /* GET home page. */
    router.get('/', function(req, res) {
      res.render('login');
    });
    router.post('/login',function(req,res){
      var name=req.body.name;
      req.session.name=name;
      res.send("success");
    });
    router.get('/index',function(req,res){
      if(req.session.name!=null && req.session.name!=""){
        res.render('index',{name:req.session.name});
      }else{
        res.redirect('/');
      }
    });
    module.exports = router;
    
    

    然后接下来创建客户端登录页面:

    // views/login.html
    <!DOCTYPE html>
    <html>
    <head lang="en">
        <meta charset="UTF-8">
        <title>登录简化聊天室</title>
        <link rel="bookmark"  type="image/x-icon"  href="images/chat.ico"/>
        <link rel="shortcut icon" href="images/chat.ico">
        <link rel="icon" href="img/images/chat.ico">
        <link rel="stylesheet" href="js/bootstrap.css" type="text/css" />
        <style>
            .tips{
                font-size: 28px;
                font-family: "楷体";
                padding: 10px;
            }
            .contentMain{
                 600px;
                height: 500px;
                position:absolute;
                left:35%;
                top:40%;
                z-index: 999;
            }
        </style>
    </head>
    <body>
    <div class="loginImg" style="margin: 4% 0;">
        <img src="images/005.jpg" style=" 100%;"/>
    </div>
    
    <div class="contentMain">
        <div class="row tips">请先输入你在聊天室的昵称 </div>
        <div class="row form-group">
            <span class="col-md-6">
                <input type="text" id="name" class="form-control" placeholder="昵称"/>
            </span>
            <span class="col-md-3">
                <button class="btn btn-default" id="login">确认</button>
            </span>
        </div>
    </div>
    <script type="text/javascript" src="js/jquery.js"></script>
    <script type="text/javascript" src="js/bootstrap.js"></script>
    <script>
        $(function(){
           $('button').click(function(){
               var name=$('#name').val();
               $.post('/login',{name:name},function(data){
                   if(data=="success"){
                       window.location.href='/index';
                   }
               });
           })
        });
    </script>
    </body>
    </html>
    

    聊天室页面:

    //  views/index.html
    <!DOCTYPE html>
    <html>
    <head lang="en">
        <meta charset="UTF-8">
        <title>简化聊天室</title>
        <link rel="bookmark"  type="image/x-icon"  href="images/chat.ico"/>
        <link rel="shortcut icon" href="images/chat.ico">
        <link rel="icon" href="img/images/chat.ico">
        <link rel="stylesheet" href="js/bootstrap.css" type="text/css" />
        <style>
            body{
                font-size: 20px;
                font-family: "楷体";
            }
            .contentMain{
                 700px;
                height: 800px;
                position:absolute;
                left:5%;
                top:6%;
                z-index: 999;
            }
            .welcome{
                height: 6%;
                font-family: "楷体";
                font-size:35px;
                background-color: #d0e9c6;
            }
            .chatContent{
                height:600px;
                border-radius: 5px;
                border: 1px solid #555555;
                overflow-y: auto;
                overflow-x: hidden;
                padding: 5px;
                margin-bottom: 20px;
            }
            .talkString{
                margin-top:15px;
            }
            .myTalk{
                border:1px solid #00B7FF;
                border-radius: 5px;
                 auto;
                padding: 5px;
                background-color: #d6e9c6;
            }
            #content{
                padding:2px 10px 2px 10px;
            }
        </style>
    </head>
    <body>
    <div class="welcome" align="center">
        欢迎您: <span id="name"><%=name%></span>
    </div>
    <div class="bgImage">
        <img src="images/005.jpg" style=" 100%;height: 100%"/>
    </div>
    <div class="contentMain">
    
        <div class="chatContent">
            <span>聊天记录:</span>
            <div id="content"></div>
        </div>
        <div class="row">
            <span class="col-md-10">
                <span class="col-md-2"> 内容:</span>
                <span class="col-md-10">
                    <input type="text" id="myWord" class="form-control" placeholder="请输入要发送的内容"/>
                </span>
            </span>
            <span class="col-md-2">
                <button class="btn btn-default">发送</button>
            </span>
        </div>
    </div>
    
    <script type="text/javascript" src="js/jquery.js"></script>
    <script type="text/javascript" src="js/socket.io.js"></script>
    <script type="text/javascript" src="js/bootstrap.js"></script>
    <script type="text/javascript" src="js/main.js"></script>
    </body>
    </html>
    

    最后实现我们客户端的 socket,进行与服务端进行通信:

    //   js/main.js
    $(function(){
    	var name = $('#name').text();
        // 向服务器发起连接请求
    	var socket = io.connect('http://localhost:3070');
    	socket.on('connected',function(){  // 监听连接信息
    		console.log('已连接');
    		socket.send("系统:"+name+" 连接成功");   // 向客户端发送消息
    	});
    	socket.on('content',function(msg){          // 监听服务器发送的消息
    		var talker="";
    		var talk="";
    		var talkString="";
    		if(msg.indexOf(':')>0){
    			talker=msg.substring(0,msg.indexOf(':'));
    			if(msg.indexOf("<script>")>0&&msg.indexOf("</script>")>0) {
    				msg = msg.replace("<script>", "");
    				msg = msg.replace("</script>", "");
    			}
    			talk=msg.substring(msg.indexOf(':')+1);
    			if(talker==name){
    				talkString="<div class='row talkString' align='right'>" +
    					"<span class='myTalk'>"+talk+"</span>" +
    					"<span> "+talker+"</span>" +
    					"</div>";
    			}else{
    				talkString="<div class='row talkString'>" +
    					"<span>"+talker+": </span>" +
    					"<span class='myTalk'>"+talk+"</span>" +
    					"</div>";
    			}
    		}else{
    			talkString="<div class='row'>"+msg+"</div>";
    		}
    		$('#content').append(talkString);
    		scrollBar();
    	});
    	$('button').click(function(){
    		var myWord=$('#myWord').val();
    
    		if(socket){
    			socket.send(name+":"+myWord);
    			$('#myWord').val("");
    			scrollBar();
    		}else{
    			return;
    		}
    	});
    	//回车发送消息
    	document.onkeydown = function(e){
    		var ev = document.all ? window.event : e;
    		if(ev.keyCode==13) {
    			$('button').click();
    		}
    	}
    
    	function scrollBar(){
    		$(".chatContent").scrollTop($(".chatContent")[0].scrollHeight);
    	}
    });
    

    至此,我们的主要工作基本上完成了,其实也没有多少东西

    • 创建 socket 服务器,监听客户端连接与消息,发送消息、广播消息
    • socket客户端向服务器申请连接,发送与监听消息

    这次只是做了一个简易的聊天室功能,下次我们加入 redis 的 订阅/发布 模式,完成更复杂更灵活的聊天功能,敬请期待!

    项目结构:
    codelist

    控制台信息:
    consolelogExpress+Socket.IO 实现简易聊天室

    代码地址如下:
    http://www.demodashi.com/demo/12477.html

    注:本文著作权归作者,由demo大师代发,拒绝转载,转载需要作者授权

  • 相关阅读:
    hdu 2203
    hdu 3081
    hdu 4240 最大流量路径
    b_vj_Fiber Network(floyd思想+状态压缩)
    b_vj_Corn Fields(预处理行的状态、合法状态+枚举当前行与上一行的状态)
    b_vj_Hackers' Crackdown(预处理所有集合+检查合法集合后进行状态转移)
    b_vj_Count Color(线段树+二进制表示颜色)
    b_vj_K-th Number(二分+线段树)
    b_lg_火烧赤壁(讨论完全覆盖/部分覆盖)
    b_hdu_Ping pong(树状数组+乘法原理)
  • 原文地址:https://www.cnblogs.com/demodashi/p/8512788.html
Copyright © 2020-2023  润新知