使用gdata对托管域的Google数据API进行OAuth身份验证失败

时间:2010-07-03 04:33:24

标签: python django google-docs-api gdata-python-client

我正在创建一个django应用,为用户创建日历和google docs文件夹,并使用API​​插入事件和添加文档。几个月前,它运作得很好;现在我正在对我的代码进行重大的重构,并且在测试上述组件时,我发现它们不再起作用了!当我尝试创建文件夹或日历时,我从API获得此响应:

RequestError: {'status': 401, 'body': '<HTML>\n<HEAD>\n<TITLE>Unknown authorization header</TITLE>\n</HEAD>\n<BODY BGCOLOR="#FFFFFF" TEXT="#000000">\n<H1>Unknown authorization header</H1>\n<H2>Error 401</H2>\n</BODY>\n</HTML>\n', 'reason': 'Unknown authorization header'}

我的代码看起来像这样 - 基于谷歌文档中的this example - (文档代码较短,所以我会粘贴那个,尽管身份验证位实际上是两者共有的功能):< / p>

from gdata.auth import OAuthSignatureMethod, OAuthToken, OAuthInputParams
from gdata.calendar.service import CalendarService
from django.conf import settings
client_instance = CalendarService()
client_instance.SetOAuthInputParameters(OAuthSignatureMethod.HMAC_SHA1,
                                settings.OAUTH_CONSUMER_KEY,
                                consumer_secret=settings.OAUTH_CONSUMER_SECRET)
user_tokens = UserToken.objects.get(user=user)
if not user_tokens.oauth_access_token_value or not user_tokens.oauth_valid_token:
    raise Exception('The user has not allowed us to access his services')      
oauth_token=OAuthToken(key=user_tokens.oauth_access_token_value,    secret=user_tokens.oauth_access_token_secret)
oauth_token.oauth_input_params = OAuthInputParams(OAuthSignatureMethod.HMAC_SHA1,
                         settings.OAUTH_CONSUMER_KEY,
                        consumer_secret=settings.OAUTH_CONSUMER_SECRET)
client_instance.SetOAuthToken(oauth_token)
new_folder = docs_service.CreateFolder("some folder")

异常来自最后一行,API中有什么变化,或者仅仅是我? (我打赌这只是我,但我几个月前就看不到它了)

1 个答案:

答案 0 :(得分:0)

原因在于json回复:'reason': 'Unknown authorization header'

一个可能的原因是您机器的当地时间。确保本地计算机上的时间正确,因为oauth使用当前的unix时间戳来签名和验证请求。 Google support forum

这是记录的错误列表。第一个看起来很适合你的情况:

希望这会有所帮助:)