0

我创建了一个类,它授权 vb.net 应用程序使用 Oauth2 访问 Google Fusion Tables。如果需要,它会以某种形式打开 Web 浏览器,加密并存储刷新令牌,并且运行良好。我可以访问融合表数据。

但是,我也想访问联系人。我已请求用户访问联系人。

我可以检索适用于融合表的 AccessToken,并尝试了不同的技术来处理联系人,但没有运气。我不断收到 401 未经授权的错误。但是如果我使用客户端登录,我可以让联系人工作。

任何帮助将非常感激。

我最近的尝试:

Dim rs As New RequestSettings("App Name", p.AccessToken) 'String retrieved from class
Dim cr As New ContactsRequest(rs)
Dim q As New FeedQuery
q.Uri = New Uri("http://www.google.com/m8/feeds/contacts/<EMAIL>/full/<IDCODE>")
Dim c As New Contact
c = cr.Retrieve(Of Contact)(q)
4

2 回答 2

0

您必须请求访问 Contacts API OAuth 范围,即https://www.google.com/m8/feeds/.

.NET 客户端库包含一个使用联系人 API 的 OAuth 2.0 示例:

https://code.google.com/p/google-gdata/source/browse/trunk/clients/cs/samples/oauth2_sample/oauth2demo.cs

于 2012-09-22T12:12:33.610 回答
0

感谢 Claudio Cherubino 的建议。我实际上已经在使用那个范围了。谢天谢地,我现在终于找到了答案。

我真的错过了一个字母:

q.Uri = New Uri("http://www.google.com/m8/feeds/contacts/<EMAIL>/full/<IDCODE>")

...是错误的,因为我要求的范围确实是:

https://www.google.com/m8/feeds/

所以 Uri 需要与 httpS 匹配。我添加了's'并且它有效。正确代码如下:

q.Uri = New Uri("https://www.google.com/m8/feeds/contacts/<EMAIL>/full/<IDCODE>")

非常感谢这篇文章的回答: http ://www.geoffmcqueen.com/2010/03/14/token-invalid-authsub-token-has-wrong-scope-oauth-google-problem

于 2012-09-23T19:46:38.873 回答