python - 为什么这个 url 使用 httplib2 和 urllib2 引发 BadStatusLine?

标签 python urllib2 httplib2

使用 httplib2 和 urllib2,我试图从这个 url 获取页面,但所有这些都没有成功,并以这个异常结束。

content = conn.request(uri="http://www.zdnet.co.kr/news/news_print.asp?artice_id=20110727092902")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/lib/python2.7/dist-packages/httplib2/__init__.py", line 1129, in request
    (response, content) = self._request(conn, authority, uri, request_uri, method, body, headers, redirections, cachekey)
  File "/usr/lib/python2.7/dist-packages/httplib2/__init__.py", line 901, in _request
    (response, content) = self._conn_request(conn, request_uri, method, body, headers)
  File "/usr/lib/python2.7/dist-packages/httplib2/__init__.py", line 871, in _conn_request
    response = conn.getresponse()
  File "/usr/lib/python2.7/httplib.py", line 1027, in getresponse
    response.begin()
  File "/usr/lib/python2.7/httplib.py", line 407, in begin
    version, status, reason = self._read_status()
  File "/usr/lib/python2.7/httplib.py", line 371, in _read_status
    raise BadStatusLine(line)

HTTP header 是这样的

http://www.zdnet.co.kr/news/news_print.asp?artice_id=20110727092902

GET /news/news_print.asp?artice_id=20110727092902 HTTP/1.1
Host: www.zdnet.co.kr
User-Agent: Mozilla/5.0 (Windows NT 5.1; rv:10.0.1) Gecko/20100101 Firefox/10.0.1
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: ko-kr,ko;q=0.8,en-us;q=0.5,en;q=0.3
Accept-Encoding: gzip, deflate
Connection: keep-alive
Cookie: RMID=7d83495d4f336fe0; __utma=37206251.1552605885.1328771258.1328771258.1329070845.2; __utmz=37206251.1328771258.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none); ASPSESSIONIDCSQCQTDD=BCLEHPPDEPHEBJDLCFNDMKDN; __utmc=37206251; ASPSESSIONIDSSQCQQCB=MJPLMOJAFPDFCLONCANBIKHN; _EXEN=2
X-FireLogger: 1.2

HTTP/1.1 200 OK
Date: Mon, 13 Feb 2012 18:02:56 GMT
Content-Length: 19158
Content-Type: text/html;charset=UTF-8; Charset=UTF-8
Set-Cookie: ASPSESSIONIDSQSDQRDB=NGAIFHKAGDIOGEMANAOLLKKF; path=/
Cache-Control: private

有什么线索吗?

最佳答案

这对我来说很好:

import urllib2

opener = urllib2.build_opener()

headers = {
  'User-Agent': 'Mozilla/5.0 (Windows NT 5.1; rv:10.0.1) Gecko/20100101 Firefox/10.0.1',
}

opener.addheaders = headers.items()
response = opener.open("http://www.zdnet.co.kr/news/news_print.asp?artice_id=20110727092902")

print response.headers
print response.read()

网站会丢弃所有没有 User-Agent 字符串的请求。

关于python - 为什么这个 url 使用 httplib2 和 urllib2 引发 BadStatusLine?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9265616/

相关文章:

python - 从列表中创建所有可能的组合

python - 无法使用 python 从 html 内容获取链接

python - 使用 urllib2 和 cookielib 在两个 opener 之间共享 cookie

python - 仅在某些文件中为 "Import error no module named httplib2"

python - 如何获取行的 nr 直到下一个值

python - 使用 Qt Designer 表单和 PyQt5 在 QWidget 中绘制 matplotlib 图

python - random.random() 在 for 循环中产生相同的结果

python - urllib2、Google App Engine 和 unicode 问题

Python httplib2 属性错误 : 'builtin_function_or_method' object has no attribute 'new'

python - httplib2 中的 SSL 版本 - EOF 发生在违反协议(protocol)的情况下