「工具|数据接口」免费公开的REST API & 如何借助github搭建自己的fake API接口

本文主要介绍日常开发、测试、教学或者分享中,可能遇到的模拟数据问题。分享免费开发的测试数据接口,以及如何利用github快速搭建定制化的接口数据,避免使用真实数据的风险以及自己现编数据的麻烦。

一、场景说明

日常开发、测试、教学或者分享中,可能在使用需要请求数据的时候遇到一些困难:

  • 需要测试数据对处理逻辑进行测试
  • 进行前端开发时后端接口尚未开发
  • 教程或分享中不可以使用真实业务数据
  • 在一些对数据格式和内容没有要求的场景,手动编写数据进行mock比较麻烦

于是这就涉及到我们需要使用一些公开的且最好是免费的API来尽可能快速地满足我们这些需求场景。

接下来将介绍满足需求的jsonplaceholder,这个接口提供了一些场景类型以及内容的数据来供测试和设计原型时使用。

并且,我们会介绍,当我们对返回的数据和内容有定制化的需求的时候,同时又希望测试真实的网络请求时,如何借助GitHub和My JSON Server搭建一个返回我们预期数据的Fake API.


二、免费公开的Fake REST API: jsonplaceholder

JSONPlaceholder 是一个免费的在线 REST API,可以在我们需要一些虚假数据时使用。它可以位于 GitHub 上的自述文件中、CodeSandbox 上的演示、Stack Overflow 上的代码示例中,或者只是在本地进行测试。

JSONPlaceholder的API地址为: https://jsonplaceholder.typicode.com/,提供了6类常见的数据:

  • /posts: 100 posts
  • /comments: 500 comments
  • /albums: 100 albums
  • /photos: 5000 photos
  • /todos: 200 todos
  • /users: 10 users

同时提供的这些数据之间存在一些关联,比如post会有一些commentalbums会涉及photos等等。

接口支持所有的HTTP方法,遵循Restful风格,所以可以进行如下请求:

  • GET /posts
  • GET /posts/1
  • GET /posts/1/comments
  • GET /comments?postId=1
  • POST /posts
  • PUT /posts/1
  • PATCH /posts/1
  • DELETE /posts/1

更多使用案例可以参考官方文档


三、借助GitHub和My JSON Server搭建自己的定制化数据接口

如果我们希望返回的数据是定制化的,比如数据包含的字段由我们自己指定。那么可以借助GitHub和My JSON Server来快速Fake一个接口。方法如下:

  • 首先在github上面新建一个仓库 (/)
  • 在项目中新建一个db.json文件,这个文件里的数据就是我们的接口会返回的数据
  • 然后我们就可以访问https://my-json-server.typicode.com/<your-username>/<your-repo-name>来获取我们的数据了

比如官方的data.json内容如下:

{
  "posts": [
    {
      "id": 1,
      "title": "Post 1"
    },
    {
      "id": 2,
      "title": "Post 2"
    },
    {
      "id": 3,
      "title": "Post 3"
    }
  ],
  "comments": [
    {
      "id": 1,
      "body": "some comment",
      "postId": 1
    },
    {
      "id": 2,
      "body": "some comment",
      "postId": 1
    }
  ],
  "profile": {
    "name": "typicode"
  }
}

同时这个data.json在github上typicode用户的demo仓库下,那么我们就可以通过如下方式访问到对应数据:

  • 获取数据库全部数据:https://my-json-server.typicode.com/typicode/demo/db
  • 获取所有的post:https://my-json-server.typicode.com/typicode/demo/posts
  • 获取id为1的post:https://my-json-server.typicode.com/typicode/demo/posts/1

基本上常见的fake API使用场景都可以用这两个方法来满足,快去试试吧!

写文不易,如果对你有帮助的话,来一波点赞、收藏、关注吧~👇

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Dart语言支持调用GitHub API接口,可以使用GitHubREST API来实现。要实现给GitHub上的项目打星,可以使用starEndpoint API来实现,具体的步骤如下: 1. 使用GitHub的OAuth2.0授权机制,获取访问令牌。 2. 使用令牌,调用starEndpoint API,传入需要给项目打星的项目信息。 3. 根据API返回的响应,检查是否给项目成功打星。 ### 回答2: 使用Dart调用GitHub APIGitHub上的项目打星可以通过以下步骤实现: 1. 首先,您需要在您的Dart项目中导入http包,使用它来发送HTTP请求并与GitHub API进行通信。 ```dart import 'package:http/http.dart' as http; ``` 2. 接下来,您需要设置GitHub API的请求头,以便进行身份验证。在GitHub上生成一个访问令牌,并将其作为请求头的Authorization字段。 ```dart String baseUrl = "https://api.github.com"; String token = "YOUR_GITHUB_ACCESS_TOKEN"; Map<String, String> headers = { "Accept": "application/vnd.github.v3+json", "Authorization": "token $token", }; ``` 3. 调用GitHub API中的“给存储库打星”接口,向存储库发送一个PUT请求。在请求中,您需要提供存储库的所有者名称和存储库名称。 ```dart String owner = "OWNER_NAME"; String repository = "REPOSITORY_NAME"; String url = "$baseUrl/user/starred/$owner/$repository"; http.Response response = await http.put(url, headers: headers); if (response.statusCode == 204) { print("成功为存储库打星!"); } else { print("无法为存储库打星:${response.reasonPhrase}"); } ``` 在上面的代码示例中,我们使用了await关键字,这意味着我们需要将代码放在一个异步函数内部。这样可以确保我们在等待从GitHub API获得的响应时,不会阻塞Dart的执行。 请注意,您需要将“OWNER_NAME”和“REPOSITORY_NAME”替换为实际的存储库所有者和存储库名称。 通过以上步骤,您可以使用Dart调用GitHub API实现给GitHub上的项目打星功能。 ### 回答3: 在使用Dart实现调用GitHub APIGitHub上的项目打星时,可以按照以下步骤进行: 第一步,确保已经在自己的Dart项目中引入了http包,可通过在`pubspec.yaml`文件中添加`http: ^0.12.0`依赖并运行`pub get`命令来安装。 第二步,导入http包和dart:convert包: ```dart import 'package:http/http.dart' as http; import 'dart:convert'; ``` 第三步,构建函数来调用GitHub API,为特定的GitHub项目打星: ```dart Future<void> starGitHubProject(String owner, String repo, String accessToken) async { final url = 'https://api.github.com/user/starred/$owner/$repo'; final response = await http.put( Uri.parse(url), headers: { 'Authorization': 'token $accessToken', 'Content-Length': '0', }, ); if(response.statusCode == 204){ print('成功给项目打星'); } else{ print('给项目打星失败:${response.statusCode}'); } } ``` 上述函数接收三个参数:`owner`表示GitHub项目的拥有者,`repo`表示GitHub项目的仓库名称,以及`accessToken`表示用户的访问令牌,用于进行身份认证。 最后,我们可以调用上述函数来给GitHub上的项目打星,例如: ```dart void main() async { final owner = '拥有者用户名'; final repo = '项目仓库名称'; final accessToken = '访问令牌'; await starGitHubProject(owner, repo, accessToken); } ``` 以上是使用Dart通过调用GitHub APIGitHub上的项目打星的简单示例代码。请注意,需要替换示例代码中的`owner`、`repo`和`accessToken`为自己合适的值才能正常运行。同时,为确保用户的访问安全,更推荐将访问令牌保存在安全的地方,而不直接硬编码在代码中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

明仔的阳光午后

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值