AkideLiu
V2EX  ›  Node.js

NodeJs 使用 express 和 typeorm 的项目如何实现 Global Error Handling

  •  
  •   AkideLiu · Jun 8, 2021 · 2889 views
    This topic created in 1799 days ago, the information mentioned may be changed or developed.

    最近在写 nodejs,遇到了一个问题很迷幻。

    如何在 controller/router 层来处理 services 或则 repository 层传递过来的错误呢?

    现在是用 try catch 代码实在是太丑了。

    我想实现的是类似于 Spring boot 的 controllerAdvise/ExceptionHandler 这种形式

    网上搜了一圈也没啥好的办法,希望大佬们给点意见

    例子如下:

    router:

    
        async login(req: Request, res: Response) {
    
            try {
                const {user, accessToken} = await this.userRepository.findAndGenerateToken(req.body);
    
                const token = await AuthService.generateTokenResponse(user, accessToken);
    
                if (user.Role[0].role_id !== 3 && user.is_approval === false) {
                    return ApiResultBean.errorMessage("User need to be approve!!");
                }
    
                if (token instanceof Error) {
                    return ApiResultBean.error(req, token);
                }
    
                return ApiResultBean.success({token, user});
    
            } catch (error){
    
                // res.status(error.statusCode)
                console.log(error);
                if (error.output.payload) {
                    return ApiResultBean.error(req, error,error.output.payload.message);
                }
                return ApiResultBean.error(req, error);
    
            }
    
    
        }
    

    repository 层:

    
           public async findAndGenerateToken(options: tokenOptions): Promise<{ user: User, accessToken: string; }> {
    
                const {username, emailAddress, password, refreshToken} = options;
    
                if (!emailAddress && !username) {
                    throw badRequest("An email address or username is required to generate a token");
                }
    
                let user;
    
                try {
                    user = await this.findOne({
                        relations: ['Role'],
                        where: emailAddress ? {emailAddress: emailAddress} : {username: username}
                    });
                }catch (error) {
                    return error;
                }
    
    
                if (!user) {
                    throw notFound('User not found');
                } else if (password && await user.passwordMatches(password.toString()) === false) {
                    throw unauthorized('Password must match to authorize a token generating');
                } else if (refreshToken && refreshToken.user.emailAddress === emailAddress && Dayjs(refreshToken.expires).isBefore(Dayjs())) {
                    throw unauthorized('Invalid refresh token');
                }
                return {user, accessToken: user.token()};
    
        }
    
    
    8 replies    2021-07-19 17:15:22 +08:00
    zzetao
        1
    zzetao  
       Jun 8, 2021
    AkideLiu
        2
    AkideLiu  
    OP
       Jun 8, 2021
    @zzetao 试过了不太行。。
    knives
        3
    knives  
       Jun 9, 2021
    没用过 express,查文档查到的: https://expressjs.com/zh-cn/guide/error-handling.html

    按理说作为 node web 框架鼻祖,大家的处理方式应该都差不多,一个 middleware 就应该能搞定才是。
    hongweiliuruige
        4
    hongweiliuruige  
       Jun 9, 2021
    nestjs 解君愁
    ChevalierLxc
        5
    ChevalierLxc  
       Jun 9, 2021
    @knives 我第一个也想到的是 middleware
    LawlietZ
        6
    LawlietZ  
       Jun 9, 2021
    中间件,不管 node 哪个框架
    leopod1995
        7
    leopod1995  
       Jun 9, 2021
    google `express global error handling`
    https://expressjs.com/en/guide/error-handling.html
    xcstream
        8
    xcstream  
       Jul 19, 2021
    app.use(function(err, req, res, next) {
    console.error(err.stack);
    res.status(500).send('Something broke!');
    });
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   4436 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 51ms · UTC 10:09 · PVG 18:09 · LAX 03:09 · JFK 06:09
    ♥ Do have faith in what you're doing.