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


当前回答

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

其他回答

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

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

我的错误是: 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/

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

git config --system --unset credential.helper

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

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

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

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

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