node.js全栈项目
创始人
2024-05-11 21:15:23
0

一、项目介绍

本项目适合作为一个课程设计或者毕业设计,最终实现了一个完整的博客系统,包括用户的登录、注册,图片上传,文章的发布、富文本编辑器、删除、编辑、修改、列表展示,评论的发布、删除、列表展示,以及实现了用户的文章和评论的后台管理和博客的前台展示和评论功能。

二、涉及技术

    • HTML+CSS+JavaScript(涉及ES6以后新增内容)
    • node.js
    • Express框架
    • mongoDB

三、涉及软件

  1. VScode(编写代码)

  1. APIpost(接口调试)

  1. node.js(后端工作)

  1. robo3t(操作数据库)

四、项目展示

1.注册页面

选择文件即为选择头像

2.登录页面

输入用户名和密码会在数据库中进行匹配,错误则无法登录

3.博客主页面

该项目会记录浏览量以及评论量,以及发布时间和作者

5.文章主页面

系统会按照时间展示评论,以及评论人的昵称和评论时间

6.用户发布文章主界面

在这里用户任意编辑文章发布,包括插入图片,同时可以查看自己之前博客,也可以对其编辑或者删除

7.删除评论功能

在用户编辑文章页面,可以修改文章,同时也可以删除别人评论

五、代码展示

后端框架(利用Express生成的脚手架)

前端页面设计

服务器的启动以及调用各种中间件

var createError = require("http-errors");
var express = require("express");
var path = require("path");
var cookieParser = require("cookie-parser");
var logger = require("morgan");
let { expressjwt } = require("express-jwt");var articlesRouter = require("./routes/articles");
var usersRouter = require("./routes/users");
var uploadRouter = require("./routes/upload");
var commentsRouter = require("./routes/comments");var articlesFrontRouter = require("./routes/front/articles");
var commentsFrontRouter = require("./routes/front/comments");var app = express();//设置跨域访问
app.all("*", function (req, res, next) {//设置允许跨域的域名,*代表允许任意域名跨域res.header("Access-Control-Allow-Origin", req.headers.origin || "*");//允许的header类型res.header("Access-Control-Allow-Headers","Content-Type, Authorization, X-Requested-With");// //跨域允许的请求方式res.header("Access-Control-Allow-Methods","PATCH,PUT,POST,GET,DELETE,OPTIONS");// 可以带cookiesres.header("Access-Control-Allow-Credentials", true);if (req.method == "OPTIONS") {res.sendStatus(200).end();} else {next();}
});// view engine setup
app.set("views", path.join(__dirname, "views"));
app.set("view engine", "ejs");app.use(logger("dev"));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, "public")));//解析jwt
app.use(expressjwt({secret: "test12345",algorithms: ["HS256"],}).unless({// 要排除的 路由path: ["/api/users","/api/upload",/^\/api\/articles\/users\/\w+/,{url: /^\/api\/articles\/\w+/,methods: ["GET"],},// 前台两个文章接口不需要权限"/api/front/articles",{url: /^\/api\/front\/articles\/\w+/,methods: ["GET"],},{url: /^\/api\/front\/comments\/articles\/\w+/,methods: ["GET"],},],})
);app.use("/api/users", usersRouter);
app.use("/api/upload", uploadRouter);
app.use("/api/articles", articlesRouter);
app.use("/api/comments", commentsRouter);
app.use("/api/front/articles", articlesFrontRouter);
app.use("/api/front/comments", commentsFrontRouter);app.use(function (err, req, res, next) {if (err.name === "UnauthorizedError") {res.status(401).json({ code: 0, msg: "无效的token或者没有没有传递token-请重新登录" });} else {next(err);}
});
// catch 404 and forward to error handler
app.use(function (req, res, next) {next(createError(404));
});// error handler
app.use(function (err, req, res, next) {// set locals, only providing error in developmentres.locals.message = err.message;res.locals.error = req.app.get("env") === "development" ? err : {};// render the error pageres.status(err.status || 500);res.render("error");
});module.exports = app;

(代码过多不一一展示了)

六、源码及配套软件

需要源码和配套软件的朋友可以私信我

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...