首页
学习
活动
专区
圈层
工具
发布

13 个设计 REST API 的最佳实践

不要返回纯文本 虽然返回 JSON 数据格式的数据不是 REST 架构规范强制限定的,但大多 REST API 都遵循这条准则。...在响应中返回错误详情 当 API 服务器处理错误时,如果能够在返回的 JSON body 中包含错误信息,对于接口调用者来说,会一定程度上帮助他们完成调试。...但这样做的问题是,通常,web 框架并不是针对构建 REST API 服务而专门存在的,换言之,Flask 和 Express 是两个十分通用的框架,但它们并非特别适合用于构建 REST API 服务。...在 Python 中,我发现的最好的 API 框架之一是 Falcon。它与 Flask 一样简单,非常高效,十分适合构建 REST API 服务。...如果你更喜欢 Django 的话,使用 Django REST Framework就足够了,虽然框架不是那么直观(注:按我的理解应该是说不太容易上手,但是我不这么认为),但功能非常强大。

4.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    REST API 设计最佳实践:如何构建、设计和使用 API ?

    在响应体中返回错误详情 当API服务器处理错误时,将错误详细信息包含在JSON主体中可以帮助使用者进行调试,这是是非常方便的,如果您还能说明哪些字段受到了错误的影响,那就更好了!...这种方法的问题在于,通常情况下,框架并不是针对构建REST API服务器而设计的。例如,Flask和Express都是两个非常灵活的框架,但它们并没有专门为帮助您构建REST API而制定。...各种语言中已经出现了新框架, 它们专门用于构建REST APIs。它们能够帮助您轻松遵循最佳做法,并提高生产力。 在Python中, 我找到过其中之一优秀API框架就是Falcon。...它与Flask一样简单易用,速度很快,非常适合在几分钟内构建REST API。 如果您更喜欢使用Django,那么首选就是Django REST框架。虽然它不如其他框架直观,但功能非常强大。...在Node中,Restify似乎也是一个很好的选择,尽管我还没有尝试过。我强烈建议您试一试这些框架,它们将帮助您构建美观、优雅且设计精良的REST API。

    2.2K40

    python教程

    用我们的序列化来写常规的Django视图 让我们看看,使用我们新的序列化类,我们怎么写一些API视图。此刻,我们不会使用REST框架的其他特性,仅仅像写常规Django视图一样。...通常,你并不想这么做,并且事实上REST框架视图更实用的做法不是这样的,但是目前来说,这足以到达我们的目的。...request.data能够处理json请求,但是它也能处理其他格式。相似地,虽然我们可以在响应对象中带数据,但允许REST框架渲染响应成正确的内容类型。...我们会是使用基类代表实例,并创建我们自己的.get()方法,而不是用普通的视图。...代表一种关系可以有很多种方式: 使用主键。 在实体之间使用超链接。 在相关的实体上使用独一无二的slug。 使用相关的实体的默认字符串。 在父表述使用嵌套的实体。 一些自定义的表述。

    6.3K10

    RESTframework_一

    在前后端分离的应用模式中,我们通常将后端开发的每个视图都称为一个接口,或者API,前端通过访问接口来对数据进行增删改查....数据 总结 开发REST API ,视图操作 将数据库序列化为前端所需要的格式,并返回 将前端的数据反序列化为模型类对象,并保存到数据库中 REST framework 特点: 提供了定义序列化器Serializer...的方法,可以快速根据 Django ORM 或者其它库自动序列化/反序列化; 提供丰富的类视图,Mixin扩展类,简化视图的编写 丰富的定制层级:函数视图,类视图,视图集合到自动生成API,满足各种需要...多种身份认证和权限认证的支持 内置限流系统 直观的API web 界面 可扩展性,插件丰富 创建 REST framework 工程 安装DRF pip install djangorestframework...='pub_date') # 5.使用关联对象的序列化器 # {'name': '乔峰', 'gender': True, 'comment': '降龙十八掌', 'book_id': 2,'

    1K20

    简化 Django 开发的八个 Python 包 | Linux 中国

    我们为 Django 应用准备了六个包,为 Django 的 REST 框架准备了两个包。几乎所有我们的项目里,都用到了这些包,真的,不是说笑。  ...◈   describe_form 输出模型的表单定义,可以粘贴到   forms.py 文件中。(需要注意的是,这种方法创建的是普通 Django 表单,而不是模型表单。)...处理 Django REST 框架的用户认证:django-rest-auth  如果 Django 开发中涉及到对外提供 API,你很可能用到了 Django REST Framework[22](DRF...Django REST 框架的 API 可视化:django-rest-swagger  Django REST Swagger[23] 提供了一个功能丰富的用户界面,用来和 Django REST 框架的...你只需要安装 Django REST Swagger,把它添加到 Django 项目的已安装应用中,然后在 urls.py 中添加 Swagger 的视图和 URL 模式就可以了,剩下的事情交给 API

    3.7K20

    测试开发进阶(二十七)

    优化视图-请求 from rest_framework.views import APIView 当视图继承 APIView之后,请求实例方法中的第二个参数 request为 Request对象,是对Django...Request 对Django中的HttpRequest进行拓展 根据请求头中的Content-Type自动进行解析 无论前端发送那种格式数据,都可以以相同的方式读取 request.data 类似于Django...中的request.POST和request.FILES 可以对POST,PUT,PATCH的请求体进行解析 支持form表单传参,支持json格式传参 request.query_params 类似Django...中的request.GET 获取查询字符串参数 支持Django.request中所有的对象和方法 优化视图-渲染 from rest_framework.response import Response...json渲染器为第一优先级 "rest_framework.renderers.JSONRenderer", # 可浏览的API渲染为第二优先级 "rest_framework.renderers.BrowsableAPIRenderer

    84120

    体验Django REST framework,解读REST架构风格

    因为项目中使用了REST API,所以对REST架构风格做了一些研究。如果有对REST架构风格还不了解,或者一知半解的朋友,可以读读我的另一篇文章《那些年,我们一起误解过的REST》。...一开始在项目中使用的是OpenResty来实现REST API,但使用起来一直觉得不方便。主要是因为Lua没有ORM,也没有REST架构风格的框架。...直到最近在用Django时,接触到Django REST framework,在深感便利的同时,也进一步加深了对REST架构风格的理解。...id=1,这样代表的是从所有的user资源中过滤出id=1的资源集合,而不是表示id=1的具体资源。 在资源URI中,id需要放在URI路径中,不能放在请求参数中。...[image.png] 当请求json格式时,REST API返回纯json的表述;当请求api格式(实际上是html格式)时,REST API返回渲染过的html页面,所以才有上文的各种功能丰富的截图

    4.5K582

    Django实践-10RESTful架构和DRF入门

    SOA支持的服务,都是些离散的可以再使用的事务处理,这些事务处理合起来就组成了一个业务流程,是从基本的系统中提取出来的抽象代码。 SOA是一个框架的方法,而SaaS是一种传递模型。...在实现SOA的诸多方案中,REST被认为是最适合互联网应用的架构,符合REST规范的架构也经常被称作RESTful架构。...ID的学生的指定ID的朋友 RDF实现 DRF使用入门 参考:https://www.django-rest-framework.org/ 在Django项目中,如果要实现REST架构,即将网站的资源发布成...前后端分离的开发需要后端为前端、移动端提供API数据接口,而API接口通常情况下都是返回JSON格式的数据,这就需要对模型对象进行序列化处理。...在Group和User中,我们使用的是HyperlinkedModelSerializer的超链接关系。您也可以使用主键和各种其他关系,但是超链接是很好的RESTful设计。

    97021

    构建强大的API-Django中的REST框架探究与实践

    本文将深入探讨Django中REST框架的使用,并通过代码实例和解析来展示其强大之处。1. 什么是REST框架?...数据验证与错误处理在API开发中,数据验证和错误处理是至关重要的部分。Django REST框架提供了强大的数据验证机制和错误处理功能,让我们能够轻松地处理各种情况。...文件上传与存储在许多应用程序中,文件上传和存储是常见的需求。Django REST框架提供了简单而强大的文件上传和存储功能,使我们能够轻松地处理文件上传和管理。...总结在本文中,我们探讨了Django中REST框架的一系列功能和技术,涵盖了API开发中的各个方面。...在实际应用中,我们应该根据具体的业务需求和场景,灵活运用Django REST框架提供的各种功能和技术,从而构建出高质量、稳定可靠的API应用程序。

    2.6K20
    领券