7

我一直在 Jenkins 中使用 Git 插件从 GitHub 存储库中提取源代码。我一直在使用用户名和密码进行身份验证

在此处输入图像描述

然而,GitHub 已经宣布

弃用通知:GitHub 将停止对 API 的密码验证。您现在必须使用 API 令牌(例如 OAuth 访问令牌、GitHub 应用安装访问令牌或个人访问令牌)对 GitHub API 进行身份验证,具体取决于您需要对令牌执行的操作

所以我需要更改身份验证以使用 oAuth 令牌。

1> 我在 GitHub 中创建了一个 oAuth 令牌
2> 然后在 Jenkins 中我创建Secret Text为全局凭证。(使用 GitHub 的 oAuth 令牌)
3> 但是,当我转到作业配置时,Git 插件不会在 DropDownList 中显示任何类型的secret text凭据(尽管它显示了所有其他凭据)

如何配置 Git Pug-in 以使用 oAuth 令牌?

4

4 回答 4

1

首先检查您是否github-oauth安装了 Jenkins 插件,如Walker Rowe的“使用 Jenkins OAuth 插件安全地从 GitHub 拉取”中所述。

这将允许将您的 Jenkins 服务器注册为可以访问 GitHub 资源的应用程序:

https://cdn.ttgtmedia.com/rms/editorial/TSS_jenkins_oauth_041018_fig5_desktop.png

于 2020-03-18T22:51:19.933 回答
0

这个答案描述了在 Jenkins 中使用 Github 设置 OAuth 的整个过程:https ://stackoverflow.com/a/61995795/9962007

于 2021-04-17T08:29:52.117 回答
0

坚持使用“带密码的用户名”凭据类型,使用令牌(通常是个人访问令牌)代替密码创建。

您链接到的GitHub 文档特别提到了这种类型的用例:

curl -u username:token https://api.github.com/user

如果您的工具仅支持基本身份验证但您想利用 OAuth 访问令牌安全功能,则此方法很有用。


Git 插件不接受SecretText凭据,因为它不知道如何处理它。虽然它不仅限于基本身份验证(毕竟它支持 SSH),但它不知道如何处理 OAuth 令牌。

幸运的是,GitHub 为这种确切类型的用例提供了一种解决方法,它允许您(虚拟地)在任何您会使用密码的地方传递令牌

使用此方法,您可以利用令牌的安全功能,例如每个令牌范围,而无需改造现有工具。

于 2020-03-22T21:14:47.503 回答
0

另一种方法是利用GitHub App 身份验证支持

它于 2020 年 4 月与GitHub Branch Source 2.7.0-beta1一起发布,可在Jenkins 实验更新中心获得。

为什么要作为 GitHub 应用程序进行身份验证?

  • 更大的速率限制 - GitHub 应用程序的速率限制随您的组织规模而变化,而基于用户的令牌的限制为 5000,无论您拥有多少存储库。
  • 独立于用户的身份验证- 每个 GitHub 应用程序都有自己的独立于用户的身份验证。
    不再需要“机器人”用户或弄清楚谁应该是 2FA 或 OAuth 令牌的所有者。
  • 改进的安全性和更严格的权限- 与服务用户及其个人访问令牌相比,GitHub 应用程序提供了更细粒度的权限。
    这让 Jenkins GitHub 应用程序需要更少的权限才能正常运行。
  • 访问 GitHub Checks API - GitHub 应用程序可以访问 GitHub Checks API 以从 Jenkins 作业创建检查运行和检查套件,并提供有关提交和代码注释的详细反馈

https://jenkins.io/images/github-app-rate-limit.png

和:

除了对 Multi-Branch Pipeline 使用 GitHub App 身份验证外,您还可以直接在 Pipelines 中使用应用身份验证。

您可以像往常一样通过加载“用户名/密码”凭据来访问 GitHub API 的 Bearer 令牌,该插件将在后台处理与 GitHub 的身份验证

于 2020-04-16T16:26:09.897 回答