溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

用Fundebug插件記錄網(wǎng)絡(luò)請(qǐng)求異常的方法

發(fā)布時(shí)間:2020-09-22 18:20:06 來(lái)源:腳本之家 閱讀:138 作者:Fundebug 欄目:web開(kāi)發(fā)

在服務(wù)端,不管我們使用Node.js、Java、PHP還是Python等等,都會(huì)用日志以文本的形式記錄請(qǐng)求以及報(bào)錯(cuò)信息。這個(gè)對(duì)于后端做事后分析是很有用的。

另一方面,前端有時(shí)候出問(wèn)題其實(shí)是因?yàn)楹蠖私涌趫?bào)錯(cuò),返回?cái)?shù)據(jù)異常導(dǎo)致。而實(shí)際上,前端才是用戶直接觸及的端,所以出了問(wèn)題,首先是在前端體現(xiàn)出來(lái),首先也是找前端。

用Fundebug插件記錄網(wǎng)絡(luò)請(qǐng)求異常的方法

為了更好地定位問(wèn)題是前端代碼還是接口問(wèn)題,在這里推薦使用Fundebug的前端JavaScript監(jiān)控插件。該插件從0.1.0之后,就開(kāi)始支持HTTP請(qǐng)求錯(cuò)誤的監(jiān)控。

例子

為了測(cè)試,我寫一個(gè)簡(jiǎn)單的例子。沒(méi)有用到任何復(fù)雜的框架,就是一個(gè)簡(jiǎn)單的HTML加上網(wǎng)絡(luò)請(qǐng)求的JS。

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>Test HTTP Request</title>
</head>
<body>
  <h2>This is a test for HTTP request error !</h2>
  <button onclick="loadRequest()">Click</button>
</body>
<script type="text/javascript">
function loadRequest() {
  var oReq = new XMLHttpRequest();
  oReq.open("GET", "http://127.0.0.1:8080/example/");
  oReq.send();
}
</script>
</html>

然后,在Fundebug創(chuàng)建一個(gè)JS監(jiān)控項(xiàng)目,并拷貝接入代碼:

用Fundebug插件記錄網(wǎng)絡(luò)請(qǐng)求異常的方法

完整代碼如下所示:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>Test HTTP Request</title>
</head>
<body>
  <h2>This is a test for HTTP request error !</h2>
  <button onclick="loadRequest()">Click</button>
</body>
<script type="text/javascript">
function loadRequest() {
  var oReq = new XMLHttpRequest();
  oReq.open("GET", "http://127.0.0.1:8080/example/");
  oReq.send();
}
</script>
<script src="https://js.fundebug.cn/fundebug.1.0.3.min.js"
    apikey="YOUR-API-KEY"></script>
</html>

使用http-server命令直接運(yùn)行(推薦小技巧:使用npm install -g http-server安裝一個(gè)簡(jiǎn)單的服務(wù)器。),在瀏覽器輸入地址http://127.0.0.1:8080訪問(wèn)該頁(yè)面。

用Fundebug插件記錄網(wǎng)絡(luò)請(qǐng)求異常的方法

點(diǎn)擊頁(yè)面上的click按鈕,就會(huì)觸發(fā)這個(gè)錯(cuò)誤。在Fundebug的控制臺(tái)可以看到報(bào)錯(cuò)信息,如下所示:

用Fundebug插件記錄網(wǎng)絡(luò)請(qǐng)求異常的方法

點(diǎn)擊該錯(cuò)誤,可以查看報(bào)錯(cuò)詳情。一個(gè)http的get請(qǐng)求訪問(wèn)http://127.0.0.1:8080/example/,然后返回404。當(dāng)然,http的請(qǐng)求錯(cuò)誤類型有很多,不僅可以抓404, 什么401啊,403啊,500啊等等都能抓過(guò)來(lái)。

用Fundebug插件記錄網(wǎng)絡(luò)請(qǐng)求異常的方法

另外,通過(guò)用戶行為也可以很好地看到觸發(fā)報(bào)錯(cuò)的過(guò)程:

用Fundebug插件記錄網(wǎng)絡(luò)請(qǐng)求異常的方法

跨域問(wèn)題

如果訪問(wèn)的是非同源的請(qǐng)求,那么報(bào)錯(cuò)會(huì)拿不到狀態(tài)碼,也就是說(shuō)status不會(huì)是404,而是0。這個(gè)比較蛋疼!

總結(jié)

監(jiān)控HTTP請(qǐng)求錯(cuò)誤有什么好處?

第一時(shí)間發(fā)現(xiàn)HTTP請(qǐng)求出現(xiàn)狀況;

及時(shí)告知后端服務(wù)器出了問(wèn)題,快速應(yīng)對(duì);

分析前端其它bug的時(shí)候多了一份信息參考;

用戶反饋服務(wù)無(wú)法使用的時(shí)候,可以快速知道問(wèn)題原因。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI