用原生nodejs写一个简单博客的后端,仅供学习用,实际开发中肯定用框架好,用原生写一遍能更好帮助你理解nodejs原理,让你使用nodejs更加得心应手。
GitHub仓库地址
https://github.com/rongliangtang/nodejs-for-blog-backend
项目实现
- 数据库开发
- 接口开发
- 登录:cookie和session的配合来存储登录状态
- 日志记录以及分析
- 安全:防止sql注入,xss攻击,密码加密
项目数据库设计
data:image/s3,"s3://crabby-images/634bc/634bc56adc43ea60a1c4e79084d32af4710ddc29" alt=""
data:image/s3,"s3://crabby-images/c2bde/c2bde6fc5ee4bb897b5dd8398ea924c243d9c93b" alt=""
项目接口设计
data:image/s3,"s3://crabby-images/3bb9a/3bb9a61ad53adf50b76d956025fe82344139cd6f" alt=""
项目结构解析
data:image/s3,"s3://crabby-images/e5950/e595038961551cd89414c191ee3b1c3f99d440c4" alt=""
启动前需要更改数据库配置和安装redis
数据库配置在src/config/db目录下,更改为你电脑上的数据库配置</br>
mysql中运行以下代码创建数据库和数据:
create database blog;
use blog;
create table user(
id INT(11) auto_increment primary key,
username VARCHAR(30) NOT null unique,
password VARCHAR(30) NOT null
);
create table classification(
id INT(11) auto_increment primary key,
name VARCHAR(30) NOT null unique,
number INT(11) default 0
);
create table article(
id INT(11) auto_increment primary key,
title VARCHAR(30) NOT null,
content longtext NOT null,
createtime bigint not null ,
classification INT(11)
);
insert into user (username,`password`) values ('admin','123456');
insert into user (username,`password`) values ('管理员','123456');
insert into classification (name,number) values ('分类1',2);
insert into classification (name) values ('分类2');
insert into article (title,content,createtime,classification) values('标题1','内容1',1111111111,1);
insert into article (title,content,createtime,classification) values('标题2','内容2',1112222222,1);
安装和启动redis参考</br>https://www.runoob.com/redis/redis-install.html</br>(注意启动后cmd窗口不可关闭)
启动前先安装项目所需要的依赖
npm install
编译运行
npm run dev
网友评论