[Hapi.js] Friendly error pages with extension events

hapi automatically responds with JSON for any error passed to a route's reply()method. But what if your application needs errors rendered in HTML? This lesson shows how to implement friendly HTML error messages using hapi extension events.

 

const Hapi = require( 'hapi' )
const Boom = require( 'boom' )
const server = new Hapi.Server()
server.connection( { port: 8000 } )


server.register(require('vision'), function(request, reply){
    server.views({
        engines: { hbs: require('handlebars') },
        relativeTo: __dirname,
        path: 'views'
    });

    server.ext('onPreResponse', function(request, reply){
        var resp = request.response;
        // if there is an error
        if (resp.isBoom) {
            return reply.view('error', resp.output.payload)
                        // change the status code
                        .code(resp.output.statusCode);
        }
        reply.continue()
    })
})


server.start( function (err) {
    if (err) {
        throw err;
    }
    console.log( 'Started at:', server.info.uri )
} );

 

转载于:https://www.cnblogs.com/Answer1215/p/5226230.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值