gpt4 book ai didi

python - urllib2 - 发布请求

转载 作者:太空狗 更新时间:2023-10-29 17:30:27 25 4
gpt4 key购买 nike

我尝试使用 urllib2 执行一个简单的 POST 请求。然而,服务器响应表明它收到了一个简单的 GET。我检查了传出请求的类型,但它被设置为 POST。
为了检查服务器的行为是否像我期望的那样,我尝试使用连接到 url 的(以前的 POST-)数据执行 GET 请求。这给了我预期的答案。
有人知道我误解了什么吗?

def connect(self):
url = 'http://www.mitfahrgelegenheit.de/mitfahrzentrale/Dresden/Potsdam.html/'
user_agent = 'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT)'
header = { 'User-Agent' : user_agent }

values = {
'city_from' : 69,
'radius_from' : 0,
'city_to' : 263,
'radius_to' : 0,
'date' : 'date',
'day' : 5,
'month' : 03,
'year' : 2012,
'tolerance' : 0
}

data = urllib.urlencode(values)
# req = urllib2.Request(url+data, None, header) # GET works fine
req = urllib2.Request(url, data, header) # POST request doesn't not work

self.response = urllib2.urlopen(req)

这似乎是一个类似于此处讨论的问题:Python URLLib / URLLib2 POST但我很确定在我的例子中尾部斜杠没有丢失。 ;)

我担心这可能是一个愚蠢的误解,但我已经想了好几个小时了!



编辑:打印的便捷功能:

def response_to_str(response):
return response.read()

def dump_response_to_file(response):
f = open('dump.html','w')
f.write(response_to_str(response))



编辑 2:分辨率:

我找到了一个工具来捕捉与网站的真实互动,http://fiddler2.com/fiddler2/ .显然,服务器从输入表单中获取数据,重定向几次,然后发出 GET 请求,并将这些数据简单地附加到 url。
urllib2 一切正常,我为误用您的时间而道歉!

最佳答案

需要检查的事项:

  • 您确定您发帖的网址正确吗?
  • 您确定可以在不登录的情况下检索结果吗?
  • 向我们展示一些不同帖子值的示例输出。

您可以使用 Firefox 的 Firebug 找到正确的帖子 URL或谷歌浏览器 DevTools .

我为您提供了一些支持 cookie 的代码,以便您可以先登录并使用 cookie 发出带有您的 post 参数的后续请求。

最后,如果您能向我们展示一些示例 HTML 输出,那将使生活更轻松。

这是我的代码,到目前为止,它对我来说非常可靠地用于发布到大多数网页,包括受 CSRF/XSRF 保护的页面。 (只要您能够正确地确定要发布的什么以及要发布到何处(哪个 URL))。

import cookielib
import socket
import urllib
import urllib2

url = 'http://www.mitfahrgelegenheit.de/mitfahrzentrale/Dresden/Potsdam.html/'
http_header = {
"User-Agent" : "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/535.11 (KHTML, like Gecko) Chrome/17.0.963.46 Safari/535.11",
"Accept" : "text/xml,application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=0.8,text/png,*/*;q=0.5",
"Accept-Language" : "en-us,en;q=0.5",
"Accept-Charset" : "ISO-8859-1",
"Content-type": "application/x-www-form-urlencoded",
"Host" : "www.mitfahrgelegenheit.de",
"Referer" : "http://www.mitfahrgelegenheit.de/mitfahrzentrale/Dresden/Potsdam.html/"
}

params = {
'city_from' : 169,
'radius_from' : 0,
'city_to' : 263,
'radius_to' : 0,
'date' : 'date',
'day' : 5,
'month' : 03,
'year' : 2012,
'tolerance' : 0
}

# setup socket connection timeout
timeout = 15
socket.setdefaulttimeout(timeout)

# setup cookie handler
cookie_jar = cookielib.LWPCookieJar()
cookie = urllib2.HTTPCookieProcessor(cookie_jar)

# setup proxy handler, in case some-day you need to use a proxy server
proxy = {} # example: {"http" : "www.blah.com:8080"}

# create an urllib2 opener()
#opener = urllib2.build_opener(proxy, cookie) # with proxy
opener = urllib2.build_opener(cookie) # we are not going to use proxy now

# create your HTTP request
req = urllib2.Request(url, urllib.urlencode(params), http_header)

# submit your request
res = opener.open(req)
html = res.read()

# save retrieved HTML to file
open("tmp.html", "w").write(html)
print html

关于python - urllib2 - 发布请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9541677/

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