我正在使用koa-static在koajs上主持一个emberjs应用程序。根据以下代码:
var app = koa();
var App1 = koa();
App1.use(stati(__dirname + "/App1"));
app.use(mount('/AppViewer',App1));
app.listen(3000);
当调用localhost:3000/AppViewer
我无法看到我的页面并得到错误说无法找到.js和.css文件,但是当调用localhost:3000/AppViewer/index.html
时,一切正常。所以我的问题是如何在调用localhost:3000/AppViewer
时看到我的页面。
首先,它似乎很奇怪,因为koa-static
应该默认在root上提供index.html
。确保App1
没有将/
路由到其他地方。
然后,您仍然可以使用index.html
删除URL中的koa-rewrite
。就像是:
var rewrite = require('koa-rewrite');
App1.use(rewrite('/*', '/index.html'));
UPDATE
使用以下代码进行测试:
var koa = require('koa');
var app = koa();
var app1 = koa();
var mount = require('koa-mount');
var serve = require('koa-static');
var rewrite = require('koa-rewrite');
var route = require('koa-route');
app1.use(serve(__dirname + "/app1"));
app1.use(rewrite('/*', '/index.html'));
app.use(mount('/av', app1));
app.use(route.get('/', function *(next) {
this.body = 'I\'m the main app!';
}));
app.listen(3000);
这对我使用ember-cli并部署到heroku就足够了:
var common = require('koa-common'),
koa = require('koa'),
app = koa();
var env = process.env.NODE_ENV || 'development',
port = process.env.PORT || '3800';
app.use(common.logger());
app.use(common.responseTime());
app.use(common.static(__dirname + "/dist"));
app.listen(port);
console.log('listening on port ' + port);
其中/ dist是ember构建的构建输出(相当于grunt dist w / EAK)
koa-static对我不起作用。我反而尝试过koa-static-server和yay!
我的中间件:
var Proxy = require("koa-proxy");
// const Rewrite = require("koa-rewrite");
const StaticServer = require("koa-static-server");
export const InstallWebApp = (app) => {
if (process.env.NODE_ENV === "production") {
// Install static web app
// app.use(Rewrite('/*', '/'));
app.use(StaticServer({rootDir: `${__dirname}/../../../../client-web/build`, notFoundFile: "index.html"}));
} else {
// Install dev server
app.use(
Proxy({
host: `http://localhost:${process.env.WEB_DEV_PORT}`,
})
);
}
};