我试过这个https://github.com/hapijs/hapi/issues/800 . 这不适合我 .
const start = async () => {
await server.register(require('inert'));
server.route({
method: 'GET',
path: '/samplespa/{file*}',
handler: function (request, h) {
directory :{
path : './samplespa/'
listing: true
}
}
});
server.ext('onPostHandler', (request, reply) => {
console.log('WORD');
const response = request.response;
if (response.isBoom && (response.output.statusCode === 500) ) {
return reply.file('./samplemap.html');
}
return reply.continue;
});
await server.start();
console.log('Server running at:', server.info.uri);
};
start();
我想服务目录samplespa并在其中呈现文件“index.html”并注意index.html是用Angular 1.X编写的,并且依赖于目录中的文件 .
也适用于路径:http://localhost:8000/samplespa/index.html
我收到以下回复
{
"statusCode": 500,
"error": "Internal Server Error",
"message": "An internal server error occurred"
}
我在vs代码中收到以下错误消息:
Debug: internal, implementation, error
Error: handler method did not return a value, a promise, or throw an error
at module.exports.internals.Manager.execute (/Users/pavithran/projects/toilet-tracker/node_modules/hapi/lib/toolkit.js:52:29)
at <anonymous>
at process._tickCallback (internal/process/next_tick.js:188:7)
这该怎么做???我已经尝试了过去两天的一切,但无法弄清楚..
1 回答
对于单个文件,您可以使用:
对于多个文件,以下内容 . 请注意,处理程序现在不是函数而是对象 .