如何针对 Google Apps Script ContentService 发出 XHR/ajax 请求?
Posted
技术标签:
【中文标题】如何针对 Google Apps Script ContentService 发出 XHR/ajax 请求?【英文标题】:How do I make XHR/ajax requests against Google Apps Script ContentService work? 【发布时间】:2012-07-13 22:30:40 【问题描述】:我有一个简单的 Google Apps Script ContentService,它会发出类似“Hello world Sat Jul 14 2012 14:17:21 GMT+1000 (EST)”的字符串,网址是 https://script.google.com/macros/s/AKfycbxbFFG95mi8PWVNCE8366XaxnXQrt6p7p3OWbclXch_bbWczQ/exec,它对匿名开放。随意击打它。代码是:
function doGet()
var output = ContentService.createTextOutput()
.setMimeType(ContentService.MimeType.TEXT)
.setContent("Hello world " + new Date());
Logger.log(output.getContent());
return output;
当我在浏览器中访问 URL 时,它会按预期返回字符串 (pass.png)。当我在 XHR(ajax 调用)中使用相同的 URL 时,它会失败并显示一个空错误。在 Chrome 的开发者工具中,重定向是 "(canceled)" (fail.png) 。这是重现失败的代码:
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc()
xhr=new XMLHttpRequest();
xhr.onreadystatechange=function()
if (xhr.readyState==4 && xhr.status==200)
document.getElementById("myDiv").innerHTML=xhr.responseText;
;
xhr.open("GET","https://script.google.com/macros/s/AKfycbxbFFG95mi8PWVNCE8366XaxnXQrt6p7p3OWbclXch_bbWczQ/exec",true);
xhr.send();
</script>
</head>
<body>
<h2>Using the XMLHttpRequest object</h2>
<div id="myDiv"></div>
<button type="button" onclick="loadXMLDoc()">Get Content via XHR</button>
</body>
</html>
直接请求: XHR 请求: 我的问题(希望足够具体):如何从 example.com 上的普通旧网页进行 XHR 调用,以从匿名 Google Apps Script ContentService 脚本中获取内容?
【问题讨论】:
....同样的问题....很有趣。 Google Apps Script cross-domain requests stopped working的可能重复 【参考方案1】:我不确定这目前是否可行。我们考虑了 JSONP 方法(确实有效;我已经对其进行了测试),但我认为针对 ContentService 的 XHR 从未经过测试。我们可能需要为此设置 CORS 标头。请在问题跟踪器上提交功能请求,我们会看看是否可以完成。
【讨论】:
在这里完成code.google.com/p/google-apps-script-issues/issues/…,我也会尝试 JSONP 脚本方法并在这里报告。 JSONP 脚本注入工作正常。谢谢。所以,我的事后分析是 JS 101:浏览器拒绝执行最终的 GET,因为 GAS 服务器需要(至少)添加一个 CORS 标头“Access-Control-Allow-Origin: somedomain | *”developer.mozilla.org/en/http_access_control . GAS 服务器不会发出这样的标头。在没有标头的情况下,浏览器端脚本受制于相同的源策略 (developer.mozilla.org/en/Same_origin_policy_for_javascript),因此 GET 的状态为“(已取消)”。 嗨@PeterHerrmann 一年多后我遇到了同样的问题——你找到解决方案了吗?谢谢,福斯托。 是的@FaustoR.,你需要让你的 ContentService 返回 JSONP 而不是 JSON。 this comment 上提到的问题被标记为无法修复。抄送@PeterHerrmann。以上是关于如何针对 Google Apps Script ContentService 发出 XHR/ajax 请求?的主要内容,如果未能解决你的问题,请参考以下文章
如何向 Google Apps Script Web App 发送有效的 HTTP 请求?
将身份验证从一个 Google Apps Script webapp 传递到另一个 Google Apps Script webapp
允许匿名访问 Google Apps Script Web 应用程序(Google Apps 帐户)
该脚本工作正常,但不在“google-apps-script”中