处理 UrlFetchApp.fetch() 中的 404 错误

2024-04-19

我正在 Google Spreadsheets 中创建一个扩展,并尝试处理 urlFetch() 可能给出的 404 错误。现在它只是在电子表格顶部显示一个弹出窗口,如下所示:

https://i.stack.imgur.com/fvCPC.png https://i.stack.imgur.com/fvCPC.png

这是我的代码:

function doTestAPICall() {
  var headers = {
    'Authorization': 'Basic ' + Utilities.base64Encode(user + "/token:" + token)
  };
  var url = "https://" + subdomain + ".domain.com/api/v2/users/me.json";
  var options = {
    'contentType': 'application/json',
    'method': 'get',
    'headers': headers
  };
  var response = UrlFetchApp.fetch(url, options);
  if(response.getResponseCode() == 200){
    var json = response.getContent();
    var data = JSON.parse(json);
    if(data.user.email != user){
      return false;
    } else {
      //User was correctly authenticated
      return true;
    } 
  }else{
    return false;
  }
}

但是,该函数永远不会到达response.getResponseCode(),因为它在UrlFetchApp.fetch 函数上已经失败。关于如何处理这个问题有什么想法/建议吗?

谢谢你!

- - 编辑 - -

根据 Amit 的建议,在 UrlFetchApp 选项中添加 muteHttpExceptions 解决了该问题。

代码现在看起来像这样:

function doTestAPICall() {
  var headers = {
    'Authorization': 'Basic ' + Utilities.base64Encode(user + "/token:" + token)
  };
  var url = "https://" + subdomain + ".domain.com/api/v2/users/me.json";
  var options = {
    'contentType': 'application/json',
    'method': 'get',
    'headers': headers,
    'muteHttpExceptions': true
  };
  var response = UrlFetchApp.fetch(url, options);
  if(response.getResponseCode() == 200){
    var json = response.getContentText();
    var data = JSON.parse(json);
    if(data.user.email != user){
      return false;
    } else {
      //User was correctly authenticated
      return true;
    } 
  }else{
    return false;
  }
}

您可以在 HTTP 请求中将 muteHttpExceptions 设置为 true 以抑制这些错误。

function fetchPage() {
  var response = UrlFetchApp.fetch("http://ctrlq.org/404", {muteHttpExceptions: true});
  if (response.getResponseCode() == 404) {
    Logger.log("Web page not found");
  }
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

处理 UrlFetchApp.fetch() 中的 404 错误 的相关文章

随机推荐