socket.io mysql_mysql+socket.io

const http=require('http');

const mysql=require('mysql');

const fs=require('fs');

const url=require('url');

const zlib=require('zlib');

const crypto=require('crypto');

const _key='sadfslekrtuew5iutoselgdtjiypoydse4ufhs.edtyo;s8te4arfeliawkfhtsie5tlfia;sefdshroiupeoutwyeli5gurse;ihf';functionmd5(str){

let obj=crypto.createHash('md5');

obj.update(str);return obj.digest('hex');

}functionmd5_2(str){return md5(md5(str)+_key);

}

let db=mysql.createPool({host: 'localhost', port: 3309, user: 'root', password: '', database: '20180127'});

let server=http.createServer((req, res)=>{

let {pathname, query}=url.parse(req.url, true);

let {user, pass}=query;switch(pathname){//接口

case '/reg'://校验

if(!user){

res.write('{"err": 1, "msg": "username can\'t be null"}');

res.end();

}else if(!pass){

res.write('{"err": 1, "msg": "password can\'t be null"}');

res.end();

}else if(!/^\w{4,16}$/.test(user)){

res.write('{"err": 1, "msg": "username is invaild"}');

res.end();

}else if(/['|"]/.test(pass)){

res.write('{"err": 1, "msg": "password is invaild"}');

res.end();

}else{

db.query(`SELECT* FROM user_table WHERE username='${user}'`, (err, data)=>{if(err){

res.write('{"err": 1, "msg": "database error"}');

res.end();

}else if(data.length>0){

res.write('{"err": 1, "msg": "this username exsits"}');

res.end();

}else{

db.query(`INSERT INTO user_table (ID,username,password) VALUES(0,'${user}','${md5_2(pass)}')`, (err, data)=>{if(err){

res.write('{"err": 1, "msg": "database error"}');

res.end();

}else{

res.write('{"err": 0, "msg": "success"}');

res.end();

}

});

}

});

}break;case '/login'://校验

if(!user){

res.write('{"err": 1, "msg": "username can\'t be null"}');

res.end();

}else if(!pass){

res.write('{"err": 1, "msg": "password can\'t be null"}');

res.end();

}else if(!/^\w{4,16}$/.test(user)){

res.write('{"err": 1, "msg": "username is invaild"}');

res.end();

}else if(/['|"]/.test(pass)){

res.write('{"err": 1, "msg": "password is invaild"}');

res.end();

}else{

db.query(`SELECT* FROM user_table WHERE username='${user}'`, (err, data)=>{if(err){

res.write('{"err": 1, "msg": "database error"}');

res.end();

}else if(data.length==0){

res.write('{"err": 1, "msg": "no this user"}');

res.end();

}else if(data[0].password!=md5_2(pass)){

res.write('{"err": 1, "msg": "username or password is incorrect"}');

res.end();

}else{

res.write('{"err": 0, "msg": "success"}');

res.end();

}

});

}break;default://缓存 TODO

//静态文件

let rs=fs.createReadStream(`www${pathname}`);

let gz=zlib.createGzip();

res.setHeader('content-encoding', 'gzip');

rs.pipe(gz).pipe(res);

rs.on('error', err=>{

res.writeHeader(404);

res.write('Not Found');

res.end();

});

}

});

server.listen(8080);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值