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


当前回答

每当我被迫修改Windows密码时,上面的答案都帮不了我。

试试下面对我有用的解决方案:

进入Windows凭证管理器。这是通过在EN-US Windows中按下Windows键并输入“credential”来完成的。在其他 本地化的Windows变体,您需要使用本地化术语(请参阅 一些例子的注释)。 您也可以使用快捷方式 control /name微软。运行对话框中的CredentialManager (WIN + R) 编辑Windows凭证下的git条目,替换旧的 用新密码。

其他回答

我想我来晚了一点。但我觉得这对新人有帮助!

我的错误是: remote: HTTP Basic:拒绝访问

remote:你必须为Git在HTTP上使用一个'read_repository'或'write_repository'范围的个人访问令牌。

remote:你可以在https://gitlab.com/profile/personal_access_tokens上生成一个

致命:“https://gitlab.com/PROFILE_NAME/REPO_NAME.git/”认证失败

我用的是Ubuntu,但这对我来说很管用:

转到https://gitlab.com/profile/personal_access_tokens 创建新的令牌和标记检查。 复制令牌 现在转到终端,像这样粘贴它。

git克隆https://oauth2:YOUR_TOKEN@gitlab.com/PROFILE_NAME/REPO_NAME.git/

这当然是一个错误,ssh在我的一台机器上工作,但在另一台机器上不工作。我解出来了,跟着这些。

生成一个永不过期的访问令牌,并选择所有可用选项。 删除已有的SSH密钥。 用https而不是ssh克隆repo。 使用用户名,但使用生成的访问令牌,而不是密码。

或者,您可以在现有的repo中使用此命令将remote设置为HTTP,并使用此命令git remote set-url origin https://gitlab.com/[username]/[repo-name].git

我也有同样的问题,但在我继续执行这里的任何建议之前,我检查了我是否仍然登录到我的github帐户。我在Gitlab账户工作时遇到了这个问题。我发现我仍然登录在我的Github帐户,我立即注销了帐户。我尝试在Gitlab再次克隆,我没有错误,克隆成功。

仅供参考,我在生成并粘贴ssh_rsa后错误地使用URL时遇到了这个问题。pub到gitlab中的SSH密钥。

$ git clone http://gitlab.x
Cloning into 'start-up'...
remote: HTTP Basic: Access denied
remote: You must use a personal access token with 'api' scope for Git over HTTP.
remote: You can generate one at http://gitlab.x

通过使用下面的URL来解决。

$ git clone gitlab@gitlab.xxx.com/your_project.git

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

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

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