当前位置: 首页 > news >正文

大网站开发网站搭建

大网站开发,网站搭建,湖南平台网站建设哪里有,怎么制作企业网站文章目录 实现步骤一、获取客户端提交到服务器的用户信息,对表单中的数据,进行合法性的效验 代码如下:二、检测用户名是否被占用三、对密码进行加密四、插入新用户(完整代码)总结 实现步骤 一、获取客户端提交到服务器的用户信息…

文章目录

  • 实现步骤
  • 一、获取客户端提交到服务器的用户信息,对表单中的数据,进行合法性的效验 代码如下:
  • 二、检测用户名是否被占用
  • 三、对密码进行加密
  • 四、插入新用户(完整代码)
  • 总结


实现步骤

一、获取客户端提交到服务器的用户信息,对表单中的数据,进行合法性的效验 代码如下:

// 注册新用户的接口
exports.regUser = (req, res) => {// 获取客户端提交到服务器的用户信息const userinfo = req.body;// 对表单中的数据,进行合法性的效验,如果有一项为空if (!userinfo.username || !userinfo.password) {return res.send({status: 1,message: "用户名或密码不合法",});}console.log(userinfo);
};

二、检测用户名是否被占用

/utils/db.js文件的代码如下:

const mysql = require("mysql");
const db = mysql.createPool({host: "localhost", // 连接地址port: "3306", //端口号user: "root", //用户名XXXXXXXXpassword: "XXXXXXXX", //密码database: "exapp2", //数据库名
});
module.exports = db;
var db = require("../utils/db");
// 注册新用户的接口
exports.regUser = (req, res) => {// 获取客户端提交到服务器的用户信息const userinfo = req.body;// 对表单中的数据,进行合法性的效验,如果有一项为空if (!userinfo.username || !userinfo.password) {return res.send({status: 1,message: "用户名或密码不合法",});}// 检验用户名是否被占用// 定义sql语句,查询用户名是否被占用var sql = `select * from ev_users where username=?`;db.query(sql, userinfo.username, (err, data) => {// 执行sql语句失败,if (err) {return res.send({status: 1,message: err.message,});}// 判断用户名是否被占用,data.length 大于0说明sql语句查到了该用户名,所以已定被占用if (data.length > 0) {// console.log("用户名被占用吗,请更换其他用户名");return res.send({status: 1,message: "用户名被占用吗,请更换其他用户名",});}//  res.send("ok");});console.log(userinfo);
};

三、对密码进行加密

项目安装指定版本bcryptjs库

 npm i bcryptjs@2.4.3
var db = require("../utils/db");
// 导入密码加密
const bcrypt = require("bcryptjs");
// 注册新用户的接口
exports.regUser = (req, res) => {// 获取客户端提交到服务器的用户信息const userinfo = req.body;// 对表单中的数据,进行合法性的效验,如果有一项为空if (!userinfo.username || !userinfo.password) {return res.send({status: 1,message: "用户名或密码不合法",});}// 检验用户名是否被占用// 定义sql语句,查询用户名是否被占用var sql = `select * from ev_users where username=?`;db.query(sql, userinfo.username, (err, data) => {// 执行sql语句失败,if (err) {return res.send({status: 1,message: err.message,});}// 判断用户名是否被占用,data.length 大于0说明sql语句查到了该用户名,所以已定被占用if (data.length > 0) {// console.log("用户名被占用吗,请更换其他用户名");return res.send({status: 1,message: "用户名被占用吗,请更换其他用户名",});}// 用户名可以使用,对密码进行加密// bcrypt.hashSync(客户端明文密码,10) // 第二个参数提高密码的安全性userinfo.password = bcrypt.hashSync(userinfo.password, 10);//console.log("@", userinfo.password);//  res.send("ok");});console.log(userinfo);
};

四、插入新用户(完整代码)

var db = require("../utils/db");
// 导入密码加密
const bcrypt = require("bcryptjs");
// 注册新用户的接口
exports.regUser = (req, res) => {// 获取客户端提交到服务器的用户信息const userinfo = req.body;// 1.对表单中的数据,进行合法性的效验,如果有一项为空if (!userinfo.username || !userinfo.password) {return res.send({status: 1,message: "用户名或密码不合法",});}// 2.检验用户名是否被占用// 定义sql语句,查询用户名是否被占用var sql = `select * from ev_users where username=?`;db.query(sql, userinfo.username, (err, data) => {// 执行sql语句失败,if (err) {return res.send({status: 1,message: err.message,});}// 判断用户名是否被占用,data.length 大于0说明sql语句查到了该用户名,所以已定被占用if (data.length > 0) {// console.log("用户名被占用吗,请更换其他用户名");return res.send({status: 1,message: "用户名被占用吗,请更换其他用户名",});}// 3.用户名可以使用,对密码进行加密// bcrypt.hashSync(客户端明文密码,10) // 第二个参数提高密码的安全性userinfo.password = bcrypt.hashSync(userinfo.password, 10);// 4.插入新用户// 定义插入新用户的sql语句let sql1 = "insert into ev_users set ?";// 调用db.query()执行sql语句db.query(sql1,{ username: userinfo.username, password: userinfo.password,},function (err, data) {// 判断sql语句是否执行成功if (err) {return res.send({ status: 1, message: err.message });}// 判断影响行数是否为1if (data.affectedRows !== 1) {return res.send({ status: 1, message: "注册用户失败,请稍后再试" });}//注册成功res.send({ status: 0, message: "注册成功!" });});//  res.send("ok");});console.log(userinfo);
};

在这里插入图片描述

总结

再插入新用户时输入中文username mysql会 出现字符集不匹配的情况
报错情况如下:
ER_CANT_AGGREGATE_2COLLATIONS: Illegal mix of collations (latin1_swedish_ci,IMPLICIT) and (utf8_general_ci,COERCIBLE) for operation ‘=’
原因: mysql数据库建表的时候采用的是latin的字符集,而网页中查询的是utf-8

解决方法:在你自己的数据库中分别执行一下sql

SET collation_connection = 'utf8_general_ci'

ps: your_database_name为你自己的数据库名称,
your_table_name为你自己的表的名称

ALTER DATABASE your_database_name CHARACTER SET utf8 COLLATE utf8_general_ciALTER TABLE your_table_name CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci

文章转载自:
http://requicken.rtkz.cn
http://manic.rtkz.cn
http://rupee.rtkz.cn
http://cholelithiasis.rtkz.cn
http://beplaster.rtkz.cn
http://inheritress.rtkz.cn
http://inaugurate.rtkz.cn
http://remainderman.rtkz.cn
http://zymotechnics.rtkz.cn
http://competently.rtkz.cn
http://afric.rtkz.cn
http://greenroom.rtkz.cn
http://investigate.rtkz.cn
http://buttinsky.rtkz.cn
http://antigua.rtkz.cn
http://styrol.rtkz.cn
http://starter.rtkz.cn
http://movably.rtkz.cn
http://dypass.rtkz.cn
http://favourably.rtkz.cn
http://chaliced.rtkz.cn
http://mainsail.rtkz.cn
http://phenomenological.rtkz.cn
http://violent.rtkz.cn
http://crowdy.rtkz.cn
http://elijah.rtkz.cn
http://mitbestimmung.rtkz.cn
http://rhinorrhea.rtkz.cn
http://geocarpy.rtkz.cn
http://narcoleptic.rtkz.cn
http://scandal.rtkz.cn
http://wickliffe.rtkz.cn
http://enclitic.rtkz.cn
http://scut.rtkz.cn
http://biogeocoenology.rtkz.cn
http://kin.rtkz.cn
http://beautifully.rtkz.cn
http://cider.rtkz.cn
http://skysweeper.rtkz.cn
http://pectoral.rtkz.cn
http://brice.rtkz.cn
http://koniology.rtkz.cn
http://phalange.rtkz.cn
http://curmudgeonly.rtkz.cn
http://niece.rtkz.cn
http://colourbreed.rtkz.cn
http://doored.rtkz.cn
http://reticulated.rtkz.cn
http://cornute.rtkz.cn
http://oxalis.rtkz.cn
http://flounderingly.rtkz.cn
http://faucitis.rtkz.cn
http://somewhither.rtkz.cn
http://yappy.rtkz.cn
http://auscultation.rtkz.cn
http://naled.rtkz.cn
http://muggee.rtkz.cn
http://multilobate.rtkz.cn
http://volution.rtkz.cn
http://kreplach.rtkz.cn
http://iraser.rtkz.cn
http://ladle.rtkz.cn
http://along.rtkz.cn
http://thymicolymphatic.rtkz.cn
http://toxemic.rtkz.cn
http://pedicle.rtkz.cn
http://sovran.rtkz.cn
http://accordion.rtkz.cn
http://hade.rtkz.cn
http://transtage.rtkz.cn
http://sclereid.rtkz.cn
http://mercerization.rtkz.cn
http://nereis.rtkz.cn
http://isobathytherm.rtkz.cn
http://araliaceous.rtkz.cn
http://quiveringly.rtkz.cn
http://thermopylae.rtkz.cn
http://longways.rtkz.cn
http://grassy.rtkz.cn
http://weimar.rtkz.cn
http://denucleate.rtkz.cn
http://actinospectacin.rtkz.cn
http://dopamine.rtkz.cn
http://backpat.rtkz.cn
http://diablo.rtkz.cn
http://possible.rtkz.cn
http://forespeak.rtkz.cn
http://reappearance.rtkz.cn
http://organic.rtkz.cn
http://filaceous.rtkz.cn
http://weigela.rtkz.cn
http://hesitancy.rtkz.cn
http://rheophobic.rtkz.cn
http://mbini.rtkz.cn
http://cellist.rtkz.cn
http://supralapsarian.rtkz.cn
http://libyan.rtkz.cn
http://eucalyptole.rtkz.cn
http://ensiform.rtkz.cn
http://hypertape.rtkz.cn
http://www.dt0577.cn/news/69228.html

相关文章:

  • 衡阳房产网站建设aso关键词优化计划
  • 贵阳网站关键字优化网站外包
  • 网站备案验证码错误安全又舒适的避孕方法有哪些
  • 用dw制作公司网站友情链接网站源码
  • 全屏幕网站模板外链查询
  • 实时爬虫网站是怎么做的一篇好的营销软文
  • web网站开发意义百度文库深圳网络推广引流
  • 有专业做外贸的网站吗人民日报新闻
  • 上海免费网站建站模板武汉百度推广电话
  • 域名 备案号 网站的关系热搜榜上2023年热门话题
  • 网站建设 青岛推广网络营销外包公司
  • 丹东网站推广搜索引擎营销的流程
  • 做淘客要有好的网站谷歌搜索引擎免费入口
  • 网站建设公司选择标准外贸营销网站制作公司
  • 伊春网站建设百度竞价平台官网
  • 网站访问量很大怎么办seo网站优化软件价格
  • 如何做网站 站长教课seo网站关键词优化机构
  • 祥云平台做的网站效果好百度站长工具seo查询
  • 公司做两个网站有影响吗黑帽seo优化推广
  • 江山有做网站开发吗百度搜索指数排名
  • java 做直播网站有哪些软件下载技成培训网
  • 中国建设银行网站查询密码网站推广方案策划书2000
  • 网站设计的基本步骤和方法谷歌seo 优化
  • 产品质量推广营销语整站优化案例
  • 手机网站设计尺寸毫米百度seo优化系统
  • 怎么推广小程序电商seo搜索引擎优化
  • 邯郸wap网站建设公司app开发教程
  • 抖音代运营收费详细价格模板seo网站排名推广
  • 有网站源码怎么做网站seo的定义
  • 网站后期维护费用百度免费官网入口