Python发送digest认证的请求:requests.auth.HTTPDigestAuth/httpx.DigestAuth

近日在做摄像头接口的调试,需要用到Digest认证,经过试验,代码如下:

一、同步版(pip install requests)

python 复制代码
import requests
from requests.auth import HTTPDigestAuth

host = 'https://192.168.0.2'
path = '/api/xxx'
path2 = '/another/api'

AUTH = ('username', 'password')
r = requests.get(host+path, verify=False, auth=HTTPDigestAuth(*AUTH))
print(r.status_code)
print(r.text)

payload = {'a': 1}
r2 = requests.put(host+path2, verify=False, auth=HTTPDigestAuth(*AUTH), json=payload)
print(r2.status_code)
print(r2.json())

二、异步协程版(pip install httpx)

python 复制代码
import asyncio
from httpx import AsyncClient, DigestAuth

host = 'https://192.168.0.2'
path = '/api/xxx'
path2 = '/another/api'

AUTH = ('username', 'password')


async def main():
    async with AsyncClient(base_url=host, verify=False, auth=DigestAuth(*AUTH)):
        r = await client.get(path)
        payload = {'a': 1}
        r2 = await client.put(path2, json=payload)
    print(r.status_code)
    print(r.text)

    print(r2.status_code)
    print(r2.json())


if __name__ == '__main__':
    asyncio.run(main())

封装成工具类之后的代码如下

python 复制代码
import os

import requests
from httpx import AsyncClient, DigestAuth

AUTH = (os.environ["API_USER"], os.environ["API_PASS"])


class HttpClient:
    PATH_GET = "/get-sth"
    PATH_PUT = "/put"

    @staticmethod
    def sync_request(method: str, host: str, path: str, **kw) -> requests.Response:
        url = host.rstrip("/") + path
        return requests.request(
            method, url, verify=False, auth=requests.auth.HTTPDigestAuth(*AUTH), **kw
        )

    @classmethod
    def sync_get(cls, host: str, params=None, path: str | None = None) -> dict:
        if path is None:
            path = cls.PATH_GET
        r = cls.sync_request("GET", host, path, params=params)
        r.raise_for_status()
        return r.json()

    @classmethod
    def sync_put(cls, payload: dict, host: str, path: str | None = None) -> dict:
        if path is None:
            path = cls.PATH_PUT
        r = cls.sync_request("PUT", host, path, json=payload)
        r.raise_for_status()
        return r.json()

    @staticmethod
    def async_client(host: str) -> AsyncClient:
        return AsyncClient(base_url=host, verify=False, auth=DigestAuth(*AUTH))

    @classmethod
    async def get(cls, host: str, params=None, path: str | None = None) -> dict:
        async with cls.async_client(host) as client:
            r = await client.get(path or cls.PATH_GET, params=params)
            return r.json()

    @classmethod
    async def put(cls, payload: dict, host: str, path: str | None = None) -> dict:
        async with cls.async_client(host) as client:
            r = await client.put(path or cls.PATH_PUT, json=payload)
            return r.json()
相关推荐
ζั͡山 ั͡有扶苏 ั͡✾3 小时前
从零搭建 Data-Juicer:一站式大模型数据预处理与可视化平台完整教程
python·data-juicer
SkylerHu3 小时前
tornado+gunicorn部署设置max_body_size
python·tornado·gunicorn
独行soc4 小时前
2025年渗透测试面试题总结-234(题目+回答)
网络·python·安全·web安全·渗透测试·1024程序员节·安全狮
木头左4 小时前
年化波动率匹配原则在ETF网格区间选择中的应用
python
清空mega4 小时前
从零开始搭建 flask 博客实验(3)
后端·python·flask
程序员小远5 小时前
7个常见的Jmeter压测问题
自动化测试·软件测试·python·测试工具·测试用例·压力测试·性能测试
红尘炼丹客5 小时前
《DeepSeek-OCR: Contexts Optical Compression》速览
人工智能·python·自然语言处理·ocr
☼←安于亥时→❦5 小时前
Playwright 安装与使用
python·playwright
大佬,救命!!!5 小时前
python实现象棋
开发语言·python·学习笔记·pygame·少儿编程·记录成长
棉猴5 小时前
《pygame中Sprite类实现多帧动画》注-通过多张序列帧显示动画2-2
开发语言·python·游戏·游戏程序·pygame