gpt4 book ai didi

javascript - 是否可以在 Javascript 中进行跨域请求并设置自定义 header ?

转载 作者:数据小太阳 更新时间:2023-10-29 06:03:51 24 4
gpt4 key购买 nike

Since you can't apply custom headers on JSONP calls ,如何使用 jQuery 发出跨域请求并应用自定义 header ?

我基本上是在尝试使用 jQuery 访问 google 文档,并且需要传递身份验证 token :

var token = "my-auth-token";
$.ajax({
url: "http://docs.google.com/feeds/documents/private/full?max-results=1&alt=json",
dataType: 'json',
beforeSend: function(xhr) {
xhr.setRequestHeader("Authorization", "GoogleLogin auth=" + token);
},
success: function(data, textStatus, XMLHttpRequest) {
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
}
});

注意:这样做的目的是完全绕过应用层。使用 ruby​​ 连接到 Google Data API 很简单,但是它一直占用大量资源来解析服务器端的提要。

最佳答案

您可以使用 Google 的 JavaScript 客户端库来查询 Docs API。虽然它没有专门为 Docs 提供帮助程序,但它仍然可以与大多数 API 一起使用,包括 Docs。看这个blog post由谷歌员工展示了一个工作示例。

如果您最终陷入授权的无限循环,请参阅此 related question来自谷歌群组。基本上,cookie 的设置速度不够快,因此当 JavaScript 客户端库检查时,它什么也没找到并重定向到 OAuth 授权页面。一种解决方案是在检查完成之前添加一个小的延迟,或者使用启动授权的登录按钮而不是在页面加载时执行。

您还需要将任何图像添加到驻留在同一域中的页面。它可以用 CSS 隐藏,只要在 DOM 中。

使用上面博客文章中的示例,我能够单独使用 JavaScript 检索我的文档列表。这是我用来摆脱无限授权循环的修改后的初始化函数:

function initialize() {
var scope = 'http://docs.google.com/feeds/';

if (google.accounts.user.checkLogin(scope)) {
var service = new google.gdata.client.GoogleService('writely', 'DocList-App-v1.0');
service.getFeed(scope + 'documents/private/full/', handleFeed, handleError);
} else {
var loginButton = $("<button>Click here to login</button>");
loginButton.click(function() {
var token = google.accounts.user.login(scope); // can ignore returned token
});
$("body").append(loginButton);
}
};

关于javascript - 是否可以在 Javascript 中进行跨域请求并设置自定义 header ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3073336/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com