NodeJs+MySQL實現(xiàn)注冊登錄功能
本文實例為大家分享了NodeJs+MySQL實現(xiàn)注冊登錄功能的具體代碼,供大家參考,具體內(nèi)容如下
之前寫過一個沒有連接數(shù)據(jù)庫的注冊與登陸的實現(xiàn),這次加上了數(shù)據(jù)庫
剛剛接觸后端,很多不完善的地方,有錯誤請指正
nodejs中mysql的寫法:
//連接池
let db=mysql.createPool({'配置'}) ??
db.query(`sql語句`,(err,data)=>{})并且在數(shù)據(jù)庫中存儲的密碼應該是密文
function md5(str){
? let obj=crypto.createHash('md5');
? obj.update(str);
? return obj.digest('hex')
}
function md5_2(str){
? return md5(md5(str))
}服務端操作,在用戶名與密碼上添加了簡單的校驗,不完善,還需要改進
const http=require('http');
const fs=require('fs');
const mysql=require('mysql');
const url=require('url');
const zlib=require('zlib');
const crypto=require('crypto');
?
const _key='bsjhjqbj1;dqwxsxx+';
?
let server=http.createServer((req,res)=>{
? let {pathname,query}=url.parse(req.url,true);
? let {user,password}=query;
?
? switch(pathname){
? ? case '/reg':
? ? ? if(!user){
? ? ? ? res.write('{"err":1,"msg":"用戶名不能為空"}');
? ? ? ? res.end();
? ? ? }else if(!password){
? ? ? ? res.write('{"err":1,"msg":"密碼不能為空"}');
? ? ? ? res.end();
? ? ? }else if(!/\w{4,16}$/.test(user)){
? ? ? ? res.write('{"err":1,"msg":"用戶名應為大小寫字母數(shù)字或下劃線"}');
? ? ? ? res.end();
? ? ? }else if(/['|"]/.test(password)){
? ? ? ? res.write('{"err":1,"msg":"密碼非法"}');
? ? ? ? res.end();
? ? ? }else{
? ? ? ? db.query(`SELECT username FROM users_table WHERE username='${user}'`,(err,data)=>{
? ? ? ? ? if(err){
? ? ? ? ? ? res.write('{"err":1,"msg":"數(shù)據(jù)庫錯誤"}');
? ? ? ? ? ? console.log(err)
? ? ? ? ? ? res.end()
? ? ? ? ? }else{
? ? ? ? ? ? if(data.length>0){
? ? ? ? ? ? ? res.write('{"err":1,"msg":"用戶名已存在"}');
? ? ? ? ? ? ? res.end();
? ? ? ? ? ? }else{
? ? ? ? ? ? ? res.write('{"err":0,"msg":"注冊成功"}');
? ? ? ? ? ? ? db.query(`INSERT INTO users_table (ID,username,password) VALUES (0,'${user}','${md5_2(password)}')`);
? ? ? ? ? ? ? res.end();
? ? ? ? ? ? }
? ? ? ? ? }
? ? ? ? })
? ? ? }
? ? ? break;
?
? ? case '/login':
? ? ? if(!user){
? ? ? ? res.write('{"err":1,"msg":"用戶名不能為空"}');
? ? ? ? res.end();
? ? ? }else if(!password){
? ? ? ? res.write('{"err":1,"msg":"密碼不能為空"}');
? ? ? ? res.end();
? ? ? }else if(!/\w{4,16}$/.test(user)){
? ? ? ? res.write('{"err":1,"msg":"用戶名應為大小寫字母數(shù)字或下劃線"}');
? ? ? ? res.end()
? ? ? }else if(/["|']/.test(password)){
? ? ? ? res.write('{"err":1,"msg":"密碼非法"}');
? ? ? ? res.end();
? ? ? }else{
? ? ? ? db.query(`SELECT username,password FROM users_table WHERE username='${user}'`,(err,data)=>{
? ? ? ? ? if(err){
? ? ? ? ? ? res.write('{"err":1,"msg":"數(shù)據(jù)庫錯誤"}');
? ? ? ? ? ? res.end()
? ? ? ? ? }else if(data.length>0){
? ? ? ? ? ? if(md5_2(password)!=data[0].password){
? ? ? ? ? ? ? res.write('{"err":1,"msg":"用戶名或密碼不正確"}');
? ? ? ? ? ? ? res.end();
? ? ? ? ? ? }else{
? ? ? ? ? ? ? res.write('{"err":0,"msg":"登陸成功"}');
? ? ? ? ? ? ? res.end();
? ? ? ? ? ? }
? ? ? ? ? }else{
? ? ? ? ? ? res.write('{"err":1,"msg":"用戶不存在"}')
? ? ? ? ? }
? ? ? ? })
? ? ? }
? ? break;
?
? ? default:
? ? ? 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(8888);以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- 使用nodejs連接mySQL寫接口全過程(增刪改查)
- nodejs+mysql實現(xiàn)用戶相關的增刪改查的詳細操作
- 三分鐘教會你用nodejs操作mysql數(shù)據(jù)庫
- Nodejs?連接?mysql時報Error:?Cannot?enqueue?Query?after?fatal?error錯誤的處理辦法
- NodeJs操作MYSQL方法詳細介紹
- nodejs中關于mysql數(shù)據(jù)庫的操作
- Nodejs中koa2連接mysql的實現(xiàn)示例
- nodejs連接mysql數(shù)據(jù)庫及基本知識點詳解
- nodejs實現(xiàn)的連接MySQL數(shù)據(jù)庫功能示例
- Nodejs連接mysql并實現(xiàn)增、刪、改、查操作的方法詳解
- NodeJS連接MySQL數(shù)據(jù)庫并進行增刪改查操作詳解
相關文章
npm報錯:npm?WARN?config?global?'--global',?&apo
這篇文章主要給大家介紹了關于npm報錯:npm?WARN?config?global?'--global',?'--local'?are?deprecated.?Use?`--location=global`?instead.的解決方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-08-08
Node.js項目中調(diào)用JavaScript的EJS模板庫的方法
這篇文章主要介紹了Node.js項目中調(diào)用JavaScript的EJS模板庫的方法,通過EJS模板引擎可以制作出維護性良好的HTML代碼結構,需要的朋友可以參考下2016-03-03
package-lock.json解決依賴的版本管理使用詳解
這篇文章主要為大家介紹了package-lock.json解決依賴的版本管理使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08

