解决node项目一个极度困难的捕获异常却无法读取异常信息的问题

这篇具有很好参考价值的文章主要介绍了解决node项目一个极度困难的捕获异常却无法读取异常信息的问题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

这个项目是集成了第三方NeteaseCloudMusicApi项目的接口代码,我没有直接使用它的接口,因为需要再跑一个npm run开个端口,感觉很麻烦。

所以下定决心,使用拆分代码的方式,硬生生将这个api项目的部分api接口代码集成到了我自己的项目。当然前提是必须能看懂它的代码,然后才能做拆分,否则你根本无从下手

最后终于都搞定了,这个过程很复杂,把它的api代码拆分到了我自己的项目中。

但是有个问题,有时候请求歌曲的时候会报404错误

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 但是这个404错误报的明显不正确,因为我已经在代码里打了埋点

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 上面证明:这个接口请求实际已经匹配到路由了,所以绝不应该是404错误!

然后排查代码发现这个第三方api的错误处理代码居然写的是404!

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

这就不对了,肯定起码应该是个500,但是这还不够,起码得知道是什么错误,

所以,把它的msg的值写成捕获到的err

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 本以为这样处理就应该能看到具体的异常信息了,但是实际返回结果却还是空对象:

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 问题变得棘手了,异常明明捕获到了啊可是为什么打印不出来呢!

看来首先得看看这个err的原始信息是什么? 于是在catch代码块的开头先console.log一下这个err:

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

然后这个异常信息被打印出来了:

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获报错如下:

get Err==> TypeError: Cannot read property 'sort' of undefined
    at Object.module.exports [as module] (D:\VueCode\VueProject\myqqmusic\src\registerRouter\NetEaseApi\modules\song_url.js:33:10)
    at processTicksAndRejections (internal/process/task_queues.js:93:5)
    at async D:\VueCode\VueProject\myqqmusic\src\registerRouter\NetEaseApi\routes.js:69:40
 

 但是为什么把err赋值给msg就取不到值呢,然后断点调试看了一下这个error的数据结构:

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 然后结合GPT分析了一下,按理说: 通过err.message和err.stack应该可以获取到异常的具体信息:

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 然后确实看到了异常的具体信息了,这回没有报空值{}:

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 好了,小结一下:Javascript中Error对象必须通过message或者stack属性来获取到具体信息,

也就是err.message或者err.stack这种形式,不能把Error对象直接赋值给变量!!!否则变量获取的值就是空对象!

但是这种报错信息太难看了,应该根据报错指引,找到异常被触发的地方:

get Err==> TypeError: Cannot read property 'sort' of undefined
    at Object.module.exports [as module] (D:\VueCode\VueProject\myqqmusic\src\registerRouter\NetEaseApi\modules\song_url.js:33:10)
    at processTicksAndRejections (internal/process/task_queues.js:93:5)
    at async D:\VueCode\VueProject\myqqmusic\src\registerRouter\NetEaseApi\routes.js:69:40

 根据上面报错信息,找到song_url.js第33行:

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

这个地方说result没有sort属性,那么result本身极有可能也是个undefined!

所以非常有必要看看它的父级res到底是个什么东西

然后通过断点调试可以看到res底下果然没有data属性,那么result就必然是个undefined了,

难怪result.sort会触发Cannot read property 'sort' of undefined异常了

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

而且这里可以看到引发异常的真实原因:

// 这个异常信息是放在res.body里面的

 {
  code: -460,
  message: "网络太拥挤,请稍候再试!",
}

 所以在通过res.body.data获取result之前,要先判断一下res.body是否有data这个属性

或者说判断res的返回状态是否正常,因为仅仅根据res.body是否有data属性来判断返回是否正常有点太片面了

然后,我找了一个请求成功的例子:

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

可以看到请求成功的时候:不仅res.body有data属性,res.body.code还等于200,

所以应该增加以下代码:在res请求失败的时候主动抛出异常,并将res.body作为异常信息:

if (res.body.code != 200 ) {    

    throw new Error(res.body)   // 因为异常的详情信息是存储在res.body里面

  }

但是在前面说的外部异常拦截的地方(catch err代码块),得到结果是:msg没能正确解构出异常的信息,显示的是: [object Object]

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 关于这个问题,我查了很久也查了很多资料,尝试了很多次,都没有能够解决问题。

可以说:这是这次问题排查中难度最大的地方

然后呢,我就尝试着从chatgpt对话,希望能找到答案。

最初按照它给的方法试了好几次,也还是不行。

最后我问了一个关键的神提问:

你没懂我意思,比如原始异常的信息是res.body="{"code":-460,"message":"网络太拥挤,请稍候再试!"}" ,然后我throw new Error(JSON.stringify(res.body)) 抛出了这个异常,我问catch的时候怎么才能把这json格式的异常信息取出来

 然后chatgpt终于给出了正确的回答:

我明白你的问题了。如果你的异常信息是一个JSON字符串,你可以在catch块中使用JSON.parse来解析它,以获取原始的JSON对象。以下是一个示例:

try {
  const res = { body: '{"code":-460,"message":"网络太拥挤,请稍候再试!"}' };
  throw new Error(JSON.stringify(res.body));
} catch (error) {
  try {
    // 尝试将异常消息解析为JSON
    const errorData = JSON.parse(error.message);
    console.log("Error code:", errorData.code);
    console.log("Error message:", errorData.message);
  } catch (parseError) {
    // 处理解析JSON失败的情况
    console.error("Error parsing JSON:", parseError);
  }
}

在这个示例中,我们首先抛出一个异常,异常消息是JSON字符串。然后在catch块中,我们尝试使用JSON.parse将异常消息解析为JSON对象,并访问其中的属性。如果解析失败,我们捕获到解析错误并进行处理。

这样你就可以获取到原始的JSON对象信息了。但要小心处理JSON解析失败的情况,因为异常消息不一定总是有效的JSON字符串。

这里的关键有两点:

1.  自定义异常信息时: new Error构造函数通常接收一个字符串作为错误信息的参数,而不是一个对象

如果是接收参数是对象必须通过JSON.stringify()方法转换成json字符串

2. 当已预知捕获的error是json字符串时,那么此时必须使用JSON.parse()方法把error.message转换成object对象,否则打印出来的就是[object Object]

 所以,代码需要这样修改:

异常主动抛出的部分:

  if (res.body.code != 200 ) {

    // 注意这里new Error的参数不能是对象,而必须是字符串!!!

    // 所以res.body必须通过JSON.stringify转成字符串

    throw new Error(JSON.stringify(res.body))  

  }

 异常捕获的地方:

catch (err) {

                // 因为err.message是JSON字符串,必须通过JSON.parse转换成对象,

               // 否则msg: errData赋值时就会变成: Error: [object Object]

                // 这样msg就获取不到值,变成了空值了

                const errData = JSON.parse(err.message)  //关键点 :必须使用 JSON.parse方法

                console.log("Error message:", errData.message);       

                console.log("get Err==>", err)

                console.log('[ERR]', decode(req.originalUrl), {

                    status: err.status,

                    body: err.body,

                })

                if (!err.body) {

                    res.status(500).send({

                        code: 500,

                        data: null,

                        msg: errData,                    

                    })

                    return

                }

问题解决:前台msg信息终于正常显示出来了,不再是[object Object]

解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 解决node项目一个极度困难的捕获异常却无法读取异常信息的问题,node,axios,异常捕获

 总结:

1. Javascript中的Error对象必须通过message或者stack属性来获取到它的具体信息,

也就是err.message或者err.stack这种形式。

不能把整个Error对象直接赋值给变量!!!否则变量获取的值就是空对象!

2.  自定义异常信息时: new Error构造函数通常接收一个字符串作为错误信息的参数,而不是一个对象

如果是接收参数是对象必须通过JSON.stringify()方法把该对象转换成json字符串

// 主动抛出异常的部分

// 如果是接收参数是对象必须通过JSON.stringify()方法把该对象转换成json字符串

new Error(JSON.stringify(err_obj))

3. 当已预知捕获的error是json字符串时,那么此时必须使用JSON.parse()方法把error.message转换成object对象,否则打印出来的就是[object Object]

// 捕获异常的部分

catch(err) {

// 当已知err是json字符串时,则必须使用JSON.parse()方法把error.message转换成object对象,否则打印出来的就是[object Object]

   errData = JSON.parse(err.message)  // 使用JSON.parse方法是关键

}文章来源地址https://www.toymoban.com/news/detail-718790.html

到了这里,关于解决node项目一个极度困难的捕获异常却无法读取异常信息的问题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【异常解决】vue项目localhost:8080无法访问此网站或者无法访问此页面,localhost拒绝了我们的连接请求

    前端页面使用的是vue,vue项目启动成功,没有任何报错,服务控制台已出现APP访问地址,如下图所示: 点击访问地址,浏览器打开后页面先是空白,然后过了一会儿显示无法访问此网站,localhost拒绝了我们的连接请求页面,信息如下: 出现此问题的原因有以下几种:请挨个

    2023年04月25日
    浏览(73)
  • Qt中无法捕获键盘按下操作的解决方法

    上述代码片段是控制窗口中 pushButton 按钮实现 上下左右移动的功能 ;即,当按下键盘中的W、S、A、D或者↑、↓、←、→键时,pushButton按钮可以随之进行位置变化;运行时发现,按下W、S、A、D可以实现所需功能,而按下↑、↓、←、→键时,按钮没有反应; 这是由于没有捕

    2024年02月13日
    浏览(43)
  • 当IDEA加载一个MAVEN新项目时,加载不成功,无法加载依赖的解决方法

    此文为练习项目时的错误记录 当使用IDEA引入一个MAVEN新项目时,点击Reload maven按钮加载不成功,显示如下图界面: 在项目中的代码显示报红,如下图: 经查阅相关资料及反复尝试,解决方法如下: 进入File-Project Structure-Project,确认选择好自己版本的jdk,这里使用的是jdk1.

    2024年01月19日
    浏览(71)
  • 【C++】异常处理 ① ( 异常概念引入 | 抛出异常语法 | 捕获异常语法 | 异常捕获流程 | 异常处理代码示例 )

    异常是一种 特殊的程序流控制机制 , 用于处理程序中可能出现的错误或异常情况 ; 当程序执行错误时 , 由 throw 抛出异常 , 并即跳转到相应的异常处理程序中 ; 如果没有适当的异常处理程序处理该异常 , 程序会崩溃终止 ; 异常与函数对比 : 函数 是一种 以 栈结构 展开的

    2024年02月04日
    浏览(52)
  • 爬虫异常处理:异常捕获与容错机制设计

    作为一名专业的爬虫程序员,每天使用爬虫IP面对各种异常情况是我们每天都会遇到的事情。 在爬取数据的过程中,我们经常会遇到网络错误、页面结构变化、被反爬虫机制拦截等问题。在这篇文章中,我将和大家分享一些关于如何处理爬虫异常情况的经验和技巧。通过异常

    2024年02月11日
    浏览(44)
  • java异常处理机制(二)之异常处理与捕获

    1 Error(错误): 是指程序无法处理的错误,表示运行应用程序时比较严重的问题。大多数错误与代码编写者执行的操作无关,而表示代码运行时JVM(Java 虚拟机)出现的问题。 2 异常(Exception): 是指在程序执行时由于程序处理逻辑上的错误而导致程序中断的一种指令流。通俗的

    2024年02月05日
    浏览(108)
  • Java 异常处理以及如何捕获和处理多个异常

    在Java中,我们使用异常处理程序组件try,catch和finally块来处理异常。 为了捕获和处理异常,我们将try...catch...finally代码块放置在可能产生异常的代码周围。finally块是可选的。 try...catch...finally的语法为: 可能会生成异常的代码放在try块中。 每个try块后面应紧跟着catch 或 fi

    2024年02月14日
    浏览(44)
  • Python 异常捕获与处理

    当我们写程序难免遇到报错,专业的称呼叫做异常,行业俗语叫做bug,由于异常情况出现会导致代码停止运行,所以在编写过程中要尽可能避免。 语法错误 这一类错误很好理解,相当于你不会写,比如用if或for的时候不知道他们怎么写,这种情况比较夸张了,好好学过的人都

    2023年04月22日
    浏览(57)
  • c++捕获异常

    catch  块跟在  try  块后面,用于捕获异常。您可以指定想要捕捉的异常类型,这是由 catch 后的括号内的异常声明决定的。 try { // 保护代码 }catch( ExceptionName e ) { // 处理 ExceptionName 异常的代码 } 上面的代码会捕获一个类型为  ExceptionName  的异常。如果您想让 catch 块能

    2024年02月09日
    浏览(40)
  • Java中的异常Exception和捕获,自定义异常

    1.1 什么是程序的异常  在使用计算机语言进行项目开发的过程中,即使程序员把代码写得尽善尽美,在系统的运行过程中仍然会遇到一些问题,因为很多问题不是靠代码能够避免的。 异常 :指的是程序在执行过程中,出现的非正常情况,如果不处理最终会导致JVM的非正常停

    2023年04月20日
    浏览(43)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包