Python网络请求分HTTP封装(如requests)和底层Socket两种路径:前者简洁高效,适合常规API调用;后者可控性强,适用于定制协议、TCP长连接等场景。
Python做网络请求,核心就两条路:走HTTP协议用高层封装(比如requests),或者直接操作Socket走底层通信。选哪条,取决于你想要多大控制权、是否需要自定义协议、对性能有没有特殊要求。
HTTP是应用层协议,Python里最常用的是requests库——它把连接管理、编码处理、Cookie维护、重定向、SSL验证等都封装好了,一行代码就能发GET,三行就能带参数和头发POST。
pip install requests
requests.get("https://httpbin.org/get"),返回Response对象,.text取响应体,.json()自动解析JSONrequests.get("https://httpbin.org/get", params={"key": "value"}),自动拼成URL查询字符串requests.post("https://httpbin.org/post", data={"name": "Alice"});传JSON则用json=...参数,自动设Content-TypeSocket是操作系统提供的网络通信接口,Python通过socket标准库暴露了底层能力。它不关心HTTP,只负责收发原始字节流——这意味着你可以实现自己的协议、调试网络问题、写TCP长连接服务,或者和非HTTP设备(如嵌入式模块)通信。
import socket
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect(("httpbin.org", 80))
s.send(b"GET /get HTTP/1.1\\r\\nHost: httpbin.org\\r\\n\\r\\n")
data = s.recv(4096)
s.close()
\\r\\n;需自己解析响应状态码和分块传输;没有自动重连或超时保护socket.SOCK_DGRAM,适合日志上报、DNS查询等容忍丢包的场景HTTP库帮你扛了协议细节、错误恢复、安全策略;Socket让你掌控每一段字节的来去。它们不是替代关系,而是协作关系——requests底层其实也用socket,只是替你屏蔽了复杂性。
立即学习“Python免费学习笔记(深入)”;
requests或httpx
socket
ssl模块包装socket实际开发中,很多问题不出在逻辑,而出在细节处理:
response.content是bytes,response.text是str——如果没指定response.encoding,requests会按HTTP头或HTML meta推测编码,可能出错;中文网站建议显式设r.encoding = "utf-8"
s.settimeout(5)设超时,再配合try/except捕获socket.timeout或ConnectionRefusedError
verify=True(或配好CA路径)httpx.AsyncClient或aiohttp