Python3 中使用requests访问某403网站并不会抛出错误

我在 Python3 中使用requests访问 http://httpstat.us/403 不会抛出错误, 但是通过打印状态码显示访问的情况是403, 但貌似状态并没有被捕获.

此外我尝试过使用urllib 模块访问该站点发现python正常抛出了HTTPError错误, 让我对requests的问题百思不得其解...我也尝试过卸掉requests模块重装, 但是问题依然存在.

使用的系统和软件是mac OS 10.13.1, sublime text3.

更多信息如图所示.

使用requests的情况
使用urllib的情况

回答:

import requests

try:

response = requests.get(url, headers=headers, timeout=30)

response.raise_for_status()

except requests.exceptions.HTTPError:

print("http error~")

print(response.status_code)

except:

print("other error~")

else:

print("good~")

回答:

你也看到了requests的结果是response success而不是http success,只要有响应这个请求都是成功的,只有请求一个不存在的网址或者网络错误才会响应失败。举个例子是一个是卖鸡蛋没买回来,一个是卖了坏的鸡蛋回来

以上是 Python3 中使用requests访问某403网站并不会抛出错误 的全部内容, 来源链接: utcz.com/a/161614.html

回到顶部