不像这篇文章,我使用的是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”认证失败


当前回答

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

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

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

其他回答

对我来说,它是一些放在配置文件中的其他git URL,所以我手动更改了它:

移动到。git/config文件并编辑它, 删除无效的URL(如果有的话),并像下面这样粘贴有效的git SSH/HTTP URL:

[remote "origin"]
        url = git@gitlab.com:prat3ik/my-project.git

而且它真的起作用了!!

这对我来说很有效:我用Mac,我把路径写在finder上:

~ /图书馆/应用支持/ SourceTree

我删除了认证文件,应该是这样的

yourUserName@STAuth-gitlab.yourAdress

然后尝试从源代码树中推拉代码,结果成功了。

你也可以阅读以下答案:

https://community.atlassian.com/t5/Sourcetree-questions/How-to-update-HTTP-S-credentials-in-sourcetree/qaq-p/297564

注意:不要将GitLab SSL设置和GitLab SSH密钥混合使用。

如果您在GitLab配置文件中配置的是SSH公钥,那么您的HTTPS URL将不会使用它。

关于您的HTTPS证书,请仔细检查:

禁用双因素认证,或 如果您的用户名或密码中有特殊字符,或者 如果你有一个Git凭据助手:Git config凭据。

Mac用户:

去钥匙链和删除gitlab帐户 转到终端的项目路径,简单地键入git pull 然后将要求您输入gitlab的用户名和密码 输入您的用户名,您将在配置文件部分的gitlab帐户中找到该用户名。 然后在这里输入您更新的密码。 开始,再次尝试推动你的代码,它可能会帮助你们。

如果您正在使用git > 2.11并使用Kerberos与Gitlab交互,则需要在本地git中设置此配置,以避免出现remote: HTTP Basic: Access denied错误。

$ git配置——global http。emptyAuth真实