对于python-cod,C2DM始终指示“未经授权”

2024-07-04 07:49:45 发布

您现在位置:Python中文网/ 问答频道 /正文

我尝试使用python编写app服务器端的代码来向设备发送消息。我想我可以成功地获得授权令牌,但是当我使用它发送消息时,它总是显示“HTTP Error 401:Unauthorized”。我的代码在这里:

import urllib, urllib2

class ClientLoginTokenFactory:
_token = None

def __init__(self):
    self.url = 'https://www.google.com/accounts/ClientLogin'
    self.accountType = 'HOSTED_OR_GOOOGLE'
    self.email = 'xxxx@gmail.com'
    self.pwd = 'xxxxx'
    self.service = 'ac2dm'
    self.source = 'com.lei.c2dmtest'

def getToken(self):
    if self._token is None:
        values = {'accountType':self.accountType,'Email':self.email,'Passwd':self.pwd,'source':self.source,'service':self.service}
        data = urllib.urlencode(values)
        request = urllib2.Request(self.url,data)
        response =  urllib2.urlopen(request)
        responseAsString = response.read()
        #print responseAsString
        responseAsList = responseAsString.split('\n')
        self._token = responseAsList[2].split('=')[1]
        print self._token

    return self._token

class C2DM:
def __init__(self):
    self.url = 'https://android.apis.google.com/c2dm/send'
    self.clientAuth = None
    self.registrationId = None  
    self.collapseKey = None
    self.data = {}

def sendMessage(self):
    if self.registrationId == None or self.collapseKey == None:
        return False
    clientAuthFactory = ClientLoginTokenFactory()
    self.clientAuth = clientAuthFactory.getToken()
    print self.clientAuth
    values = {'registration_id': self.registrationId, 'collapse_key': self.collapseKey, 'data.msg': 'Hello!!!'}
    #print values
    headers = {'Authorization': 'GoolgeLogin auth=' + self.clientAuth}
    #print headers
    data = urllib.urlencode(values)
    request = urllib2.Request(self.url, data, headers)

    try:
        response = urllib2.urlopen(request)
        responseAsString = response.read()
        return "AAA"
        return responseAsString
    except urllib2.HTTPError, e:
        print 'HTTPError ' + str(e)

sender = C2DM()
sender.registrationId = 'APA91bGZaTpEgJ9a4tOgFTisedsJCOBFvsdwSkKqfzY97QyOiDlzvlZJv6cP1xDENw6DJM3sYTLslGGke0yAMTH9Ep0eeDmfVLUuM2bkFfwKWGyLG4HQDHR1zxw5TN1hoagi5FLWXYKmEQAvX6Qw-rIiwg03UBrvXA'
sender.collapseKey = 3
response = sender.sendMessage()

registrationId也是正确的,我使用java代码测试并证明了它是有效的。但当我把它转换成python时,它总是表示“未经授权”

有人知道吗?在

谢谢!在


Tags: selfcomtokennoneurldatareturnresponse

热门问题