blog项目回顾

这篇博客回顾了一个基于Node.js的小项目,涵盖了从创建服务器到数据库连接、路由设置、用户验证、密码加密、session管理等多个环节。作者特别提到了在登录逻辑中,密码的比对与session的使用,以及在数据分页、模板设计上的实践。同时,项目中遇到的一个未解决的问题是关于JSON解析错误,作者计划找到解决方案后更新博客。
摘要由CSDN通过智能技术生成

前言:第一次做完一个小项目,想来总结一下知识点和遇到的一些问题,可能写的有些凌乱。这次总结,想以项目知识点的顺序来做。
1.创建服务器
//引用express框架
const express = require(‘express’);
//创建网站服务器
const app = express();
2.数据库连接

//引入mongoose第三方模块
const mongoose = require('mongoose');
//连接数据库
mongoose.set('useCreateIndex', true);
mongoose.connect('mongodb://localhost/blog', {
    useNewUrlParser: true ,useUnifiedTopology: true})
.then(()=>{
   
    console.log('数据库连接成功');
}).catch(()=>{
   console.log('数据库连接失败');})

3.创建路由

//引用express框架
const express = require('express');
const admin = express.Router();

4.mongoose创建集合

// 创建用户集合
// 引入mongoose第三方模块
const mongoose = require('mongoose');
// 导入bcrypt
const bcrypt = require('bcrypt');
// 引入joi模块
const Joi = require('joi');
// 创建用户集合规则
const userSchema = new mongoose.Schema({
   
	username: {
   
		type: String,
		required: true,
		minlength: 2,
		maxlength: 20
	},
	email: {
   
		type: String,
		// 保证邮箱地址在插入数据库时不重复
		unique: true,
		required: true
	},
	password: {
   
		type: String,
		required: true
	},
	// admin 超级管理员
	// normal 普通用户
	role: {
   
		type: String,
		required: true
	},
	// 0 启用状态
	// 1 禁用状态
	state: {
   
		type: Number,
		default: 0
	}
});

// 创建集合
const User = mongoose.model('User', userSchema);

5.在服务器端验证用户信息
用到的模块:

// 引入joi模块
const Joi = require('joi');
const validateUser = user => {
   
	// 定义对象的验证规则
	const schema = {
   
		username: Joi.string().min(2).max(12).required().error(new Error('用户名不符合验证规则')),
		email: Joi.string().email().required().error(new Error('邮箱格式不符合要求')),
		password: Joi.string().regex(/^[a-zA-Z0-9]{
   3,30}$/).required().error(new Error('密码格式不符合要求')),
		role: Joi.string().valid('normal', 'admin').required().error(new Error('角色值非法')),
		state: Joi.number().valid(0, 1).required().error(new Error('状态值非法'))
	};

	// 实施验证
	return Joi.validate(user, schema);
}

6.为创建进数据库中的密码进行加密

// 导入bcrypt
const bcrypt = require('bcrypt');
async function createUser () {
   
	const salt = await bcrypt.genSalt(10);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当前课程中博客项目的实战源码是我在 GitHub上开源项目 My-Blog,目前已有 3000 多个 star:本课程是一个 Spring Boot 技术栈的实战类课程,课程共分为 3 大部分,前面两个部分为基础环境准备和相关概念介绍,第三个部分是 Spring Boot 个人博客项目功能的讲解,通过本课程的学习,不仅仅让你掌握基本的 Spring Boot 开发能力以及 Spring Boot 项目的大部分开发使用场景,同时帮你提前甄别和处理掉将要遇到的技术难点,认真学完这个课程后,你将会对 Spring Boot 有更加深入而全面的了解,同时你也会得到一个大家都在使用的博客系统源码,你可以根据自己的需求和想法进行改造,也可以直接使用它来作为自己的个人网站,这个课程一定会给你带来巨大的收获。作者寄语本课程录制于 2020 年,代码基于 Spring Boot 2.x 版本。到目前为止,Spring Boot 技术栈也有一些版本升级,比如 Spring Boot 2.7 发版、Spring Boot 3.x 版本发布正式版本。对于这些情况,笔者会在本课程实战项目的开源仓库中创建不同的代码分支,保持实战项目的源码更新,保证读者朋友们不会学习过气的知识点。课程特色 课程内容紧贴 Spring Boot 技术栈,涵盖大部分 Spring Boot 使用场景。开发教程详细完整、文档资源齐全、实验过程循序渐进简单明了。实践项目页面美观且实用,交互效果完美。包含从零搭建项目、以及完整的后台管理系统和博客展示系统两个系统的功能开发流程。技术栈新颖且知识点丰富,学习后可以提升大家对于知识的理解和掌握,对于提升你的市场竞争力有一定的帮助。实战项目预览    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值