Heim  >  Artikel  >  Backend-Entwicklung  >  So schreiben Sie API-Dokumentation und Tests mithilfe von API Blueprint-Spezifikationen in PHP

So schreiben Sie API-Dokumentation und Tests mithilfe von API Blueprint-Spezifikationen in PHP

WBOY
WBOYOriginal
2023-06-17 08:50:561563Durchsuche

Mit der rasanten Entwicklung des Internets ist die Verwendung von Web-APIs immer häufiger geworden. Um Benutzern den schnellen Einstieg zu erleichtern, ist es entscheidend, eine gute API-Dokumentation und -Tests zu schreiben. API Blueprint ist eine API-Dokumentspezifikation, die mit der Markup-Sprache Markdown geschrieben wurde und uns dabei helfen kann, API-Dokumentation und -Tests auf standardisierte Weise zu schreiben, wodurch die API einfacher zu verstehen und zu verwenden ist. In diesem Artikel wird erläutert, wie Sie API Blueprint-Spezifikationen verwenden, um API-Dokumentation und -Tests in PHP zu schreiben.

API Blueprint installieren

Bevor wir beginnen, müssen wir zuerst API Blueprint installieren. Wir können API Blueprint über Composer in PHP-Projekte einführen. Führen Sie zur Installation den folgenden Befehl im Terminal aus:

composer require apiaryio/php-codex

API-Dokumentation schreiben

Endpunkte definieren

Eine der Hauptfunktionen von API Blueprint besteht darin, dass es uns bei der Definition von API-Endpunkten helfen kann. Wir können ## verwenden, um einen neuen API-Endpunkt darzustellen. Beispiel: ##表示一个新的API端点。例如:

## 用户

以下API端点针对用户进行操作。

### 获取用户列表 [GET /users]

获取用户列表。

+ Response 200 (application/json)
    + Headers
        Link: <http://example.com>; rel="self"
    + Body

            [
              {
                "id": 1,
                "username": "user1",
                "name": "User One"
              },
              {
                "id": 2,
                "username": "user2",
                "name": "User Two"
              }
            ]

上述定义了一个用户端点和获取用户列表的API端点,并且针对该API端点定义了返回数据结构和错误码等信息。

定义请求参数

我们可以使用+ Parameters来定义请求参数。例如:

+ Parameters

    + page (int, optional, default: 1) ... 页码
    + per_page (int, optional, default: 10) ... 每页数量

上述表示该API端点支持两个请求参数:pageper_page。其中page的数据类型为整型,可选项,缺省值为1;per_page的数据类型为整型,可选项,缺省值为10。

定义请求体

我们可以使用+ Request来定义请求体。例如:

+ Request (application/json)

    {
      "username": "user1",
      "password": "123456"
    }

上述表示该API端点需要传递一个JSON格式的请求体,包含usernamepassword两个参数。

定义返回数据

我们可以使用+ Response来定义返回数据。例如:

+ Response 200 (application/json)
    + Headers
        Link: <http://example.com>; rel="self"
    + Body

            {
              "id": 1,
              "username": "user1",
              "name": "User One"
            }

上述表示该API端点的返回数据为JSON格式,包含idusernamename三个参数。

定义错误码

我们可以使用+ Response来定义错误码。例如:

+ Response 400 (application/json)
    + Headers
        Link: <http://example.com>; rel="self"
    + Body

            {
              "error": "请求参数错误"
            }

上述表示当请求参数错误时,该API端点会返回HTTP状态码为400,错误信息为请求参数错误

npm install -g dredd

Das Obige definiert einen Benutzerendpunkt und den API-Endpunkt zum Abrufen der Benutzerliste sowie die Rückgabedatenstruktur, den Fehlercode und andere Informationen für den API-Endpunkt.

Anforderungsparameter definieren

Wir können + Parameter verwenden, um Anforderungsparameter zu definieren. Zum Beispiel:

## 用户

以下API端点针对用户进行操作。

### 获取用户列表 [GET /users]

获取用户列表。

+ Request

    + Headers

            Authorization: Token abcdefg

    + Parameters

        + page (int, optional, default: 1) ... 页码
        + per_page (int, optional, default: 10) ... 每页数量

+ Response 200 (application/json)
    + Headers
        Link: ; rel="self"
    + Body

            [
              {
                "id": 1,
                "username": "user1",
                "name": "User One"
              },
              {
                "id": 2,
                "username": "user2",
                "name": "User Two"
              }
            ]

+ Response 401 (application/json)
    + Body

            {
              "error": "您没有访问该接口的权限"
            }

+ Request

    + Headers

            Authorization: Token abcdefg

    + Body

            {
              "username": "user1",
              "password": "123456"
            }

+ Response 200 (application/json)
    + Headers
        Link: <http://example.com>; rel="self"
    + Body

            {
              "id": 1,
              "username": "user1",
              "name": "User One"
            }

+ Response 400 (application/json)
    + Body

            {
              "error": "请求参数错误"
            }

Das Obige zeigt an, dass der API-Endpunkt zwei Anforderungsparameter unterstützt: page und per_page. Der Datentyp von page ist ganzzahlig, optional, und der Standardwert ist 1; der Datentyp von per_page ist ganzzahlig, optional und der Standardwert ist 10.

Definieren Sie den Anfragetext

Wir können + Anfrage verwenden, um den Anfragetext zu definieren. Beispiel:

dredd api.apib http://localhost:8000

Das Obige zeigt an, dass der API-Endpunkt einen Anforderungstext im JSON-Format übergeben muss, der zwei Parameter enthält: username und password.

Rückgabedaten definieren

Wir können + Response verwenden, um Rückgabedaten zu definieren. Zum Beispiel:

rrreee

Das Obige zeigt an, dass die Rückgabedaten des API-Endpunkts im JSON-Format vorliegen und drei Parameter enthalten: id, username und name Code>. <p></p>Fehlercode definieren<h2></h2>Wir können <code>+ Response verwenden, um Fehlercode zu definieren. Beispiel:

rrreee

Das Obige bedeutet, dass der API-Endpunkt bei falschem Anforderungsparameter den HTTP-Statuscode 400 zurückgibt und die Fehlermeldung Anfrageparameterfehler lautet. 🎜🎜API-Tests schreiben🎜🎜Eine weitere Hauptfunktion von API Blueprint ist, dass es uns beim Schreiben von API-Tests helfen kann. Wir können [Dredd](https://dredd.org/en/latest/) verwenden, um API-Blueprint-Tests auszuführen. 🎜🎜Installieren Sie Dredd🎜🎜Führen Sie den folgenden Befehl im Terminal aus, um ihn zu installieren: 🎜rrreee🎜Schreiben Sie ein Testskript🎜🎜Wir können das Testskript in API Blueprint definieren. Beispiel: 🎜rrreee🎜Das Obige definiert einen Benutzerendpunkt und den API-Endpunkt zum Abrufen der Benutzerliste und definiert das Testskript im API Blueprint, einschließlich Sendeanforderungen, Überprüfungsantworten und HTTP-Statuscodes. 🎜🎜Führen Sie das Testskript aus🎜🎜Geben Sie im Terminal das Verzeichnis ein, in dem sich der API Blueprint befindet, und führen Sie den folgenden Befehl aus, um die API zu testen: 🎜rrreee🎜Das oben Gesagte bedeutet, dass Sie das Testskript des API Blueprint ausführen und eine Anfrage an senden den lokalen Port 8000, um zu prüfen, ob die API den vereinbarten Spezifikationen entspricht. 🎜🎜Fazit🎜🎜Durch die Verwendung von API-Blueprint-Spezifikationen zum Schreiben von API-Dokumentation und -Tests können wir API-Endpunkte, Anforderungsparameter, Anforderungstexte, Rückgabedaten, Fehlercodes und andere Informationen klarer definieren, wodurch die API einfacher zu verstehen und zu verwenden ist. Gleichzeitig kann durch die Verwendung von Dredd für API-Tests effektiv sichergestellt werden, dass die API den vereinbarten Spezifikationen entspricht. 🎜

Das obige ist der detaillierte Inhalt vonSo schreiben Sie API-Dokumentation und Tests mithilfe von API Blueprint-Spezifikationen in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn