关于koa:优雅-koa处理异常

39次阅读

共计 2313 个字符,预计需要花费 6 分钟才能阅读完成。

一个良好的编码习惯必然离不开异样解决,本文将会介绍如何在 koa 框架上面如何抛出谬误,并对立解决返回异样。

失常错误处理

koa 是一个优良的 NodeJs web 框架,在咱们开发 web 我的项目的时候,防止不了任何错误处理,包含 http 谬误以及自定义的业务逻辑解决。
在 Node.js 中,抛出谬误如下

if(someCondition){throw Error("Error");
}

Http 错误处理

这里应用 ctx.throw(400)的形式,抛出 http 谬误,同时返回一些信息。

ctx.status = 400
ctx.body = {msg: "some params is invalid"}

此时既返回了状态码,又返回了相干的错误信息。

业务逻辑错误处理

如果须要开发 Restful API server,这个时候须要定义若干的业务逻辑错误代码,像上面这样的

code 码 阐明
0 success
-1 server error
4001 token 过期

这个时候,就须要在业务层中进行解决。

router.get("/", (ctx, next) => {if(tokenExpire(token)){
        const errcode = ERROR_CODE.TOKEN_EXPIRED;
        ctx.body = {
            errcode,
            msg: ERROR_MSG[errcode]
        }
        return
    }
})

这里,就返回了相干的 errcode,通过 errcode 的形式返回了相干的错误代码

全局捕捉异样解决

这里在 koa 里,全局捕捉异样,这里应用中间件的形式,确保异样能够捕捉到
在 middlewares 建设一个 catcherror 中间件,达到捕捉到异样的形式

// middlewares/catcherror.js
const catchError = async(ctx, next) => {
    try{await next();
    }catch(error){if(error.errorCode){console.log("捕捉到异样")
            return ctx.body = errror.msg;
        }
    }
}
module.exports = catchError

这样定义一个中间件,在中间件进行相干的捕捉,确保捕捉到相干的异样,并把这个中间件进行导出。

放在 next 外面,如果 next 程序出现异常,就能够实现在中间件进行相干的捕捉。

const koa = require("koa")
const Router = require("router")
const app = new koa();
const router = new Router();
const catchError = require("./middlewares/catcherror")

app.use(catchError)

router.get('/login', (ctx, next) => {
    const path = ctx.request.query;
    
    // 被动抛出谬误
    if(true){const error = new Error();
        error.errorCode = 1000;
        error.msg = "谬误";
        throw error
    }
})

app.use(router.routers())
app.listen(3000)

这个时候,凭借着中间件,能够实现抛出谬误异样。

应用基类的形式解决

被动抛出谬误,会显示的相当麻烦,这里应用面向对象的形式,继承 error 类。
把错误信息,放入到 error 类中,通过放入 error 类中,实现对谬误的间接抛出。

// core/http-exception.js

class HttpException extends Error{constructor(msg = '服务器异样', errorCode = 1000. code = 400){super();
        this.msg = msg;
        this.code = code;
        this.errorCode = errorCode;
    }
}
module.export = HttpException

再次改写 app.js

// app.js
const koa = require('koa')
const Router = require('router')
const app = new koa()
const router = new Router()
const {HttpException} = require('../core/http-exception')
const catchError = require('./middlewares/catcherror')

app.use(catchError) // 肯定要放在第一个中间件

router.get('/login',(ctx,next)=>{
    const path = ctx.request.query
    
    // 咱们被动抛出一个谬误
    if(true){
        // 次要改写这里,创立新的异样
        const error = new HttpException('登录谬误',10000,500)
        throw error
    }
})

app.use(router.routes())
app.listen(3000)

再次改写中间件,判断异样是否属于此异样的对象

// middlewares/catcherror.js
const {HttpException} = require('../core/http-exception')
const catchEoore = async (ctx,next)=>{
        try{await next()
        } catch(error){if(error instanceof HttpExcetion){return ctx.body = error.msg}
        }
    }
}

module.exports = catchError

这样就实现了一次的改写。

微信公众号

正文完
 0