代码拉取完成,页面将自动刷新
//引入各种包
var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');
var app = express();//实例化一个应用
//安装中间件
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());
//上传的文件体,分发到不同位置
let multer = require('multer');
let storage = multer.diskStorage({
destination: function (req, file, cb) {
if(req.url.includes('user')|| req.url.includes('reg')){
cb(null, path.join(__dirname,'public','upload','user'))
}else if(req.url.includes('banner')){
cb(null, path.join(__dirname,'public','upload','banner'))
}else{
cb(null, path.join(__dirname,'public','upload','product'))
}
}
})
let objMulter = multer({ storage});
app.use(objMulter.any()); //允许上传什么类型文件,any 代表任何类型
//静态资源托管 接口的权重比资源托管 高
app.use(express.static(path.join(__dirname, 'public','template','views')));
app.use(express.static(path.join(__dirname, 'public','template')));
// app.use(express.static(path.join(__dirname, 'public','admin')));
app.use(express.static(path.join(__dirname, 'public')));
// 可以添加别名
//客户端接口
app.all('/api/*',require('./routes/api/params'));//处理api一下所有的公共参数
app.use('/api/goods', require('./routes/api/goods'));
app.use('/api/reg', require('./routes/api/reg'));
app.use('/api/login', require('./routes/api/login'));
app.use('/api/user', require('./routes/api/user'));
app.use('/api/logout', require('./routes/api/logout'));
//服务端接口
//代理端接口
//推送端接口
// 处理404
app.use(function(req, res, next) {
next(createError(404));
});
// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
if(req.url.includes('/api')){//你再访问一个不存在的api/不存在
res.send({err:1,msg:'不存在的接口'})
}else if(req.url.includes('/admin')){
res.render('error');
}else{ //解决 vue项目部署后的问题
}
});
module.exports = app;
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。