-
Notifications
You must be signed in to change notification settings - Fork 70
/
Copy pathserver.js
65 lines (57 loc) · 2.38 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/** 用于开发环境的服务启动 **/
const path = require("path"); // 获取绝对路径有用
const express = require("express"); // express服务器端框架
const env = process.env.NODE_ENV; // 模式(dev开发环境,production生产环境)
const webpack = require("webpack"); // webpack核心
const webpackDevMiddleware = require("webpack-dev-middleware"); // webpack服务器
const webpackHotMiddleware = require("webpack-hot-middleware"); // HMR热更新中间件
const webpackConfig = require("./webpack.dev.config.js"); // webpack开发环境的配置文件
const mock = require("./mock/mock-data"); // mock模拟数据,模拟后台业务
const app = express(); // 实例化express服务
const DIST_DIR = webpackConfig.output.path; // webpack配置中设置的文件输出路径,所有文件存放在内存中
let PORT = 8888; // 服务启动端口号
app.use(express.urlencoded({ extended: false }));
app.use(express.json());
/** 监听POST请求,返回MOCK模拟数据 **/
app.post(/\/api.*/, (req, res, next) => {
const result = mock.mockApi({ url: req.originalUrl, body: req.body });
res.send(result);
});
app.get(/\/api.*/, (req, res, next) => {
const result = mock.mockApi({ url: req.originalUrl, body: req.body });
res.send(result);
});
if (env === "production") {
// 如果是生产环境,则运行build文件夹中的代码
PORT = 8889;
app.use(express.static("build"));
app.get("*", (req, res) => {
res.sendFile(path.join(__dirname, "build", "index.html"));
});
} else {
const compiler = webpack(webpackConfig); // 实例化webpack
app.use(express.static("dll"));
app.use(
webpackDevMiddleware(compiler, {
publicPath: webpackConfig.output.publicPath, // 对应webpack配置中的publicPath
}),
);
app.use(webpackHotMiddleware(compiler)); // 挂载HMR热更新中间件
// 所有请求都返回index.html
app.get("*", (req, res, next) => {
const filename = path.join(DIST_DIR, "index.html");
// 由于index.html是由html-webpack-plugin生成到内存中的,所以使用下面的方式获取
compiler.outputFileSystem.readFile(filename, (err, result) => {
if (err) {
return next(err);
}
res.set("content-type", "text/html");
res.send(result);
res.end();
});
});
}
/** 启动服务 **/
app.listen(PORT, () => {
console.log("本地服务启动地址: http://localhost:%s", PORT);
});