数据模拟接口

news2024/11/16 19:41:11

因项目需要,使用FastAPI框架编写了一个简单的HTTP API服务,用于生成短信发送记录和短信回复记录。

  • is_valid_phone_numbers函数用于验证手机号码列表的格式是否正确。
  • current_time_str函数返回当前时间的字符串表示,可选参数format用于指定时间格式。
  • PhoneBaseModel是所有手机相关模型的基类,定义了mobile字段,并在validator中验证该字段是否由数字组成。
  • SendRecord和DeliverRecord分别表示短信发送记录和短信回复记录的模型类,继承自PhoneBaseModel,定义了各自的字段。
  • get_send_records和get_deliver_records是两个API接口的实现,分别用于生成短信发送记录和短信回复记录。它们都接收一个numbers参数,表示手机号码列表,以逗号分隔。如果输入号码格式错误,则返回400错误。如果发生其他异常,则返回500错误。接口返回相应的记录列表。
  • 最后,在if __name__ == "__main__":中启动FastAPI服务,可以选择线上模式或debug模式运行

1、接口开发:

from fastapi import FastAPI
from fastapi import HTTPException, Query 
from pydantic import BaseModel, Field, validator
import re
import random
from datetime import datetime
from typing import Optional
import uvicorn

app = FastAPI()
error_codes = ['DELIVRD', 'MK:0029', 'MK:0011', 'MK:0001']

def is_valid_phone_numbers(s):
    pattern = r'^(1[3-9]\d{9})(,(1[3-9]\d{9}))*$'
    return bool(re.match(pattern, s))

def current_time_str(format="%Y%m%d%H%M%S"):
    now = datetime.now()
    return now.strftime(format)

class PhoneBaseModel(BaseModel):
    mobile: str = Field(..., min_length=11, max_length=11)
    @validator('mobile')
    def validate_mobile(cls, value):
        # 检查mobile字段是否全部由数字组成
        if not value.isdigit():
            raise ValueError("Phone number must contain only digits.")
        return value

class SendRecord(PhoneBaseModel):
    errorCode: str
    msgGroup: str = '0625161548000003527178'
    receiveDate: Optional[str] = None
    reportStatus: str = 'CM:0000'
    submitDate: str

class DeliverRecord(PhoneBaseModel):
    addSerial: str
    sendTime: Optional[str] = None
    smsContent: str = '2'

@app.get("/send_records", summary="sms", tags=['短信发送记录'])
async def get_send_records(numbers: str = Query(None, description="手机号码列表,以逗号分隔")):
    # 验证文件格式
    if not is_valid_phone_numbers(numbers):
        raise HTTPException(status_code=400, detail="输入号码格式错误")
        return {
            "message": "输入号码格式错误"
        }
    try:
        input_numbers = numbers.split(',') if numbers else numbers.split(',')

        send_records = [
            SendRecord(
                errorCode=error_code,
                mobile=mobile,
                submitDate=current_time_str(),
                receiveDate=current_time_str() if error_code == 'DELIVRD' else None
            )
            for mobile in input_numbers
            for error_code in [random.choice(error_codes)]
        ]
        return send_records
    except Exception as e:
        raise HTTPException(status_code=500, detail=str(e))

@app.get("/deliver_records", summary="sms", tags=['短信回复记录'])
async def get_deliver_records(numbers: str = Query(None, description="手机号码列表,以逗号分隔")):
    if not is_valid_phone_numbers(numbers):
        raise HTTPException(status_code=400, detail="输入号码格式错误")
        return {
            "message": "输入号码格式错误"
        }
    try:
        input_numbers = numbers.split(',') if numbers else numbers.split(',')

        deliver_records = [
            DeliverRecord(
                addSerial='106509712041021',
                mobile=mobile,
                sendTime=current_time_str(),
                smsContent='2'
            )
            for mobile in input_numbers]
        return deliver_records
    except Exception as e:
        raise HTTPException(status_code=500, detail=str(e))


if __name__ == "__main__":
    ## 线上模式
    # uvicorn.run("sms_server:app", host="0.0.0.0", port=1315)

    ## debug 模式
    uvicorn.run("sms_server:app", host="0.0.0.0", port=1315, reload=True, )

2、接口文档:

如果输入号码:XXXX,YYYY

request_url:http://xxx.xxx.x.xxx:1315/send_records?numbers=XXXX%2CYYYY

curl命令:

两个curl命令都用于向指定的HTTP服务器发送GET请求,用于获取短信发送记录。它们在功能上是等价的,只是书写风格有所不同。下面是对每个命令的具体解释:

第一个命令

1curl -X 'GET' \
2  'http://xxx.xxx.x.xxx:1315/send_records?numbers=XXXX%2CYYYY' \
3  -H 'accept: application/json'
  • -X 'GET' 明确指定了HTTP请求的方法为GET。虽然GET是curl发送HTTP请求的默认方法,显式写出是为了清晰或在需要时覆盖默认设置。
  • 'http://xxx.xxx.x.xxx:1315/send_records?numbers=XXXX%2CYYYY' 是目标URL,其中 %2C 是逗号 , 的URL编码形式,用于分隔多个电话号码。
  • -H 'accept: application/json' 设置了请求头,告诉服务器客户端期望接收的内容类型为JSON。这有助于服务器返回适当格式的数据

第二个命令

curl 'http://xxx.xxx.x.xxx:1315/send_records?numbers=15071207452%2C15071207453'

这个命令更简洁,没有明确指定请求方法和自定义头部。因为它省略了-X 'GET'-H 'accept: application/json'curl会默认使用GET方法,并且通常也会接受服务器返回的默认内容类型。在大多数情况下,如果服务器设计合理,它会根据请求的资源自动提供正确的响应内容类型,即使客户端没有明确指定Accept头部。

注意:在URL中,特殊字符需要进行编码以便正确传输。"%2C" 是逗号(,)的URL编码形式。因此,"XXXX%2CYYYY" 解码后实际上是 "XXXX,YYYY"。这里的逗号用来分隔两个不同的电话号码,所以 "%2C" 在这个上下文中代表的是一个分隔符,用于区分多个数值或者项目。当你将此URL用于请求时,服务器会解码 "%2C" 返回其原始字符“,”,从而理解这些是两个独立的号码

3、调用测试:

import requests

# FastAPI服务地址
base_url = "http://xxx.xxx.x.xxx:1315"

# 调用短信发送记录接口
numbers = "13800138000,1390013"
response = requests.get(f"{base_url}/send_records?numbers={numbers}")

if response.status_code == 200:
    print("短信发送记录响应:", response.json())
else:
    print(f"请求失败,状态码:{response.status_code}, 原因:{response.text}")

# 调用短信回复记录接口
response = requests.get(f"{base_url}/deliver_records?numbers={numbers}")

if response.status_code == 200:
    print("短信回复记录响应:", response.json())
else:
    print(f"请求失败,状态码:{response.status_code}, 原因:{response.text}")

输出结果: 

请求失败,状态码:400, 原因:{"detail":"输入号码格式错误"}
请求失败,状态码:400, 原因:{"detail":"输入号码格式错误"}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1864786.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

聚乙烯醇(PVA)涂布型薄膜是高阻隔性包装材料 我国市场增长快速

聚乙烯醇(PVA)涂布型薄膜是高阻隔性包装材料 我国市场增长快速 聚乙烯醇(PVA)涂布型薄膜,是以其他塑料薄膜(主要是双向拉伸薄膜)为基材,以聚乙烯醇为涂料,经表面涂布后制…

推荐5个国内宝藏级物联网平台

随着物联网技术的快速发展物联网平台正成为企业和个人开发者构建智能系统的首选。这些平台以其灵活性、成本效益和强大的社区支持,为用户提供了快速开发和部署物联网解决方案的新途径。本文将介绍几款市场上流行的物联网平台,以及它们各自的技术优势和核…

昇思25天学习打卡营第1天|基本介绍与快速入门

先贴上打卡截图 基本介绍 首先来看基本介绍,昇思MindSpore是华为的一个全场景深度学习框架,属于昇腾AI全栈的一部分。 总体架构如下图所示(来自官方学习材料) 从对底层多样性硬件适用的Runtime到应用层面的Model Zoo、科学计算…

Windows bat 提取多个目录下的文件,到一个目录

批处理命令 echo off setlocalrem 设置源目录和目标目录 set "sourceDirE:\motrix" set "targetDirE:\新建文件夹"rem 创建目标目录,如果不存在 if not exist "%targetDir%" mkdir "%targetDir%"rem 循环遍历源目录中的所…

微信小程序服务器从腾讯云迁移到阿里云出现的坑

微信小程序服务器从腾讯云迁移到阿里云出现的坑 背景 原先小程序后台服务器到期,因为之前买的是腾讯云新用户,便宜,到期后续费金额懂的都懂。就在阿里云用新用户买了个新的,遂把服务全转到了阿里云服务器上。 此时,域…

[SAP ABAP] 汇总内表数据

在加入新数据记录时&#xff0c;将非数值字段具有相同内容记录的数值字段汇总 语法格式 COLLECT <wa> INTO <itab>. <wa>&#xff1a;代表工作区 <itab>&#xff1a;代表内表 示例1 结果显示&#xff1a;

解决google chrome helper 内存占用较高!

导语&#xff1a;mac 后台有很多 google chrome helper 线程并且内存占用较高。一直怀疑是IDEA插件的锅&#xff0c;并不是&#xff01; 查看是哪个网页&#xff0c;哪个插件占用内存。 chrome 更多工具 -> 任务管理器&#xff1a; 找到罪魁祸首&#xff0c;关闭标签页或者…

基于前馈神经网络的姓氏分类任务(基础)

1、认识前馈神经网络 What is it 图1-1 前馈神经网络结构 人们大多使用多层感知机&#xff08;英语&#xff1a;Multilayer Perceptron&#xff0c;缩写&#xff1a;MLP&#xff09;作为前馈神经网络的代名词&#xff0c;但是除了MLP之外&#xff0c;卷积神经网络&#xff08…

Linux通用LInux高危漏洞(CVE-2024-1086)修复案例

一、漏洞描述 2024年3月28日&#xff0c;监 Linux kernel权限提升漏洞&#xff08;CVE-2024-1086&#xff09;的PoC/EXP在互联网上公开&#xff0c;该漏洞的CVSS评分为7.8&#xff0c;目前漏洞细节已经公开披露&#xff0c;美国网络安全与基础设施安全局&#xff08;CISA&…

[leetcode]search-insert-position 搜索插入位置

. - 力扣&#xff08;LeetCode&#xff09; class Solution { public:int searchInsert(vector<int>& nums, int target) {int left 0, right nums.size()-1;while(left <right) {int mid left (right-left)/2;if(nums[mid] target){return mid;} else if(nu…

视觉与味蕾的交响:红酒与艺术的无界狂欢,震撼你的感官世界

在浩瀚的艺术海洋中&#xff0c;红酒以其不同的魅力&#xff0c;成为了一种跨界整合的媒介。当雷盛红酒与艺术相遇&#xff0c;它们共同呈现出一场特别的视觉盛宴&#xff0c;让人沉醉在色彩与光影的交织中&#xff0c;感受红酒与艺术的无界碰撞。 雷盛红酒&#xff0c;宛如一件…

DNS入门指南:企业DNS系统架构趋势解读

诞生于1987年的DNS是互联网和IT基础设施中发生的几乎所有事情的起点。从最初的简单域名解析到现在的智能解析、安全解析&#xff0c;伴随技术的变化与演进&#xff0c;DNS系统也在发生着诸多的变化。总体来说DNS系统的发展有着五大趋势&#xff0c;本文将会逐一进行解读。   …

DataX数据迁移

DataX数据迁移 访问DataX Web管理页面&#xff1a; http://ip:9527/index.html 用户名&#xff1a;admin&#xff0c;密码&#xff1a;123456 本文中示例将SqlServer数据增量同步到MySql中。 增量同步同步时&#xff0c;MySql中的新字段设置默认值 1. 查看执行器是否注册成…

【吊打面试官系列-Mysql面试题】说说对 SQL 语句优化有哪些方法?

大家好&#xff0c;我是锋哥。今天分享关于 【说说对 SQL 语句优化有哪些方法&#xff1f;】面试题&#xff0c;希望对大家有帮助&#xff1b; 说说对 SQL 语句优化有哪些方法&#xff1f; 1、Where 子句中&#xff1a;where 表之间的连接必须写在其他 Where 条件之前&#xff…

品牌电商维权:应对渠道低价与假货的有力举措

在品牌治理渠道的过程中&#xff0c;会遭遇各种各样的问题&#xff0c;其中低价现象尤为突出。低价往往导致经销商被迫跟价&#xff0c;而未授权的店铺则更加不受管控&#xff0c;更容易出现低价情况。然而&#xff0c;低价本身不能直接作为品牌管控渠道的充分理由&#xff0c;…

聚类距离度量(保姆级讲解,包学会~)

在机器学习的聚类中&#xff0c;我们通常需要使用距离来进行类的划分&#xff0c;或者比较不同类之间的各种距离&#xff0c;这里我们介绍西瓜书上所提出的一些距离计算方式。 首先介绍一下距离的一些性质&#xff1a; 西瓜书上给出了四条性质&#xff0c;第一个是非负性&#…

MATLAB-DBO-CNN-SVM,基于DBO蜣螂优化算法优化卷积神经网络CNN结合支持向量机SVM数据分类(多特征输入多分类)

DBO-CNN-SVM&#xff0c;基于DBO蜣螂优化算法优化卷积神经网络CNN结合支持向量机SVM数据分类(多特征输入多分类) 1.数据均为Excel数据&#xff0c;直接替换数据就可以运行程序。 2.所有程序都经过验证&#xff0c;保证程序可以运行。 3.具有良好的编程习惯&#xff0c;程序均…

你的企业“赚钱能力”,银行怎么看?聊聊税贷与票贷背后的门道

大家都听过“税贷”和“票贷”吧&#xff1f;特别是这两年&#xff0c;国家扶持中小微企业&#xff0c;这些名词更是火得不行。但你知道吗&#xff0c;税贷和票贷并不是只看税和票那么简单。今天&#xff0c;咱就来聊聊这背后的门道&#xff08;最后附上&#xff1a;企业信用贷…

四川赤橙宏海商务信息咨询有限公司一站式抖音电商服务

在数字化浪潮汹涌的当下&#xff0c;电商行业正以前所未有的速度发展&#xff0c;而抖音电商作为其中的佼佼者&#xff0c;更是吸引了无数商家和消费者的目光。在这个充满机遇与挑战的市场中&#xff0c;四川赤橙宏海商务信息咨询有限公司凭借其专业的服务和丰富的经验&#xf…

QCC51XX---开启手机log日志

QCC51XX---系统学习目录_trbi200软件-CSDN博客 目录 1.Vivo 2.华为 3.小米 4.三星 5.oppo 1.Vivo *#*#112#*#* 输入命令后会进入log日志系统(由于版本原因,界面可能不同),打开log开关,log就会在后台自动录制。 点击设置,则可进入图1(右边)的界面,可以导出log,导出…