Appengine urlfetch调试

Mar*_*tin 0 python debugging google-app-engine

我正在尝试使用google appengine做一个相当简单的url fetch.然而,它一直在失败.

result = urlfetch.fetch(url=apiurl, method=urlfetch.POST)
Run Code Online (Sandbox Code Playgroud)

我也尝试过使用httplib:

conn = httplib.HTTPConnection("api.eve-online.com")
conn.request("POST", "/char/CharacterSheet.xml.aspx", params, headers)

response = conn.getresponse()
self.response.out.write(response.read())
Run Code Online (Sandbox Code Playgroud)

这两个都返回非常相似的错误,

Traceback (most recent call last):
  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\ext\webapp\__init__.py", line 515, in __call__
    handler.get(*groups)
  File "C:\Users\Martin\Documents\google_appengine\martindevans\eveapi.py", line 24, in get
    method=urlfetch.POST)
  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\api\urlfetch.py", line 241, in fetch
    return rpc.get_result()
  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\api\apiproxy_stub_map.py", line 530, in get_result
    return self.__get_result_hook(self)
  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\api\urlfetch.py", line 315, in _get_fetch_result
    rpc.check_success()
  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\api\apiproxy_stub_map.py", line 502, in check_success
    self.__rpc.CheckSuccess()
  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\api\apiproxy_rpc.py", line 149, in _WaitImpl
    self.request, self.response)
  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\api\apiproxy_stub.py", line 80, in MakeSyncCall
    method(request, response)
  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\api\urlfetch_stub.py", line 133, in _Dynamic_Fetch
    deadline=deadline)
  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\api\urlfetch_stub.py", line 223, in _RetrieveURL
    connection.request(method, full_path, payload, adjusted_headers)
  File "C:\Python27\lib\httplib.py", line 946, in request
    self._send_request(method, url, body, headers)
  File "C:\Python27\lib\httplib.py", line 986, in _send_request
    self.putheader(hdr, value)
  File "C:\Python27\lib\httplib.py", line 924, in putheader
    str = '%s: %s' % (header, '\r\n\t'.join(values))
TypeError: sequence item 0: expected string, int found
Run Code Online (Sandbox Code Playgroud)

我不知道这里发生了什么.我没有为urlfetch方法提供任何序列,所以我不确定从哪里开始调试它.

编辑:根据要求,这里是标题:

headers = { "Content-type": "application/x-www-form-urlencoded" }
Run Code Online (Sandbox Code Playgroud)

这可能不是问题,因为第一种方法甚至没有设置任何标题!

J-1*_*DiZ 5

你在使用Python 2.7吗?它仅支持2.5.2.虽然2.6大部分都有效,但2.7则没有.