当涉及到进行网络请求和处理HTTP相关任务时,Python的urllib3
库是一个强大且灵活的选择。它提供了一种简单的方式来执行HTTP请求、处理响应和处理连接池,使得与Web服务进行交互变得更加容易。本文将详细介绍如何使用urllib3
库进行网络请求。
首先我们需要安装urllib3
库,我们可以直接使用pip
命令进行安装,安装命令如下:
pip install urllib3
下面是一个使用urllib3
库发起简单的GET请求的例子:
import urllib3
# 创建一个连接池管理器
http = urllib3.PoolManager()
# 发起 GET 请求
url = "https://www.baidu.com"
response = http.request('GET', url)
# 打印响应内容
print(response.data)
--------------------
响应内容如下:
b'\r\n\r\n\t\r\n\r\n\r\n\t\r\n\r\n'
在这个例子中,我们首先导入了urllib3
库,然后创建了一个连接池管理器http
。接着,我们使用request
方法发起了一个GET请求,并指定了请求的URL。最后,我们打印了响应的内容。
如果需要在GET请求中传递查询参数,可以使用fields
参数来实现:
import urllib3
http = urllib3.PoolManager()
params = {
'name': 'theshy',
'team': 'wbg'
}
url = "https://www.baidu.com"
response = http.request('GET', url, fields=params)
print(response.data)
下面是一个使用urllib3
库发起POST请求的例子:
import urllib3
http = urllib3.PoolManager()
data = {
'name': 'theshy',
'team': 'wbg'
}
url = "https://www.baidu.com"
response = http.request('POST', url, fields=data)
print(response.data)
在这个例子中,我们使用request
方法发起了一个POST请求,并通过fields
参数传递了POST请求的数据。
urllib3
的响应对象提供了许多有用的属性和方法来处理响应数据,例如:
import urllib3
http = urllib3.PoolManager()
url = "https://www.baidu.com"
response = http.request('GET', url)
print("Status code:", response.status)
print("Headers:", response.headers)
print("Data:", response.data)
-----------------
输出内容如下:
Status code: 200
Headers: HTTPHeaderDict({'Accept-Ranges': 'bytes', 'Cache-Control': 'no-cache', 'Connection': 'keep-alive', 'Content-Length': '227', 'Content-Security-Policy': "frame-ancestors 'self' https://chat.baidu.com http://mirror-chat.baidu.com https://fj-chat.baidu.com https://hba-chat.baidu.com https://hbe-chat.baidu.com https://njjs-chat.baidu.com https://nj-chat.baidu.com https://hna-chat.baidu.com https://hnb-chat.baidu.com http://debug.baidu-int.com;", 'Content-Type': 'text/html', 'Date': 'Wed, 09 Aug 2023 08:20:31 GMT', 'P3p': 'CP=" OTI DSP COR IVA OUR IND COM ", CP=" OTI DSP COR IVA OUR IND COM "', 'Pragma': 'no-cache', 'Server': 'BWS/1.1', 'Set-Cookie': 'BD_NOT_HTTPS=1; path=/; Max-Age=300, BIDUPSID=67ECF8FD208F495FB1FC93888A3580FB; expires=Thu, 31-Dec-37 23:55:55 GMT; max-age=2147483647; path=/; domain=.baidu.com, PSTM=1691569231; expires=Thu, 31-Dec-37 23:55:55 GMT; max-age=2147483647; path=/; domain=.baidu.com, BAIDUID=67ECF8FD208F495F18B77C28BD39D136:FG=1; max-age=31536000; expires=Thu, 08-Aug-24 08:20:31 GMT; domain=.baidu.com; path=/; version=1; comment=bd', 'Strict-Transport-Security': 'max-age=0', 'Traceid': '1691569231141853722613530868379522833862', 'X-Ua-Compatible': 'IE=Edge,chrome=1'})
Data: b'\r\n\r\n\t\r\n\r\n\r\n\t\r\n\r\n'
连接池可以提高性能,避免频繁地建立和关闭连接。urllib3
库默认使用连接池,你可以直接使用PoolManager
来管理连接池:
import urllib3
http = urllib3.PoolManager()
url = "https://www.baidu.com"
response = http.request('GET', url)
print(response.data)
urllib3
库为Python开发者提供了一个强大的工具,用于进行各种类型的HTTP请求、处理响应以及管理连接池。本文介绍了如何使用urllib3
库来发起基本的GET和POST请求,处理响应以及处理网络请求错误。
最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:
这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!