Skip to main content

验证为 GitHub 应用程序安装

可以将 GitHub App 作为安装进行身份验证,以便发出 API 请求来影响安装应用的帐户拥有的资源。

关于以 GitHub App安装形式进行身份验证

在帐户上安装 GitHub App后,你可以将其以 API 请求的应用安装形式进行身份验证。 这允许应用访问该安装拥有的资源,前提是已授予该应用必要的存储库访问权限和相应权限。 应用安装发出的 API 请求归属于该应用。 有关安装GitHub应用的详细信息,请参阅 Installing GitHub Apps

例如,如果你要让应用更改组织拥有的“octo-org”项目上问题的 Status 字段,需要以应用的 octo-org 安装形式进行身份验证。 问题的时间线将指出应用已更新状态。

若要以安装方式发出 API 请求,必须首先生成安装访问令牌。 然后,你将在后续 API 请求的 Authorization 标头中发送安装访问令牌。 此外,还可以使用 GitHub 的 Octokit SDK,它可以为你生成安装访问令牌。

某些 REST API 终结点不接受安装访问令牌,且大多数 REST API 终结点要求应用具有使用终结点的特定权限。 要查看 REST API 终结点是否接受安装访问令牌并查看所需的权限,请参阅终结点的文档。

应用安装还可以使用 GraphQL API。 与 REST API 类似,应用必须具有特定权限才能访问 GraphQL API 中的对象。 对于 GraphQL 请求,应测试应用是否具有执行你需要的 GraphQL 查询和变更的所需权限。

还可以使用安装访问令牌对基于 HTTP 的 Git 访问进行身份验证。 应用必须具有“内容”存储库权限。 然后可以使用安装访问令牌作为 HTTP 密码。 将 TOKEN 替换为安装访问令牌:git clone https://x-access-token:TOKEN@github.com/owner/repo.git

使用安装访问令牌发出的请求有时称为“服务器到服务器”请求。

有关代表用户以应用形式而不是以应用安装形式进行身份验证的详细信息,请参阅“代表用户使用 GitHub 应用进行身份验证”。

使用安装访问令牌以应用安装形式进行身份验证

要使用安装访问令牌以安装形式进行身份验证,请先使用 REST API 生成安装访问令牌。 然后,在 REST API 或 GraphQL API 请求的 Authorization 标头中使用该安装访问令牌。 安装访问令牌将在 1 小时后过期。

生成安装访问令牌

数据 可重用 应用程序.生成安装访问令牌 %}

使用安装访问令牌进行身份验证

要使用安装访问令牌进行身份验证,请将它添加到 API 请求的 Authorization 标头中。 访问令牌将同时适用于 GraphQL API 和 REST API。

应用必须具有使用终结点所需的权限。 有关详细信息,请参阅“为GitHub应用选择权限”。

在以下示例中,将 INSTALLATION_ACCESS_TOKEN 替换为安装访问令牌:

curl --request GET \
--url "http(s)://HOSTNAME/api/v3/meta" \
--header "Accept: application/vnd.github+json" \
--header "Authorization: Bearer INSTALLATION_ACCESS_TOKEN" \
--header "X-GitHub-Api-Version: 2022-11-28"

使用 Octokit.js SDK 以应用安装形式进行身份验证

可以使用 GitHub 的 Octokit.js SDK 以应用安装形式进行身份验证。 使用 SDK 进行身份验证的一个优点是,无需自行生成 JSON Web 令牌 (JWT)。 此外,SDK 将负责为你重新生成安装访问令牌,你无需担心在一小时后过期。

注意

必须安装和导入 octokit,才能使用 Octokit.js 库。 以下示例根据 ES6 使用导入语句。 有关不同安装和导入方法的详细信息,请参阅 Octokit.js 自述文件的用法部分

使用 Octokit.js 通过安装 ID 进行身份验证

  1. 获取 GitHub App 的 ID。 可以在 GitHub App 的设置页上找到应用的 ID。 若要详细了解如何导航到 GitHub App 的设置页,请参阅“修改GitHub应用注册”。

  2. 生成私钥。 有关详细信息,请参阅“管理GitHub应用的私钥”。

  3. 获取要作为其身份进行身份验证的安装 ID。

    如果要响应 Webhook 事件,Webhook 有效负载将包含安装 ID。

    还可以使用 REST API 查找应用安装的 ID。 例如,可以使用 GET /users/{username}/installationGET /repos/{owner}/{repo}/installationGET /orgs/{org}/installationGET /app/installations 终结点获取安装 ID。 有关详细信息,请参阅“GitHub Apps 的 REST API 终结点”。

  4. App 导入 octokit。 创建 App 的一个新实例。 在以下示例中,将 APP_ID 替换为对应用 ID 的引用。 将 PRIVATE_KEY 替换为对应用私钥的引用。

    JavaScript
    import { App } from "octokit";
    
    const app = new App({
      appId: APP_ID,
      privateKey: PRIVATE_KEY,
    });
    
  5. 使用 getInstallationOctokit 方法创建经过身份验证的 octokit 实例。 在以下示例中,将 INSTALLATION_ID 替换为要代表其进行身份验证的应用的安装 ID。

    JavaScript
    const octokit = await app.getInstallationOctokit(INSTALLATION_ID);
    
  6. 使用 octokit 方法向 API 发出请求。

    应用必须具有使用终结点所需的权限。 有关详细信息,请参阅“为GitHub应用选择权限”。

    例如,若要向 GraphQL API 发出请求:

    JavaScript
    await octokit.graphql(`
      query {
        viewer {
          login
        }
      }
      `)
    

    例如,若要向 REST API 发出请求:

    JavaScript
    await octokit.request("GET /meta")
    

使用 Octokit.js 进行身份验证以响应 Webhook 事件

Octokit.js SDK 还会将经过预身份验证的 octokit 实例传递给 Webhook 事件处理程序。

  1. 获取 GitHub App 的 ID。 可以在 GitHub App 的设置页上找到应用的 ID。 若要详细了解如何导航到 GitHub App 的设置页,请参阅“修改GitHub应用注册”。

  2. 生成私钥。 有关详细信息,请参阅“管理GitHub应用的私钥”。

  3. 获取在应用的设置中指定的 Webhook 密钥。 有关 Webhook 密钥的详细信息,请参阅将 Webhook 与 GitHub 应用配合使用

  4. App 导入 octokit。 创建 App 的一个新实例。 在以下示例中,将 APP_ID 替换为对应用 ID 的引用。 将 PRIVATE_KEY 替换为对应用私钥的引用。 请将 WEBHOOK_SECRET 替换为您应用的 Webhook 密钥。

    JavaScript
    import { App } from "octokit";
    
    const app = new App({
      appId: APP_ID,
      privateKey: PRIVATE_KEY,
      webhooks: { WEBHOOK_SECRET },
    });
    
  5. 使用 app.webhooks.* 方法处理 Webhook 事件。 有关详细信息,请参阅 Octokit.js 自述文件的 Webhook 部分。 例如,要在提交问题后为问题创建注释,请参考以下内容:

    app.webhooks.on("issues.opened", ({ octokit, payload }) => {
      await octokit.request("POST /repos/{owner}/{repo}/issues/{issue_number}/comments", {
          owner: payload.repository.owner.login,
          repo: payload.repository.name,
          issue_number: payload.issue.number,
          body: `This is a bot post in response to this issue being opened.`,
          headers: {
            "x-github-api-version": "2022-11-28",
          },
        }
      )
    });