如何制作API接口?

如何制作api接口?

api是应用程序编程接口,可以理解为与不同软件系统进行通信的通道。它本质上是一个预定义的函数。

api有多种形式,最流行的一种是使用http协议提供服务(如:restful),只要符合规定就可以正常使用。现在很多企业都使用第三方提供的api,也为第三方提供api,所以api的设计也需要谨慎。

如何设计一个好的api接口?

阐明功能
在设计之初,你需要按照业务功能点或者模块来组织api的功能,明确你的api需要提供的

清晰的代码逻辑
保持代码整洁并添加必要的注释以确保界面具有单一功能。如果接口需要复杂的业务逻辑,建议将其拆分为多个接口,或者将功能独立封装成公共方法,避免接口中代码过多,不利于维护和后期迭代。

必要的安全校验和
常见的解决方案是使用数字签名。为每个http请求添加签名,服务器端验证签名的有效性,保证请求的真实性。

记录
日志记录对于及时定位问题至关重要。

最小化耦合
一个好的 api 应该尽可能简单。如果api之间的业务耦合度太高,很容易导致某段代码出现异常,导致相关api不可用。所以还是尽量避免api之间关系的复杂性吧。

返回有意义的状态代码
api返回数据中应携带状态码数据。例如,200表示请求正常,500表示服务器出现内部错误。返回通用的状态码有利于问题定位。

开发文档
由于api是提供给第三方或者内部使用的,所以开发文档是必不可少的,否则别人不知道如何使用。

一个好的api开发文档应该包含以下元素:

api架构模型描述、开发工具及版本、系统依赖等环境信息。api提供的功能。api 模块依赖项。调用规则、注释。部署说明等

如何开发api接口?

如果对开发环境满意,大概不到10分钟,就可以完成一个简单api接口的开发(只是一个demo)。

开发前需要安装jdk、maven和ide。

创建一个基于spring boot的新项目。为了快速完成,我选择使用(start.spring.io)来生成我的项目。通过【搜索要添加的依赖项】可以选择包。我只导入了spring mvc,如果需要通过mybatis访问数据库,也可以选择这里,然后点击生成项目。

解压下载的项目并将其引入到您的ide中,然后创建一个新类:com.wukong.apidemo.controller.apicontroller。

在这个类中添加一个方法,主要使用@restcontroller、@requestmapping、@responsebody标签。

最简单的api接口已经完成。我们可以启动项目,访问对应的接口地址,并获取接口返回信息。

我们可以使用swagger来帮助我们生成接口文档,优化api接口。

更高效的api接口制作方法?

python flask 和 java spring boot 都可以用来高效创建 api 接口。

spring boot 将开发过程简化为简单。对于python,我推荐一个用于开发api接口的第三方包:fastapi。

这是一个快速高效的工具,具有以下功能:

快速:与 nodejs 和 go 相当。最快的 python 框架之一。快速编码:将开发速度提高约 200% 至 300%。更少的错误:减少开发人员造成的约 40% 的错误。简单:易于使用和学习。花在阅读文档上的时间更少。基于标准:基于并完全兼容api的开放标准。

使用python3和flask制作restful api(接口测试服务和mockserver工具)

构建 restful api 似乎是开发人员的工作,事实上,有很多场景需要测试开发人员构建 restful api。

有些测试人员会构建restful api,将服务器端域名劫持到自己的api上,故意返回各种异常,以查看客户端的稳定性。

rest: representational state transferget - /api/category - retrieve all categoriespost - /api/category - add a new categoryput - /api/category - update a categorydelete - /api/category - delete a categoryget - /api/comment - retrieve all the stored commentspost - /api/comment - add new comment

要求:python3.*,postgresql.

project/├── app.py├── config.py├── migrate.py├── model.py├── requirements.txt├── resources│   └── hello.py│   └── comment.py│   └── category.py└── run.py

requirements.txt如下:
flask – python 微框架
flask_restful – flask 的扩展,用于快速构建 rest api。
flask_script – 提供在 flask 中编写外部脚本的支持。
flask_migrate – 使用 alembic 的 flask 应用程序进行 sqlalchemy 数据库迁移。
marshmallow – 用于复杂数据类型和 python 数据类型转换。
flask_sqlalchemy – 添加了对 sqlalchemy 的支持的 flask 扩展。
flask_marshmallow – 烧瓶和棉花糖之间的中间层。
marshmallow-sqlalchemy – sqlalchemy 和 marshmallow 之间的中间层。
psycopg – 用于 python 的 postgresql api。

安装依赖项

# pip3 install -r requirements.txt

安装并配置postgresql(以ubuntu 16.04为例)

# sudo apt-get update && sudo apt-get upgrade# apt-get install postgresql postgresql-contrib# su - postgres$ createdb api$ createuser andrew --pwprompt #create user$ psql -d api -c "alter user andrew with password 'api';"

配置

from flask import blueprintfrom flask_restful import apifrom resources.hello import hellofrom resources.category import categoryresourcefrom resources.comment import commentresourceapi_bp = blueprint('api', __name__)api = api(api_bp)# routesapi.add_resource(hello, '/hello')api.add_resource(categoryresource, '/category')api.add_resource(commentresource, '/comment')

快速入门

app.py

from flask import blueprintfrom flask_restful import apifrom resources.hello import helloapi_bp = blueprint('api', __name__)api = api(api_bp)# routeapi.add_resource(hello, '/hello')

资源/hello.py

#!/usr/bin/python# -*- coding: utf-8 -*-# author:    xurongzhong#126.com wechat:pythontesting qq:37391319# createdate: 2018-1-10from flask_restful import resourceclass hello(resource):    def get(self):        return {"message": "hello, world!"}    def post(self):        return {"message": "hello, world!"}

run.py

from flask import flaskdef create_app(config_filename):    app = flask(__name__)    app.config.from_object(config_filename)    from app import api_bp    app.register_blueprint(api_bp, url_prefix='/api')    return appif __name__ == "__main__":    app = create_app("config")    app.run(debug=true)

开始服务

$ python3 run.py * running on http://127.0.0.1:5000/ (press ctrl+c to quit) * restarting with stat * debugger is active! * debugger pin: 136-695-873

使用浏览器访问:http://127.0.0.1:5000/api/hello

{    "hello": "world"}

访问数据库

from flask import flaskfrom marshmallow import schema, fields, pre_load, validatefrom flask_marshmallow import marshmallowfrom flask_sqlalchemy import sqlalchemyma = marshmallow()db = sqlalchemy()class comment(db.model):    __tablename__ = 'comments'    id = db.column(db.integer, primary_key=true)    comment = db.column(db.string(250), nullable=false)    creation_date = db.column(db.timestamp, server_default=db.func.current_timestamp(), nullable=false)    category_id = db.column(db.integer, db.foreignkey('categories.id', ondelete='cascade'), nullable=false)    category = db.relationship('category', backref=db.backref('comments', lazy='dynamic' ))    def __init__(self, comment, category_id):        self.comment = comment        self.category_id = category_idclass category(db.model):    __tablename__ = 'categories'    id = db.column(db.integer, primary_key=true)    name = db.column(db.string(150), unique=true, nullable=false)    def __init__(self, name):        self.name = nameclass categoryschema(ma.schema):    id = fields.integer()    name = fields.string(required=true)class commentschema(ma.schema):    id = fields.integer(dump_only=true)    category_id = fields.integer(required=true)    comment = fields.string(required=true, validate=validate.length(1))    creation_date = fields.datetime()

迁移.py

from flask_script import managerfrom flask_migrate import migrate, migratecommandfrom model import dbfrom run import create_appapp = create_app('config')migrate = migrate(app, db)manager = manager(app)manager.add_command('db', migratecommand)if __name__ == '__main__':    manager.run()

数据迁移

$ python3 migrate.py db init$ python3 migrate.py db migrate$ python migrate.py db upgrade

测试
您可以使用curl,例如:

curl http://127.0.0.1:5000/api/Category --data '{"name":"test5","id":5}' -H "Content-Type: application/json"

以上就是如何制作API接口?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1499021.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 20:57:41
下一篇 2025年12月19日 20:57:46

相关推荐

  • JavaScript中根据条件动态创建对象属性的策略与实践

    本教程探讨了在JavaScript中如何根据特定条件动态地为对象添加属性,旨在避免分散的对象创建步骤和不必要的中间对象。文章将详细介绍使用构造函数、对象展开语法、立即执行函数表达式(IIFE)以及传统条件赋值等多种方法,并分析它们的优缺点,帮助开发者选择最适合其场景的实现方式,从而编写出更简洁、高效…

    2025年12月20日
    000
  • Vue 中实现高性能虚拟列表:解决大数据量滚动优化难题

    在 Vue 应用中,特别是 Electron 环境下,如何高效处理包含大量数据的滚动列表是一个常见的挑战。针对传统无限滚动和分页在大数据量下可能导致的性能瓶颈,本文将详细介绍并实现一种基于虚拟滚动(Virtual List)的解决方案。通过构建一个可复用的虚拟列表组件,文章将阐述其核心原理、代码实现…

    2025年12月20日
    000
  • 在React Router应用中按需隐藏导航栏的策略

    本文探讨了在React Router应用中,如何通过引入布局组件(Layout Component)优雅地实现导航栏的按需显示与隐藏。通过将通用UI元素(如导航栏和页脚)封装在布局中,并根据路由需求选择性地应用这些布局,开发者可以有效地管理不同页面间的结构差异,避免在特定页面(如404页面)上渲染不…

    2025年12月20日
    000
  • 什么是WebAssembly与JavaScript的互操作,以及它如何提升计算密集型任务的执行效率?

    WebAssembly与JavaScript互操作通过共享线性内存实现高效数据传递,JavaScript调用Wasm函数处理计算密集任务,Wasm可调用JS函数访问浏览器API,数据以ArrayBuffer形式共享,避免拷贝开销。典型应用包括图像视频处理、科学计算、游戏物理引擎、加密解密和Web I…

    2025年12月20日
    000
  • React Router 中条件渲染导航栏:使用布局组件优化页面UI

    本教程详细阐述如何在 React Router 应用中实现特定页面的导航栏条件隐藏,尤其针对如 404 错误页等无需导航的场景。通过引入布局组件模式,将共享的 UI 元素(如导航栏和页脚)封装起来,并结合 React Router 的路由配置,实现对不同页面应用不同的布局,从而构建出结构清晰、可维护…

    2025年12月20日
    000
  • 如何用WebUSB实现固件更新与设备管理?

    答案:WebUSB通过浏览器实现USB设备固件更新与管理,需设备支持DFU协议并声明landing page URL;使用navigator.usb.requestDevice()请求设备,通过transferOut()/transferIn()进行数据传输;兼容性方面主要依赖Chromium内核浏…

    2025年12月20日
    000
  • 如何用WebGPU实现深度学习模型的推理加速?

    WebGPU在深度学习推理中的核心优势体现在性能提升、跨平台支持和隐私保护。它通过更底层的硬件访问能力,利用GPU并行计算显著加速模型推理,相比WebGL减少了CPU与GPU间的数据传输开销;其原生浏览器支持实现了多平台兼容,使AI计算可在用户端完成,保障数据隐私并降低服务器成本。 WebGPU的出…

    2025年12月20日
    000
  • 如何用Web Serial实现传感器数据的实时采集与可视化?

    Web Serial API使浏览器能直接与串口设备通信,实现传感器数据的实时采集与可视化。通过前端应用调用API连接设备,读取格式化数据(如JSON或CSV),并利用Chart.js等库动态更新图表,相比传统方案具备零安装、低延迟、跨平台、易部署等优势。但需注意浏览器兼容性(仅Chromium系支…

    2025年12月20日
    000
  • Vue高性能无限滚动与虚拟列表实现指南

    本文将深入探讨在Vue应用中如何高效处理海量数据列表的渲染问题,特别是针对需要实现分页或无限滚动加载的场景。我们将重点介绍虚拟列表(Virtual List)技术的核心原理与Vue组件实现,通过仅渲染可视区域内的DOM元素,显著提升应用性能和用户体验,即使面对数万条数据也能保持流畅。 理解海量数据渲…

    2025年12月20日
    000
  • React Router中根据路由动态控制导航栏显示策略

    本文探讨了在React应用中,如何利用React Router实现特定页面(如404页面)隐藏导航栏的需求。通过引入布局(Layout)组件模式,我们将导航栏封装在可复用的布局中,并根据路由配置选择性地应用这些布局,从而优雅地解决全局导航栏显示与局部隐藏之间的矛盾,提升应用结构的可维护性和灵活性。 …

    2025年12月20日
    000
  • HTML表单电话号码验证:pattern属性的正确使用与正则表达式解析

    本文深入探讨HTML pattern 属性在电话号码验证中常见的问题,特别是针对 (+971)NNNNNNNNNN 格式的正则表达式编写。我们将详细解析如何正确转义特殊字符如 +、(、),并提供一个精确匹配该格式的解决方案,确保表单验证的准确性和用户体验。通过本文,读者将掌握使用 pattern 属…

    2025年12月20日
    000
  • Vue中大型列表性能优化:虚拟滚动实现指南

    在Vue应用中处理包含数千甚至数万条记录的滚动列表时,直接渲染所有数据会导致严重的性能问题。本文将详细介绍如何通过虚拟滚动(Virtual List)技术来高效渲染大型数据集,避免性能瓶颈,尤其适用于多列无限滚动场景。我们将提供一个功能完善的Vue虚拟列表组件实现,并解析其核心原理与使用方法。 1.…

    2025年12月20日
    000
  • JavaScript错误处理与异常捕获机制

    JavaScript错误处理通过try…catch、throw和window.onerror提升程序健壮性,try…catch用于捕获并处理异常,可结合finally执行清理操作;throw用于主动抛出自定义错误,支持携带错误信息并按类型处理;window.onerror作为…

    2025年12月20日
    000
  • TomSelect:Ajax响应后设置选中值的正确方法

    本文档旨在指导开发者如何在TomSelect下拉选择器中,通过Ajax请求获取数据后,正确设置选中值。常见的.val().change()方法在TomSelect中可能失效,本文将提供一种有效的解决方案,并附带示例代码,帮助你快速解决类似问题。 问题分析 在使用TomSelect时,直接使用$(&#…

    2025年12月20日
    000
  • 动态构建 Tailwind CSS 类名:问题与解决方案

    本文探讨了在使用 Tailwind CSS 和 clsx 等工具时,动态构建类名所面临的挑战。Tailwind CSS 依赖于静态分析来提取类名,因此动态生成的类名可能无法被正确识别。文章将介绍几种解决此问题的方法,包括使用完整的类名、安全地列出类名,以及转换内容文件。 在使用 Tailwind C…

    2025年12月20日
    000
  • Tailwind CSS与clsx动态生成类名:深入理解与最佳实践

    在使用clsx和tailwind-merge构建React/Next.js组件时,开发者常试图通过自定义工具函数动态生成带有修饰符(如dark:、hover:)的Tailwind类名,以提高代码复用性。然而,这种动态拼接字符串的方式通常无法生效,核心原因在于Tailwind CSS的类名提取机制是基…

    2025年12月20日
    000
  • 什么是JavaScript的异步错误处理策略,以及如何在Promise链和async/await中统一捕获异常?

    Promise链通过.catch()捕获错误,async/await使用try…catch处理异常,两者需结合全局unhandledrejection事件和顶层.catch()确保所有错误被捕捉,避免程序崩溃。 JavaScript的异步错误处理策略核心在于如何优雅地捕获和处理Promi…

    2025年12月20日
    000
  • JS 可选链与空值合并 – 简化多层对象属性访问的安全写法

    可选链(?.)和空值合并(??)简化嵌套属性访问与默认值设置,避免 TypeError 并提升代码可读性,适用于处理可能为 null 或 undefined 的情况,需注意兼容性及合理使用场景。 JS 可选链与空值合并,简单说,就是让你在访问嵌套对象属性时,不用写一堆 && 判断是否…

    2025年12月20日
    000
  • 怎么使用JavaScript操作日期和时间?

    JavaScript中操作日期时间需使用Date对象,通过new Date()创建,支持获取当前或指定时间。获取年月日可用getFullYear()、getMonth()(需+1)和getDate(),并结合padStart()格式化补零。格式化推荐Intl.DateTimeFormat或手动拼接字…

    2025年12月20日 好文分享
    000
  • 如何用WebTransport实现低延迟的网络通信?

    WebTransport基于HTTP/3和QUIC,提供低延迟双向通信,支持可靠流与不可靠数据报,适用于实时游戏等场景。 WebTransport 是一种现代的网络协议,它在 HTTP/3 的基础上构建,旨在提供低延迟、双向、多路复用的通信能力。它非常适合实时应用,比如在线游戏、实时协作工具等。核心…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信