node.js代码二
var express = require('express');
var app = express();
var server = require('http').Server(app);
var io = require('socket.io')(server);
var formidable = require('formidable');
var mysql = require('mysql');
var session = require('express-session');
var cookieParser = require('cookie-parser');
// 静态。
app.use(express.static('public'));
app.use(express.static('node_modules'));
app.use(cookieParser());
app.use(session({
secret:'randomstring',
resave: false,
saveUninitialized:true,
cookie:{
maxAge:600000,
hostOnly:true
}
}));
// 配置 模版引擎。
app.set('view engine', 'ejs');
app.set('views', './views');
// 路由设置。
// 引入登录。
app.post('/doLogin', function(req, res){
var form = new formidable.IncomingForm();
// 表单处理。
form.parse(req, function(error, fields, files){
// 获取用户名和密码。
var username = fields.username;
var password = fields.password;
var rememberme = fields.rememberme;
// 查询数据库。
var con = mysql.createConnection({
host:'localhost',
user:'root',
password:'',
database:'lamp183'
});
// 连接。
con.connect();
// 执行查询。
con.query("SELECT * FROM user WHERE username='"+ username +"'", function(err, results, fields){
// console.log(results[0].password);
// res.send('ok');
if(results.length <= 0)
{
res.json({'login': 0, 'data':'没有这个用户'});
return ;
}
// 判断密码。
if(results[0].password != password)
{
res.json({'login': 0, 'data':'密码错误'});
}
else
{
// 判断是否记住我。
if(rememberme == 1)
{
res.cookie('admin', results[0], {maxAge: 600000000, hostOnly:true});
}
// 将用户数据存入session
req.session.admin = results[0];
// 发送登录成功指令
res.json({'login': 1, 'data':results[0]});
}
});
con.end();
return ;
});
});
// 注册功能。
app.post('/doRegist', function(req, res){
var form = new formidable.IncomingForm();
// 表单处理。
form.parse(req, function(error, fields, files){
// console.log(fields);
var username = fields.username;
var password = fields.password;
var nickname = fields.nickname;
// 查询数据库。
var con = mysql.createConnection({
host:'localhost',
user:'root',
password:'',
database:'lamp183'
});
// 连接。
con.connect();
// 执行添加。
con.query("INSERT INTO user(username,password,nickname) VALUES('"+ username +"','"+ password +"','"+ nickname +"')", function(err, results, fields){
// console.log(results);
if(results.affectedRows > 0)
{
res.json({'regist':1, 'info':'注册成功,请登录'});
}
else
{
res.json({'regist':0, 'info':'注册失败'});
}
});
con.end();
return ;
});
});
// 监听。
server.listen(8080);
// 引入聊天室页面。
app.get('/', function(req, res){
// 判断用户是否已经登录。
if(req.session.admin || req.cookies.admin)
{
res.render('index2');
io.on('connection', function(socket){
if(req.session.admin)
{
socket.emit('nolog', req.session.admin);
}
else if(req.cookies.admin)
{
socket.emit('nolog', req.session.admin);
}
});
}
else{
res.render('index');
}
// res.render('index');
// console.log(req.session.admin);
});
var users = [];
// 建立连接
io.on('connection', function(socket) {
socket.on('login', function(data){
// console.log(data.data.nickname);
// 保存所有用户。
var u = {nickname:data.data.nickname};
users.push(u);
});
socket.on('users', function(){
// 发送给所有客户端。
socket.emit('users', users);
});
// 监听消息
socket.on('send', function(data){
// console.log(data);
// 发送给所有用户。
socket.broadcast.emit('receiver', data);
});
});
// 退出登录功能。
app.get('/logout', function(req, res){
// 清空session和cookie
if(req.session.admin)
{
var name = req.session.admin.nickname
delete(req.session.admin);
}
else
{
var name = req.session.admin.nickname
res.cookie('admin', 1, {maxAge: -1, hostOnly:true});
}
// 跳转登录页面。
res.redirect('/');
return ;
});
node.js代码二的更多相关文章
- 玩转Node.js(二)
玩转Node.js(二) 先来回顾上次的内容,上一次我们使用介绍了Node.js并写了第一个服务器端的Hello World程序,在这个Hello World程序中,请求自带的http模块并将其赋给h ...
- 《超实用的Node.js代码段》连载三:Node.js深受欢迎的六大原因
<超实用的Node.js代码段>连载一:获取Buffer对象字节长度 <超实用的Node.js代码段>连载二:正确拼接Buffer Node.js是一种后起的优秀服务器编程语言 ...
- 我们为什么要看《超实用的Node.JS代码段》
不知道自己Node.JS水平如何?看这张图 如果一半以上的你都不会,必须看这本书,一线工程师用代码和功能页面来告诉你每一个技巧点. 都会一点,但不知道如何检验自己,看看本书提供的面试题: 1. ...
- Edge.js:让.NET和Node.js代码比翼齐飞
通过Edge.js项目,你可以在一个进程中同时运行Node.js和.NET代码.在本文中,我将会论述这个项目背后的动机,并描述Edge.js提供的基本机制.随后将探讨一些Edge.js应用场景,它在这 ...
- 《超实用的Node.js代码段》连载二:正确拼接Buffer
对于初学Node.js框架的开发人员来说,可能认为Buffer模块比较易学.重要性也不是那么突出.其实,Buffer模块在文件I/O和网络I/O中应用非常广泛,其处理二进制的性能比普通字符串性能要高出 ...
- 初学node.js有感二
node.js进阶 一.回顾与继续 对于一种语言的认识都是经历这样的一个过程的,首先从原生的环境(CMD)中开始学习,找到一门语言之间各种引用的本质和相互之间的调用方式,明澈各种依赖关系,在这个基 ...
- node.js 生成二维码
因为自己的项目中,想在商品详情页上 显示一个 商品优惠券的二维码. 以此为需求. node.js 后台代码 const qr_image = require("qr-image") ...
- node.js问题二
看了Node.js开发指南发现routes和app.js分开的话要使用下面代码 app.use(express.router(routes)) 但是真正是使用上面代码会遇到无数的问题报错 找了资料才发 ...
- 8 行 Node.js 代码实现代理服务器
接触 Node.js 已有多年,一直喜欢它的单线程模型和异步IO特性,以及 JavaScript 语言本身的灵活性.同时,JavaScript 前后端通吃,在全栈开发领域具有独特的优势.今天就来看看作 ...
随机推荐
- 安装部署hyperledger fabric1.0
安装环境 CentOS7 1.安装Docker Docker Hub在国外,安装会较慢,可用国内镜像DaoCloud.可执行以下命令安装Docker. sudo yum install -y yum- ...
- 网络编程---socket模块
内容中代码都是先写 server端, 再写 client端 1 TCP和UDP对比 TCP(Transmission Control Protocol)可靠的.面向连接的协议(eg:打电话).传输效 ...
- 动态表单数据验证 vue
idCard: [{ validator: (rule, value, callback) => { if (this.idCardVif === 'idCard') { this.valida ...
- Natas10 Writeup(正则表达式、grep命令)
Natas10: 页面与上一关类似,只是增加了提示“出于安全原因,我们现在过滤某些字符”. 查看源码,发现关键代码如下: $key = ""; if(array_key_exist ...
- 欲善事先利器-IEAD插件篇
工欲善其事,必先利其器,好鞋踢好球是非常合乎逻辑的事情. --<长江七号> 同样的开场白,不一样的酒,不一样的故事. 上篇<欲善事先利器--系统篇>已经推荐了一些个人常用的效率 ...
- tomcat启动时间5分钟左右org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [342,445] milliseconds.
org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom Creation of SecureRandom instance ...
- Dubbo 扩展点加载机制:从 Java SPI 到 Dubbo SPI
SPI 全称为 Service Provider Interface,是一种服务发现机制.当程序运行调用接口时,会根据配置文件或默认规则信息加载对应的实现类.所以在程序中并没有直接指定使用接口的哪个实 ...
- beautifulsoup实现文章截取和脚本攻击
引子:现在我们所写的所有高大上,炫酷的网页,在数据库中是如何存储的呢?其实数据库中存储的所有高大上的文章都是存的html,然后我们平时看的写的都是由于编辑器的原因,在编辑器内部做了转换,所以我们可以直 ...
- MySQL----DML(增删改表中数据)
##DML:增删改表中的数据 1.添加数据 *语法: * insert into 表名(列名1,列名2,...列名n) values (值1,值2,...值n); *注意: 1.列名和值要一一对应. ...
- 搭建Hadoop集群需要注意的问题:
搭建Hadoop集群需要注意的问题: 1.检查三台主机名是否正确 2.检查三台IP是否正确 3.检查 /etc/hosts 映射是否正确 4.检查 JDK和Hadoop 是否安装成功(看环境变量配置) ...