Node.js后端+MySQL数据库+jQuery前端实现

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: Node.js后端+MySQL数据库+jQuery前端实现

Node.js后端+MySQL数据库+jQuery前端实现


✨博主介绍

通用组件部分

数据定义

数据库

验证码

跨域问题

前端部分

概述

登录部分

数据校验

登陆成功

登陆失败

密码安全性

注册部分

数据校验

密码强度把关

确认密码框和密码框内容保持一致

注册成功

注册失败

密码安全性

后端部分

概述

数据库连接部分

💫点击直接资料领取💫


✨博主介绍

🌊 作者主页:苏州程序大白


🌊 作者简介:🏆CSDN人工智能域优质创作者🥇,苏州市凯捷智能科技有限公司创始之一,目前合作公司富士康、歌尔等几家新能源公司


💬如果文章对你有帮助,欢迎关注、点赞、收藏


💅 有任何问题欢迎私信,看到会及时回复

💅关注苏州程序大白,分享粉丝福利


通用组件部分

数据定义


63cccedd97284784b0c546ff330cab53.png


username:用户名。


email:邮件。


hash:密码加盐的盐值。


passwd:加密后的密码。


uid:数据表主键,用于唯一标识一个用户。


我们约定,用户名是不可以重复的,但是邮箱是可以重复的。约束放在后端来做。除了邮箱以外,其他的字符串类型的数据都是严格区分大小写的。


在我提供的导出的数据库文件中,已经包含了三个账户,用户名分别是 ss1,ss2,ss3,密码都是 ssss1111。数据库转移文件是 base_info.sql。


155f7157e2684508b65149acef8489a5.png


数据库


为了便于开发和调试,我选择了在 docker 中启动 MySQL(数据库)和 phpMyAdmin(面板)服务。启动过程如下所示,十分简洁明了。提交文件中附有转移数据表使用的 SQL 脚本文件,可轻松迁移到其他平台。


docker pull mysql:8.0.1
docker run --name YDJSIR-mysql -p 3307:3306 -e MYSQL_ROOT_PASSWORD=<数据库密码> -d mysql:8.0.1
docker pull phpmyadmin/phpmyadmin:latest
docker run --name YDSJIR-phpmyadmin -d --link YDJSIR-mysql:db -p 5601:80 phpmyadmin/phpmyadmin


验证码


验证码图片由后端生成,然后发送给前端。前端在每一次提交登录 / 注册请求时会把绑定到当前会话的验证码带上,由后端进行校验,以确保安全性。


前端部分对应代码如下。


function getCaptcha() {
  $.ajax({
    method: "GET",
    xhrFields: { withCredentials: true },
    url: "http://localhost:3001/getcaptcha",
    data: {},
  }).done(function (data, status) {
    console.log(status);
    if (status == "success") {
      const captcha = document.getElementById("captchaPic");
      captcha.innerHTML = data;
      console.log(captcha);
    }
  });
}


补充说明一下,这个 captcha 元素在初始状态长这样。实际上整个

标签在点击时都会触发验证码刷新。


<div id="captchaPic" class="input-addon" style="float: left">
    <button
            class="button-link"
            style="margin: auto; color: aliceblue"
            id="getcaptchapic"
            >
        点击获取
    </button>
</div>


后端部分对应如下:


// 验证码请求接口,在前端加载页面或手动触发时会请求
app.get("/getcaptcha", (req, res) => {
  const captcha = svgCaptcha.create({
    noise: 3, // 干扰线条的数量
    background: "#50ff33", // 背景颜色
    width: "100",
    height: "40",
  });
  // 将图片的验证码存入到 session 中
  req.session.img_code = captcha.text.toLocaleUpperCase(); // 验证码不区分大小写,存储统一大写
  res.type("html"); // 注意这里的类型设置为HTML,与前端直接把返回体作为HTML代码嵌入网页中相对应
  res.send(String(captcha.data));
  res.status(200);
});
// 下面是在处理登录注册请求时的校验过程,以登录过程为例
const { username, password, captcha } = req.body;
console.log(req.session.img_code);
console.log("Client Captcha: " + captcha);
if (captcha.toLocaleUpperCase() != req.session.img_code) {
    console.log("ERROR: captcha wrong!");
    res.send({ RESULT: invalid_captcha }); // 向客户端报告这个错误,并不做进一步的处理
    return;
}


跨域问题


为了解决所有的跨域问题,特别是带上了 express-session 后的跨域问题,如下设置。


前端的每次请求都会带上如下内容,以保证能在 cookie 中保存会话相关信息并在请求时能带上会话信息。


xhrFields: { withCredentials: true }


后端明确指出了前端的来源 refer,因此启动前端时请注意默认情况是让前端跑在 80 端口,且跑在同一台机器上(两边都是 localhost)。如果修改了这样的设置,会因为跨域引起失败。


// 所有请求开始之前
app.use(
  session({
    secret: SECRET,
    resave: false,
    cookie: {
      domain: "localhost:" + PORT,
      maxAge: 600000,
    },
    saveUninitialized: true,
    cookie: { secure: false }, // 为了兼容性设置
  })
);
// 解决跨域问题
app.all("*", function (req, res, next) {
  res.header("Access-Control-Allow-Origin", "http://localhost"); // 明确指出了前端的地址
  res.header("Access-Control-Allow-Headers", "X-Requested-With");
  res.header("Access-Control-Allow-Credentials", "true"); // 否则请求时候带不上会话相关信息
  res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS");
  res.header("X-Powered-By", " 3.2.1");
  res.header("Content-Type", "application/json;charset=utf-8");
  next();
});


前端部分


概述


前端部分沿用了第一次作业的大体设计,但是增加了新的重复密码框,并使用 CDN 引入 jQuery 与后端进行通信。除此以外显然引入了大量 JavaScript 以实现功能。前端界面具有适配多种平台的能力,在 Chrome 91 开发者工具所提供的所有类型的设备的模拟屏幕种均能完整显示正常操作。


运行前端时应尽量保证它在一个服务器环境中运行。本人采用的是 nginx-1.16.1。监听的端口应设为 80,正如前文提及的跨域设置中那样。


登录部分


数据校验


用户名和密码都不能为空,否则拒绝提交并提示用户输入。


登陆成功

如果登陆成功,会弹窗提示,点击确认后跳转到首页。


139b2a18b164444092b2c9f94376c2b7.png


登陆成功时后端会向前端发送 Token。这是用户登陆状态的证明,


登陆失败


登陆失败有两种情况。


用户名和密码不匹配时,会做如下提示,并允许用户在点击确认后重新输入。


e29bd3cc7fec48969f32c9f7e6dda1d6.png


验证码错误时,无论账号密码是否正确,会做如下提示,并允许用户重新输入。


cd8c6c9f8cb54606adab4b0598893b9a.png


密码安全性


前端向后端发送请求的时候即已经密码加盐(用户名)并用 SHA-256 散列,服务端不接触明文密码。SHA-256 的实现使用如下:


var oripwd = password.value;
var encryptedpassword = forge_sha256(username.value + oripwd);


注册部分


数据校验


所有的项目均为必填项目,包括必须勾选已经阅读隐私协议(不勾选提交会弹窗警告)。


255619c40dfb4ef8843dc7ab25b7c2ab.png


如有缺漏,前端会从上到下检测,并给出对应的提示。邮件一栏使用了 HTML5 自带的 email 类型。


本项目通过监听密码框和确认密码框的输入事件实现以下功能:


密码强度把关。


确认密码框和密码框内容保持一致。


密码强度把关


本项目基本密码强度要求是密码长度应在 8 到 30 之间,且有大小写字母、数字和英文特殊符号中的至少两种。


如不符合任意一项,密码复杂度置为 0。密码将从长度(8-14:1 分;15-19:2 分;20-30:3 分)和字符类型丰富度(每多一种字符加一分)两方面打分,并根据得分提示密码强度(3 分 - 弱;4 分 - 中;5 分 - 强;6 分 - 极强;7 分:固若金汤)。提示内容的背景颜色会随之变化。


确认密码框和密码框内容保持一致


当且仅当确认密码框和密码框内容保持一致且密码本身符合强度要求规定时,提示 “完全一致” 并允许注册。否则,对应显示 “密码不符合要求” 或 “两次输入的密码不一致”。提示内容的背景颜色会随之变化。


8ede627585394824a6609a9e8b5d36de.png


注册成功


如果该用户名从未被占用,且密码强度符合要求,则允许注册。


32cae3aa68d0421e85f572b43da8400d.png


注册失败


如果用户名被占用,会提示用户名被占用,并指引用户进行修改。


84bbc0164b9649d783f59f10d12add40.png


密码安全性


前端在向后端发送请求时会做和登录侧一样的处理,在此不再赘述。


后端部分


概述


后端采用了 Node.js 和 express 框架。依赖的 npm 包如下。


express

-express-session

mysql

-body-parser

sonwebtoken

bcryptjs

csprng

package.json 已经编写好,直接 npm install 即可。


数据库连接部分


const con = mysql.createConnection({
  host: <主机名>,
  user: "root",
  password: <数据库密码>,
  port: 3307,
  database: <数据库名>,
});
// 定义一个执行 sql 语句的函数 并且返回一个 promise 对象
const exec = (sql) => {
  const promise = new Promise((resolve, reject) => {
    con.query(sql, (err, result) => {
      resolve(result);
    });
  });
  return promise;
};
// 连接数据库
con.connect();


以后每次调用数据库都是通过如下过程进行。


const sql0 = <SQL语句>;
exec(sql0).then((result) => {});



相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
23天前
|
存储 前端开发 安全
实现“永久登录”:针对蜻蜓Q系统的用户体验优化方案(前端uni-app+后端Laravel详解)-优雅草卓伊凡
实现“永久登录”:针对蜻蜓Q系统的用户体验优化方案(前端uni-app+后端Laravel详解)-优雅草卓伊凡
125 5
|
5月前
|
JavaScript 前端开发 Java
制造业ERP源码,工厂ERP管理系统,前端框架:Vue,后端框架:SpringBoot
这是一套基于SpringBoot+Vue技术栈开发的ERP企业管理系统,采用Java语言与vscode工具。系统涵盖采购/销售、出入库、生产、品质管理等功能,整合客户与供应商数据,支持在线协同和业务全流程管控。同时提供主数据管理、权限控制、工作流审批、报表自定义及打印、在线报表开发和自定义表单功能,助力企业实现高效自动化管理,并通过UniAPP实现移动端支持,满足多场景应用需求。
494 1
|
6月前
|
前端开发 Java 物联网
智慧班牌源码,采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署
智慧班牌系统是一款基于信息化与物联网技术的校园管理工具,集成电子屏显示、人脸识别及数据交互功能,实现班级信息展示、智能考勤与家校互通。系统采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署与私有化定制。核心功能涵盖信息发布、考勤管理、教务处理及数据分析,助力校园文化建设与教学优化。其综合性和可扩展性有效打破数据孤岛,提升交互体验并降低管理成本,适用于日常教学、考试管理和应急场景,为智慧校园建设提供全面解决方案。
410 70
|
5月前
|
存储 消息中间件 前端开发
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
校园圈子系统校园论坛小程序采用uni-app前端框架,支持多端运行,结合PHP后端(如ThinkPHP/Laravel),实现用户认证、社交关系管理、动态发布与实时聊天功能。前端通过组件化开发和uni.request与后端交互,后端提供RESTful API处理业务逻辑并存储数据于MySQL。同时引入Redis缓存热点数据,RabbitMQ处理异步任务,优化系统性能。核心功能包括JWT身份验证、好友系统、WebSocket实时聊天及活动管理,确保高效稳定的用户体验。
319 4
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
|
7月前
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
329 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
4月前
|
人工智能 监控 前端开发
AI工具:前端与后端的终极对决?谁将成为新时代的宠儿?
深入探讨AI工具对前端和后端开发的具体影响、各自的机遇与挑战,并分析未来开发者如何驾驭AI,实现能力跃迁。
203 0
|
7月前
|
前端开发 算法 NoSQL
前端uin后端php社交软件源码,快速构建属于你的交友平台
这是一款功能全面的社交软件解决方案,覆盖多种场景需求。支持即时通讯(一对一聊天、群聊、文件传输、语音/视频通话)、内容动态(发布、点赞、评论)以及红包模块(接入支付宝、微信等第三方支付)。系统采用前后端分离架构,前端基于 UniApp,后端使用 PHP 框架(如 Laravel/Symfony),配合 MySQL/Redis 和自建 Socket 服务实现高效实时通信。提供用户认证(JWT 集成)、智能匹配算法等功能,助力快速上线,显著节约开发成本。
169 1
前端uin后端php社交软件源码,快速构建属于你的交友平台
|
6月前
|
监控 前端开发 小程序
陪练,代练,护航,代打小程序源码/前端UNIAPP-VUE2.0开发 后端Thinkphp6管理/具备家政服务的综合型平台
这款APP通过技术创新,将代练、家政、娱乐社交等场景融合,打造“全能型生活服务生态圈”。以代练为切入点,提供模块化代码支持快速搭建平台,结合智能匹配与技能审核机制,拓展家政服务和商业管理功能。技术架构具备高安全性和扩展性,支持多业务复用,如押金冻结、录屏监控等功能跨领域应用。商业模式多元,包括交易抽成、增值服务及广告联名,同时设计跨领域积分体系提升用户粘性,实现生态共生与B端赋能。
542 12
|
7月前
|
资源调度 JavaScript 前端开发
前端开发必备!Node.js 18.x LTS保姆级安装教程(附国内镜像源配置)
本文详细介绍了Node.js的安装与配置流程,涵盖环境准备、版本选择(推荐LTS版v18.x)、安装步骤(路径设置、组件选择)、环境验证(命令测试、镜像加速)及常见问题解决方法。同时推荐开发工具链,如VS Code、Yarn等,并提供常用全局包安装指南,帮助开发者快速搭建高效稳定的JavaScript开发环境。内容基于官方正版软件,确保合规性与安全性。
6181 24
|
8月前
|
SQL JavaScript 安全
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
320 11
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战

热门文章

最新文章