代码拉取完成,页面将自动刷新
//导入express
const express = require('express')
const app = express() //创建服务器
//安装跨域的中间件
const cors = require('cors')
// 使用express.static将upload目录中的图片托管成静态资源
app.use('uploads', express.static('./uploads'))
app.use(cors())
//配置解析表单的中间件
app.use(express.urlencoded({ extended: false }))
// 封装res.cc
app.use((req, res, next) => {
// status = 0 为成功; status = 1 为失败; 默认将 status 的值设置为 1,方便处理失败的情况
res.cc = (err, status = 1) => {
res.send({
// 状态
status,
// 状态描述,判断 err 是 错误对象 还是 字符串
message: err instanceof Error ? err.message : err,
})
}
next()
})
// 导入配置文件
const config = require('./config')
// 在路由之前配置解析token的中间件
const expressJwt = require('express-jwt')
// 以/api开头的地址不需要token
app.use(expressJwt({
secret: config.jwtSecretKey
}).unless({ path: [/^\/api\//] }));
const Joi = require('@hapi/joi')
// router中间件
const userouter = require('./router/user')
app.use('/api', userouter)
// 导入使用个人中心的路由模块
const userinfoRouter = require('./router/userinfo')
app.use('/my', userinfoRouter)
// 导入并使用文章分类的路由模块
const artCateRouter = require('./router/artcate')
app.use('/my/article', artCateRouter)
// 导入并使用发布文章的路由
const articleRouter = require('./router/article')
app.use('/my/article', articleRouter)
// 定义错误级别的的中间件
app.use((err, req, res, next) => {
console.log(err);
// 数据验证失败
if (err instanceof Joi.ValidationError) return res.cc(err)
if (err.name === 'UnauthorizedError') return res.cc('身份认证失败')
// 未知错误
res.cc(err)
})
//
// 启动服务器
app.listen(80, () => {
console.log('http://127.0.0.1');
})
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。