Express+Socket.IO 实现简易聊天室
闲暇之余研究了一下 Socket.io,搭建了一个简易版的聊天室,如有不对之处还望指正,先上效果图:
首先是登录页面:
接下来就是聊天页面:
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{
width: 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="width: 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{
width: 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;
width: 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="width: 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 的 订阅/发布 模式,完成更复杂更灵活的聊天功能,敬请期待!
项目结构:
控制台信息:
Express+Socket.IO 实现简易聊天室
注:本文著作权归作者,由demo大师代发,拒绝转载,转载需要作者授权
Express+Socket.IO 实现简易聊天室的更多相关文章
- node+express+socket.io制作一个聊天室功能
首先是下载包: npm install express npm install socket.io 建立文件: 服务器端代码:server.js var http=require("http ...
- 示例:Socket应用之简易聊天室
在实际应用中,Server总是在指定的端口上监听是否有Client请求,一旦监听到Client请求,Server就会启动一个线程来响应该请求,而Server本身在启动完线程之后马上又进入监听状态. 示 ...
- 使用socket.io打造公共聊天室
最近的计算机网络课上老师开始讲socket,tcp相关的知识,当时脑袋里就蹦出一个想法,那就是打造一个聊天室.实现方式也挺多的,常见的可以用C++或者Java进行socket编程来构建这么一个聊天室. ...
- AngularJS+Node.js+socket.io 开发在线聊天室
所有文章搬运自我的个人主页:sheilasun.me 不得不说,上手AngularJS比我想象得难多了,把官网提供的PhoneCat例子看完,又跑到慕课网把大漠穷秋的AngularJS实战系列看了一遍 ...
- 利用socket.io构建一个聊天室
利用socket.io来构建一个聊天室,输入自己的id和消息,所有的访问用户都可以看到,类似于群聊. socket.io 这里只用来做一个简单的聊天室,官网也有例子,很容易就做出来了.其实主要用的东西 ...
- Socket.io文字直播聊天室的简单代码
直接上代码吧,被注释掉的主要是调试代码,和技术选型的测试代码 var app = require('express')(); var server = require('http').Server(a ...
- socket.io 实现简易聊天
客户端: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF- ...
- Node.js下基于Express + Socket.io 搭建一个基本的在线聊天室
一.聊天室简单介绍 采用nodeJS设计,基于express框架,使用WebSocket编程之 socket.io机制.聊天室增加了 注册登录模块 ,并将用户个人信息和聊天记录存入数据库. 数据库采用 ...
- Socket实现简易聊天室,Client,Server
package seday08; import java.io.BufferedWriter;import java.io.OutputStream;import java.io.OutputStre ...
随机推荐
- 【bzoj4439】[Swerc2015]Landscaping 网络流最小割
题目描述 FJ有一块N*M的矩形田地,有两种地形高地(用‘#’表示)和低地(用‘.’表示) FJ需要对每一行田地从左到右完整开收割机走到头,再对每一列从上到下完整走到头,如下图所示 对于一个4*4的田 ...
- CentOS7.3系统启动故障修复
CentOS7.3系统启动故障修复 破解CentOS7的root口令方法一 启动时任意键暂停启动菜单,选择启动内核菜单项 按 e 键进入编辑模式 将光标移动 linux16 开始的行,添加内核参数rd ...
- CF 964C Alternating Sum
给定两正整数 $a, b$ .给定序列 $s_0, s_1, \dots, s_n,s_i$ 等于 $1$ 或 $-1$,并且已知 $s$ 是周期为 $k$ 的序列并且 $k\mid (n+1)$,输 ...
- Google Code Jam 2008 Round 1A C Numbers(矩阵快速幂+化简方程,好题)
Problem C. Numbers This contest is open for practice. You can try every problem as many times as you ...
- topK问题解法
topK问题的最佳解法是堆排,下面介绍用堆排来解决该问题. 堆排解决topK问题的思路,取出前K个数,最重要的就是要减少比较的次数,用堆排维护一个K大小的堆,比如一个小顶堆,则堆顶为堆中最小的值,将堆 ...
- pat 团体天梯赛 L3-009. 长城
L3-009. 长城 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 邓俊辉(清华大学) 正如我们所知,中国古代长城的建造是为了抵御外 ...
- 【HDOJ5536】Chip Factory(Trie树)
题意:给定n个数字,第i个数字为a[i],求max((a[i]+a[j])^a[k]),其中i,j,k互不相同 n<=1000,0<=a[i]<=1e9 思路:队友写的,抱大腿 先对 ...
- IIC知识
任何一个微处理器都要与一定数量的部件和外围设备连接,但如果将各部件和每一种外围设备都分别用一组线路与CPU直接连接,那么连线将会错综复杂,甚至难以实现.为了简化硬件电路设计.简化系统结构,常用一组线路 ...
- linux下编译安装gcc5.1
一.下载源代码:ftp://ftp.mirrorservice.org/sites/sourceware.org/pub/gcc/releases/gcc-5.1.0/gcc-5.1.0.tar.bz ...
- linux内核情景分析之强制性调度
从系统调用返回到用户空间是否调度,从ret_with_reschedule可看出,是否真正调度,取决于当前进程的pcb中的need_resched是否设置为1,那如何设置为1取决于以下几种情况: 时间 ...