在 Python 中使用公共类处理接口请求的响应结果

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: 在 Python 中使用公共类处理接口请求的响应结果

引言


在现代软件开发中,API 接口请求和处理响应结果是非常常见的操作。无论是在与外部服务的集成、处理第三方数据,还是构建微服务架构的系统,开发人员通常都需要频繁处理 HTTP 请求以及对应的响应数据。在 Python 中,很多开发者使用 requests 库来发送 HTTP 请求。尽管 requests 是一个强大的库,但处理每个接口的响应时,编写重复的代码会显得低效且容易出错。


为了解决这个问题,可以使用公共类来统一处理接口请求的响应结果。通过定义一个公共类,封装请求的发送、响应的处理、以及错误处理逻辑,不仅可以减少代码的重复性,还能增强代码的可读性和可维护性。


本文将详细讲解如何在 Python 中使用公共类处理接口请求及其响应结果,并通过实例演示代码如何实现。


目录


1.为什么使用公共类处理接口请求响应?

2.需求分析

3.环境准备与依赖库安装

4.Python 实现流程

公共类设计

封装请求的发送与响应处理

错误处理与重试机制

5.代码实现

基础公共类

GET 请求处理

POST 请求处理

错误处理类

扩展公共类

6.完整示例代码

7.测试与优化

8.总结与展望


1. 为什么使用公共类处理接口请求响应?


1.1 减少重复代码

在项目开发过程中,如果每次发送 HTTP 请求都需要编写相似的代码来处理响应结果,不仅浪费时间,还容易引入错误。通过定义公共类,开发者可以复用已有的逻辑,并专注于具体的业务逻辑。


1.2 提高代码可读性和可维护性


使用公共类可以将复杂的逻辑抽象出来,隐藏内部实现细节,从而提升代码的可读性。对于团队开发来说,这也是一种规范代码风格的方法,使得后续的维护更加方便。


1.3 集中管理错误处理


API 请求通常会遇到各种错误(例如网络超时、HTTP 状态码错误等),每次处理这些错误显然是不现实的。通过公共类的封装,错误处理逻辑可以集中到一个地方,简化代码结构。


2. 需求分析


在实际项目中,我们需要处理各种类型的 HTTP 请求,包括 GET、POST、PUT、DELETE 等请求,并且需要对响应数据进行统一处理。每次请求可能会成功,也可能会失败。因此,公共类需要具备以下功能:

发送 HTTP 请求(GET、POST、PUT 等)

解析响应数据(例如 JSON 格式的响应)

处理常见的错误(如超时、500 错误、404 错误等)

实现重试机制,以应对短期的网络故障

灵活扩展,以支持未来可能的需求变化


3. 环境准备与依赖库安装


在开始编写代码之前,我们需要确保系统中安装了 requests 库。可以使用以下命令安装:

pip install requests


requests 是一个强大的 HTTP 请求库,支持发送 GET、POST、PUT、DELETE 等多种 HTTP 方法,同时还支持各种高级特性,如超时处理、SSL 验证、会话保持等。


4. Python 实现流程

4.1 公共类设计


在设计公共类时,我们需要定义一个类 ApiHandler,该类包含发送 HTTP 请求的公共方法。这个类应该能够处理不同的请求类型(如 GET 和 POST),并且需要对每个请求的响应结果进行解析和处理。


4.2 封装请求的发送与响应处理


请求发送逻辑可以封装在一个方法中,而响应的解析可以根据不同的内容类型来进行。例如,如果响应是 JSON 格式,我们可以直接调用 response.json() 方法进行解析。


4.3 错误处理与重试机制


为了提高系统的可靠性,当请求失败时,我们可以加入重试机制,自动尝试再次发送请求。同时,为了防止无限重试导致的死循环,我们可以设定重试的最大次数。此外,常见的错误如网络超时、404、500 错误等也需要进行统一处理。


5. 代码实现


5.1 基础公共类


首先,我们定义一个基础的 ApiHandler 类,它可以处理 HTTP GET 和 POST 请求,并对响应数据进行解析。

import requests
import logging

class ApiHandler:
    def __init__(self, base_url, timeout=10, max_retries=3):
        self.base_url = base_url
        self.timeout = timeout
        self.max_retries = max_retries
        self.logger = logging.getLogger(__name__)
        
    def send_request(self, method, endpoint, params=None, data=None, headers=None):
        url = f"{self.base_url}/{endpoint}"
        retries = 0
        
        while retries < self.max_retries:
            try:
                if method == 'GET':
                    response = requests.get(url, params=params, headers=headers, timeout=self.timeout)
                elif method == 'POST':
                    response = requests.post(url, json=data, headers=headers, timeout=self.timeout)
                else:
                
                    raise ValueError("Unsupported HTTP method")
                # 如果响应状态码不是 200,抛出异常
                if response.status_code != 200:
                    self.logger.error(f"Error: {response.status_code}, {response.text}")
                    
                    response.raise_for_status()
                return self.handle_response(response)
                
            except requests.exceptions.RequestException as e:
                self.logger.error(f"Request failed: {e}, retrying... ({retries}/{self.max_retries})")
                retries += 1
                
        self.logger.error("Max retries exceeded")
        return None
        
    def handle_response(self, response):
        try:
            # 尝试解析 JSON 格式的响应
            return response.json()
        except ValueError:
            self.logger.error("Failed to parse JSON response")
            return response.text


在这个 ApiHandler 类中,我们做了以下几件事情:

初始化:通过构造函数初始化基础 URL、超时参数以及最大重试次数。

发送请求:根据传入的 HTTP 方法(GET 或 POST),发送请求。

响应处理:尝试解析 JSON 格式的响应,并在失败时记录错误日志。

重试机制:在请求失败时,最多重试 max_retries 次。


5.2 GET 请求处理


在 ApiHandler 中,我们可以通过 send_request 方法发送 GET 请求。下面是一个示例,展示如何使用该类进行 GET 请求。

def get_data(api_handler, endpoint, params=None):
    response = api_handler.send_request('GET', endpoint, params=params)
    if response:
        print("GET Request Success:", response)
    else:
        print("GET Request Failed")


假设我们要从某个 API 端点获取数据,可以这样调用:

api_handler = ApiHandler(base_url="https://api.example.com")
get_data(api_handler, "data", params={"key": "value"})


5.3 POST 请求处理


类似地,我们可以使用 send_request 方法来发送 POST 请求。

def post_data(api_handler, endpoint, data):
    response = api_handler.send_request('POST', endpoint, data=data)
    if response:
        print("POST Request Success:", response)
    else:
        print("POST Request Failed")


示例代码展示了如何使用 POST 请求将数据发送到服务器:

api_handler = ApiHandler(base_url="https://api.example.com")
post_data(api_handler, "submit", data={"name": "John", "age": 30})


5.4 错误处理类


在实际应用中,除了记录错误日志之外,处理 HTTP 请求时,还需要处理特定的 HTTP 状态码。例如,404 错误意味着资源未找到,500 错误意味着服务器内部问题。我们可以定义一个公共的错误处理类。

class ApiErrorHandler:
    @staticmethod
    def handle_status_code(status_code):
        if status_code == 404:
            return "Error 404: Resource not found."
        elif status_code == 500:
            return "Error 500: Server internal error."
        else:
            return f"Unhandled error: {status_code}"


在 ApiHandler 中,我们可以在请求失败时调用 ApiErrorHandler 进行错误处理:

response = requests.get(url, params=params, headers=headers, timeout=self.timeout)
if response.status_code != 200:
    error_message = ApiErrorHandler.handle_status_code(response.status_code)
    self.logger.error(error_message)
    response.raise_for_status()


5.5 扩展公共类


为了提高 ApiHandler 的灵活性,我们可以进一步扩展这个公共类,使其支持更多的 HTTP 请求方法(如 PUT、DELETE),并支持更多的响应处理逻辑。

class ExtendedApiHandler(ApiHandler):
    def send_put_request(self, endpoint, data=None, headers=None):
        return self.send_request('PUT', endpoint, data=data, headers=headers)
        
    def send_delete_request(self, endpoint, headers=None):
        return self.send_request('DELETE', endpoint, headers=headers)


通过这样的扩展,我们的 ApiHandler 类可以支持更多种类的 HTTP 请求,同时保持了响应处理逻辑的一致性和代码结构的简洁性。


6. 完整示例代码


在本节中,我们将基于前文的设计和实现,提供一个完整的示例代码。这个例子将展示如何使用 ApiHandler 类处理接口请求,解析响应结果,并进行错误处理。


假设我们有一个 API 服务,提供以下两个接口:

1.GET /users:获取所有用户列表

2.POST /users:创建一个新的用户


6.1 公共类 ApiHandler 的实现

import requests
import logging

class ApiHandler:
    def __init__(self, base_url, timeout=10, max_retries=3):
        self.base_url = base_url
        self.timeout = timeout
        self.max_retries = max_retries
        self.logger = logging.getLogger(__name__)
        
    def send_request(self, method, endpoint, params=None, data=None, headers=None):
        url = f"{self.base_url}/{endpoint}"
        retries = 0
        
        while retries < self.max_retries:
            try:
                if method == 'GET':
                    response = requests.get(url, params=params, headers=headers, timeout=self.timeout)
                elif method == 'POST':
                    response = requests.post(url, json=data, headers=headers, timeout=self.timeout)
                else:
                
                    raise ValueError("Unsupported HTTP method")
                if response.status_code != 200:
                    self.logger.error(f"Error: {response.status_code}, {response.text}")
                    response.raise_for_status()
                    
                return self.handle_response(response)
                
            except requests.exceptions.RequestException as e:
                self.logger.error(f"Request failed: {e}, retrying... ({retries}/{self.max_retries})")
                retries += 1
                
        self.logger.error("Max retries exceeded")
        return None
        
    def handle_response(self, response):
        try:
            return response.json()
        except ValueError:
            self.logger.error("Failed to parse JSON response")
            return response.text


6.2 错误处理类 ApiErrorHandler

class ApiErrorHandler:
    @staticmethod
    def handle_status_code(status_code):
        if status_code == 404:
            return "Error 404: Resource not found."
        elif status_code == 500:
            return "Error 500: Server internal error."
        else:
            return f"Unhandled error: {status_code}"


6.3 使用 ApiHandler 进行 GET 请求

d

ef get_users(api_handler):
    response = api_handler.send_request('GET', 'users')
    if response:
        print("GET Request Success:", response)
    else:
        print("GET Request Failed")


6.4 使用 ApiHandler 进行 POST 请求

def create_user(api_handler, user_data):
    response = api_handler.send_request('POST', 'users', data=user_data)
    if response:
        print("POST Request Success:", response)
    else:
        print("POST Request Failed")


6.5 示例调用

if __name__ == "__main__":
    logging.basicConfig(level=logging.INFO)
    
    api_handler = ApiHandler(base_url="https://api.example.com")
    
    print("Fetching users list:")
    get_users(api_handler)
    
    new_user_data = {
        "name": "John Doe",
        "email": "john.doe@example.com",
        "age": 30
    }
    print("\nCreating new user:")
    create_user(api_handler, new_user_data)



7. 测试与优化


测试是开发过程中的重要环节。我们可以编写单元测试来验证 ApiHandler 的各个功能模块。使用 unittest 或 pytest 等测试框架,我们可以模拟 HTTP 请求,并测试不同的响应状态码、数据解析逻辑、错误处理等。


在优化方面,我们可以根据具体的项目需求,进一步优化 ApiHandler,例如:

添加缓存机制:对于某些接口,可以通过缓存机制减少重复请求。

多线程/异步支持:对于高并发场景,可以考虑使用 asyncio 或 threading 提升性能。


8. 总结与展望


通过详细的分析与代码示例,本文展示了如何在 Python 中使用公共类来处理接口请求的响应结果。我们设计了一个基础的 ApiHandler 类,封装了 GET 和 POST 请求的处理逻辑,并实现了错误处理和重试机制。通过这种方式,我们可以减少代码的重复,提高代码的可读性和可维护性。


进一步优化:

引入异步编程支持(如 asyncio),提升高并发处理能力。

添加更多的 HTTP 方法支持,如 PUT 和 DELETE。

通过更多的自定义错误处理机制进一步提高健壮性。


通过这种方式,ApiHandler 类可以成为一个功能强大、灵活易用的工具,在实际项目中发挥更大的作用。


目录
相关文章
|
5天前
|
数据采集 JSON API
深入解析:使用 Python 爬虫获取淘宝店铺所有商品接口
本文介绍如何使用Python结合淘宝开放平台API获取指定店铺所有商品数据。首先需注册淘宝开放平台账号、创建应用并获取API密钥,申请接口权限。接着,通过构建请求、生成签名、调用接口(如`taobao.items.search`和`taobao.item.get`)及处理响应,实现数据抓取。代码示例展示了分页处理和错误处理方法,并强调了调用频率限制、数据安全等注意事项。此技能对开发者和数据分析师极具价值。
|
2月前
|
API Python
【02】优雅草央央逆向技术篇之逆向接口协议篇-以小红书为例-python逆向小红书将用户名转换获得为uid-优雅草央千澈
【02】优雅草央央逆向技术篇之逆向接口协议篇-以小红书为例-python逆向小红书将用户名转换获得为uid-优雅草央千澈
128 1
|
9天前
|
JSON API 数据格式
Python 请求微店商品详情数据 API 接口
微店开放平台允许开发者通过API获取商品详情数据。使用Python请求微店商品详情API的主要步骤包括:1. 注册并申请API权限,获得app_key和app_secret;2. 确定API接口地址与请求参数,如商品ID;3. 生成签名确保请求安全合法;4. 使用requests库发送HTTP请求获取数据;5. 处理返回的JSON格式响应数据。开发时需严格遵循微店API文档要求。
|
5天前
|
存储 JSON API
Python测试淘宝店铺所有商品接口的详细指南
本文详细介绍如何使用Python测试淘宝店铺商品接口,涵盖环境搭建、API接入、签名生成、请求发送、数据解析与存储、异常处理等步骤。通过具体代码示例,帮助开发者轻松获取和分析淘宝店铺商品数据,适用于电商运营、市场分析等场景。遵守法规、注意调用频率限制及数据安全,确保应用的稳定性和合法性。
|
2月前
|
测试技术 Python
【03】做一个精美的打飞机小游戏,规划游戏项目目录-分门别类所有的资源-库-类-逻辑-打包为可玩的exe-练习python打包为可执行exe-优雅草卓伊凡-持续更新-分享源代码和游戏包供游玩-1.0.2版本
【03】做一个精美的打飞机小游戏,规划游戏项目目录-分门别类所有的资源-库-类-逻辑-打包为可玩的exe-练习python打包为可执行exe-优雅草卓伊凡-持续更新-分享源代码和游戏包供游玩-1.0.2版本
150 31
【03】做一个精美的打飞机小游戏,规划游戏项目目录-分门别类所有的资源-库-类-逻辑-打包为可玩的exe-练习python打包为可执行exe-优雅草卓伊凡-持续更新-分享源代码和游戏包供游玩-1.0.2版本
|
1月前
|
API 文件存储 数据安全/隐私保护
python 群晖nas接口(一)
这段代码展示了如何通过群晖NAS的API获取认证信息(SID)并列出指定文件夹下的所有文件。首先,`get_sid()`函数通过用户名和密码登录NAS,获取会话ID(SID)。接着,`list_file(filePath, sid)`函数使用该SID访问FileStation API,列出给定路径`filePath`下的所有文件。注意需替换`yourip`、`username`和`password`为实际值。
93 18
|
1月前
|
API Python
python泛微e9接口开发
通过POST请求向指定IP的API注册设备以获取`secrit`和`spk`。请求需包含`appid`、`loginid`、`pwd`等头信息。响应中包含状态码、消息及`secrit`(注意拼写)、`secret`和`spk`字段。示例代码使用`curl`命令发送请求,成功后返回相关信息。
45 5
|
1月前
|
API 文件存储 Python
python 群晖nas接口(二)
这段代码展示了如何通过API将文件上传到群晖NAS。它使用`requests`库发送POST请求,指定文件路径、创建父级目录及覆盖同名文件的参数,并打印上传结果。确保替换`yourip`和`sid`为实际值。
52 2
|
测试技术 Python
python接口自动化(五)--接口测试用例和接口测试报告模板(详解)
当今社会在测试领域,接口测试已经越来越多的被提及,被重视,而且现在好多招聘信息要对接口测试提出要求。区别于传统意义上的系统级别测试,很多测试人员在接触到接口测试的时候,也许对测试执行还可以比较顺利的上手,但一 提到相关的文档,比如测试用例和报告,就有些不知所措了。这类问题在我加入的几个测试的群里,经常看到一些人在不断提问。   今天就用这篇文章来说说接口测试用例和报告。
486 2
python接口自动化(五)--接口测试用例和接口测试报告模板(详解)

热门文章

最新文章