node mysql登录注册_Node数据库入门(登录注册功能)

这篇博客介绍了如何使用Node.js和MySQL实现登录注册功能。通过创建HTTP服务器,解析URL,连接数据库并执行SQL查询来检查用户名是否存在,插入新用户,以及验证登录时的用户名和密码。
摘要由CSDN通过智能技术生成

const http=require('http');const mysql=require('mysql');const url=require('url');const fs=require('fs');//1.连接到服务器

let db=mysql.createConnection({

host:'localhost',

port:3306,

user:'root',

password:'',

database:'node_sql'})if(db){console.log('sql success');}//2.配合http

http.createServer( (req,res)=>{const {pathname,query}=url.parse(req.url,true);

let{username,password}=query;if(pathname=='/reg'){ //用户想注册

if(!username || !password){

res.write('用户名和密码不能为空');

res.end();

}else if(username.length>32){

res.write('用户名最大32个字');

res.end();

}else{

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

res.write('数据库有错');

res.end();

}else if(data.length>0){

res.write('用户名已被注册');

res.end();

}else{

db.query(`INSERT INTO user (username,password,nickname) VALUES ('${username}','${password}','placeholder')`,(err,data)=>{if(err){

res.write('数据库有错');

res.end();

}else{

res.write('注册成功');

res.end();

}

})

}

})

}

}else if(pathname=='/login'){ //用户登录

if(!username || !password){

res.write('用户名和密码不能为空');

res.end();

}else{

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

res.write('数据库有错');

res.end();

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

res.write('用户名不存在');

res.end();

}else{

db.query(`SELECT password FROM userwhere username='${username}'`,(err,data)=>{if(err){

res.write('数据库有错');

res.end();

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

res.write('密码错误');

res.end();

}else{

res.write('登录成功');

res.end();

}

}

})

}

})

}

}else{

fs.readFile(`www${pathname}`,(err,buffer)=>{

console.log(err,buffer);if(err){

res.writeHeader(404);

res.write('NOT FOUND');

}else{

res.write(buffer);

}

res.end();

})

}

}).listen(8520,()=>{

console.log("node_sql action");

});

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值