Ich versuche, eine HTML-Seite zu öffnen und zu analysieren. In Python 2.7.8 habe ich kein Problem:Python 3.4 urllib.request Fehler (http 403)
import urllib
url = "https://ipdb.at/ip/66.196.116.112"
html = urllib.urlopen(url).read()
und alles ist in Ordnung. Ich möchte jedoch zu Python 3.4 wechseln und dort bekomme ich den HTTP-Fehler 403 (Forbidden). Mein Code:
import urllib.request
html = urllib.request.urlopen(url) # same URL as before
File "C:\Python34\lib\urllib\request.py", line 153, in urlopen
return opener.open(url, data, timeout)
File "C:\Python34\lib\urllib\request.py", line 461, in open
response = meth(req, response)
File "C:\Python34\lib\urllib\request.py", line 574, in http_response
'http', request, response, code, msg, hdrs)
File "C:\Python34\lib\urllib\request.py", line 499, in error
return self._call_chain(*args)
File "C:\Python34\lib\urllib\request.py", line 433, in _call_chain
result = func(*args)
File "C:\Python34\lib\urllib\request.py", line 582, in http_error_default
raise HTTPError(req.full_url, code, msg, hdrs, fp)
urllib.error.HTTPError: HTTP Error 403: Forbidden
Es funktioniert für andere URLs, die https nicht verwenden.
url = 'http://www.stopforumspam.com/ipcheck/212.91.188.166'
ist in Ordnung.
Siehe auch https://stackoverflow.com/questions/3336549/pythons-urllib2-why-do-i-get-error -403-when-i-urlopen-a-wikipedia-page – Trilarion