GitLab中文网站 > 技术问题 > GitLab如何接入第三方登录 GitLab中怎样配置OAuth2认证

GitLab如何接入第三方登录 GitLab中怎样配置OAuth2认证

发布时间:2025-07-30 08: 00: 00

品牌型号:联想拯救者R7000

系统:Windows 10专业版

软件版本:JiHu GitLab 16.6

很多公司自建服务器搭建了GitLab服务,并且想要定制化登录,如果要使用公司自己创建好的账号密码登录,就需要使用SSO单点登录技术。其次为GitLab接入第三方登录和配置OAuth2认证,能提升系统的安全性。本文将为大家介绍GitLab如何接入第三方登录,GitLab中怎样配置OAuth2认证的相关内容。

一、GitLab如何接入第三方登录

如果要把GitLab接入公司自定义的登录方式,需要部署OAuth2 SSO服务,下文的演示步骤使用了https://github.com/sonicrang/spring-boot-oauth2-sso-demo开源代码,并且是本地搭建的GitLab服务,最终实现SSO登录。假设现在公司已经部署好了GitLab和OAuth2 SSO,参考下文步骤即可实现第三方登录。

第一步:修改配置文件

1、修改【/etc/gitlab/gitlab.rb】,建议使用MobaXterm等软件修改,需要注意两个地方:

配置文件
图1:配置文件

1)OAuth SSO登录认证URL需要更改为运行【AuthServerApplication】的ip和端口。

Auth服务
图2:Auth服务

2)【external_url】路径参数,需要配置到【configure】方法中的【redirectUris(重定向)】地址。

重定向地址配置
图3:重定向地址配置

第二步:重新加载配置文件

配置完毕后,使用命令【gitlab-ctl reconfigure】重新加载配置文件。

第三步:SSO登录

等待重启完毕后,重新进入GitLab的Web界面,此时看到登录界面多了一个【SSO】选项。

SSO登录
图4:SSO登录

点击【SSO】后跳转【http://192.168.150.1:8300/auth/login】,也就是【OAuth SSO登录】认证服务。

登录
图5:登录

输入账号密码后,点击【sign in】登录,此处借助的是开源代码,可以在代码中看到写死的账号密码。在实际使用中,我们可以对该代码二次开发,读取公司内部的数据库,并判断账号密码是否正确。

查看账号密码
图6:查看账号密码

认证通过后,自动跳转到GitLab中,并实现登录。

登录成功
图7:登录成功

二、GitLab中怎样配置OAuth2认证

了解了第三方登录的接入方法后,配置OAuth2认证同样很重要。OAuth2认证是一种访问机制,能让授权服务器在用户批准下,向第三方客户端颁发访问令牌。以下是GitLab配置OAuth2认证的操作步骤。

1、登录GitLab Web界面后,找到【管理中心-应用程序】选项。

应用程序
图8:应用程序

2、点击【新建应用】,输入应用名称,并且填写用户授权后被重定向到的URL,即重定向URI,一般是【http://xxxx.com/users/auth/gitlab/callback】。

重定向链接
图9:重定向链接

3、选择授权应用程序的范围。例如,【read_user】范围可授予对用户配置文件的只读访问权限,【read_api】范围授予对API的读取权限。

范围
图10:范围

4、完成选择后,系统会生成【应用程序ID】和【密码】,分别对应OAuth2客户端ID和客户端密钥,务必妥善保管。

创建应用成功
图11:创建应用成功

三、总结

以上就是GitLab如何接入第三方登录,GitLab中怎样配置OAuth2认证的相关内容。本文借助开源代码,为大家演示了自建GitLab服务接入第三方登录的步骤,主要就是修改配置文件和重定向地址。本文还介绍了GitLab中配置OAuth2认证的步骤,希望本文对你有所帮助。

展开阅读全文

标签:极狐gitlabDevOps测试

读者也访问过这里:
极狐GitLab
助力企业数字化转型
立即购买
最新文章
Jenkins和GitLab哪个好 GitLab CI/CD怎么用
在实际开发中,借助Jenkins工具或者GitLab的CI/CD功能,可以快速部署项目。很多用户不知道这两款工具应该怎么选择,如果团队正在使用GitLab,并且流程不复杂,使用GitLab CI/CD即可实现自动部署。若项目流程复杂,再考虑Jenkins。本文将为大家介绍Jenkins和GitLab哪个好,GitLab CI/CD怎么用的相关内容。
2025-12-15
GitLab如何配置Shell Runner GitLab如何配置Java环境
GitLab不仅是一个代码管理仓库,还提供了CI/CD功能,可以自动跑代码、测代码,前提是需要配置Runner以及Java环境变量。本文将为大家介绍Gitlab如何配置Shell Runner,Gitlab如何配置Java环境的相关内容。
2025-11-14
GitLab如何导入GitHub项目 GitLab如何导入Gitee项目
很多人用GitHub或者Gitee存储代码,假如公司搭建了GitLab平台,需要把代码统一挪到GitLab里管理,GitLab针对GitHub平台提供了【导入功能】,但是对于Gitee没有提供官方的导入功能,应该怎么才能导入呢?本文将为大家介绍GitLab如何导入GitHub项目,GitLab如何导入Gitee项目的相关内容。
2025-11-14
Gitlab Runner是什么 Gitlab Runner如何配置
在现代的软件开发流程中,持续集成与持续交付(CI/CD)可以有效提高代码质量与工作效率,避免出现大规模代码Bug的情况。Gitlab Runner是GitLab CI/CD的核心组件,主要负责运行自动化任务。本地部署GitLab时,建议掌握GitLab runner的配置方法,尽可能发挥GitLab的全部功能。本文将为大家介绍Gitlab Runner是什么,Gitlab Runner如何配置的相关内容。
2025-11-14
Git、GitHub、GitLab有什么区别 Git和GitLab使用教程
在软件开发的流程中,版本控制与协作平台是推动项目前进的重要基石。Git、GitHub与GitLab都是代码版本控制工具,这三者并不是同一个东西,对于初次接触大型项目开发的用户来说,了解三者关系不仅可以有效提升开发效率,还能提升代码提交的质量。本文将为大家介绍Git、GitHub、GitLab有什么区别,Git和GitLab使用教程的相关内容。
2025-11-14
GitLab可以安装在Windows上吗 GitLab可以代码审查吗
GitLab是一个代码管理平台,可以将本地代码推送到远程仓库,从而实现和同事协作开发,相比于其他代码管理平台,GitLab支持本地部署,那么GitLab可以安装在Windows上吗?提交代码时,一个重要功能就是【代码审查】,那么GitLab可以代码审查吗?本文将为大家回答这两个问题。
2025-10-30

读者也喜欢这些内容:

咨询热线 400-8765-888