不像这篇文章,我使用的是macOS。

我已经在GitLab中配置了密码。我也有一个SSL密钥创建后的项目是在GitLab。

当我在新项目中使用现有文件夹并执行以下步骤时,系统会提示我输入GitLab用户名和密码。

现有的文件夹

cd existing_folder
git init
git remote add origin https://gitlab.com/sobopla/Geronimod.git
git add .
git commit -m "Initial commit"
git push -u origin master

输入密码后,我得到以下错误。

remote: HTTP Basic:拒绝访问 致命:“https://gitlab.com/myname/myproject”认证失败


当前回答

以管理员身份打开命令提示符,然后执行以下命令:

git config --system --unset credential.helper

其他回答

我尝试使用浏览器URL存储库

git clone $(browserURL)

它提示输入我的用户名和密码

它运行得很好

mac下使用KeyChain ->登录->密码:修改密码

我从窗口的“凭据管理器”中删除了gitlab凭据,并成功推送

在Gitlab中,进入管理员/设置/常规/登录限制部分。

如果您正在通过HTTPS对GitLab进行身份验证,请确保您具备:

Allow password authentication for Git over HTTP(S)

检查。此选项假设您不使用2FA。如果您不使用外部身份验证提供程序,则显示还具有:

Allow password authentication for the web interface

也检查。

除了凭据管理器中的无效凭据之外,还有另一个导致此错误的原因。

我遇到了一个问题,我的帐户使用LDAP进行身份验证,但仍然设置了密码过期日期。由于服务器被配置为只使用LDAP身份验证,密码过期在web UI中是不可见的,直到GitLab发布了13.12.2版本的安全修复后才成为一个问题。

您可以通过GitLab Rails控制台检查和编辑用户帐户的password_expires_at属性。将其设置为nil解决了这个问题,并使LDAP身份验证再次工作。