首页 文章

如何在Hapi js中设置单页面应用程序的路径

提问于
浏览
0

我试过这个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 回答

  • 0

    对于单个文件,您可以使用:

    server.route({
            method: 'GET',
            path: '/samplespa/index.html',
            handler: function (request, h) {
                return h.file('./samplespa/index.html');
            }
        });
    

    对于多个文件,以下内容 . 请注意,处理程序现在不是函数而是对象 .

    server.route({
            method: 'GET',
            path: '/samplespa/{file*}',
            handler: {
              directory: {
                path: 'samplespa'
              }
            },
        });
    

相关问题