每当我尝试推入我的存储库时,git都会要求用户名和密码。

每次重新输入密码没有问题,但问题是输入用户名。我使用https克隆存储库。

那么,我如何配置git,使它在每次git推送时都不需要用户名。

我是linux新手,但windows git push中的IIRC只要求输入密码。


当前回答

请注意,从2021 8月13日开始,github在对Git操作进行身份验证时不再接受帐户密码,并且将要求对github.com上所有经过身份验证的Git操作使用基于令牌的身份验证。您也可以继续使用SSH密钥。

因此,对于必须使用的给定身份验证上下文的用户名静态配置(使用github时):

https://username:<personal-access-tokens>@repository-url.com

请注意,我们使用的是<个人访问令牌>,而不是<密码>

有关如何创建个人访问令牌的详细信息,请查看文档。

github文档称:

HTTPS上的GitHub。。。每次使用Git进行身份验证时GitHub,将提示您输入凭据以进行身份验证使用GitHub,除非您使用凭据助手缓存它们。...使用SSH。。。每次使用Git向GitHub进行身份验证时,除非您已经存储密钥。

github建议通过HTTPS进行连接。可能是因为他们希望您使用Git凭据管理器核心。但是Git凭据管理器核心在Windows和macOS上运行。Linux支持(截至发布时)在早期预览中。

因此,我只提供Git和SSH解决方案。

Git的文档讨论了如何避免反复使用gitcredentials输入相同的凭据。

解决方案1

使用凭据助手缓存密码(在内存中短时间)。

git config --global credential.helper cache

解决方案2

使用凭据助手存储密码(无限期地存储在磁盘上)。

git config --global credential.helper 'store --file ~/.my-credentials'

您可以在文档中找到凭据将保存的位置(如果未使用--file显式设置)。

注:为了解决gitcredentials完全未加密(“原样”)存储凭据的问题,您可以在使用之前始终对文件进行加密和解密。

解决方案3

这几乎是从生成一个新的SSH密钥并将其添加到SSH代理的直接复制粘贴。我认为点击链接会比在这里阅读更好。无论如何,我会在这里复制粘贴命令。

使用ssh keygen-t ed25519-C创建ssh密钥“your_email@example.com“.您也可以使用ssh keygen-t RSA-b 4096-C使用RSA代替Ed25519”your_email@example.com"将SSH密钥添加到GitHub上的帐户。如果未启动,请在后台使用$eval“$(ssh代理-s)”启动ssh代理使用$SSH-Add~/.SSH/id_ed25519将SSH私钥添加到SSH代理。如果您使用不同的名称创建了密钥,或者正在添加具有不同名称的现有密钥,请将命令中的id_ed25519替换为私钥文件的名称。

其他回答

我尝试了这些步骤,结果成功了:

创建个性化访问令牌:https://docs.github.com/en/github/authenticating-to-github/keeping-your-account-and-data-secure/creating-a-personal-access-token将令牌添加到Android studio(文件->设置->版本控制->Github->添加-使用令牌登录)转到文件->设置->版本控制->Git并取消选中“使用凭据助手”

为了避免输入用户名,但仍会提示您输入密码,您可以简单地克隆存储库,包括用户名:

git clone user_name@example.gitrepo.com/my_repo.git

请注意,从2021 8月13日开始,github在对Git操作进行身份验证时不再接受帐户密码,并且将要求对github.com上所有经过身份验证的Git操作使用基于令牌的身份验证。您也可以继续使用SSH密钥。

因此,对于必须使用的给定身份验证上下文的用户名静态配置(使用github时):

https://username:<personal-access-tokens>@repository-url.com

请注意,我们使用的是<个人访问令牌>,而不是<密码>

有关如何创建个人访问令牌的详细信息,请查看文档。

github文档称:

HTTPS上的GitHub。。。每次使用Git进行身份验证时GitHub,将提示您输入凭据以进行身份验证使用GitHub,除非您使用凭据助手缓存它们。...使用SSH。。。每次使用Git向GitHub进行身份验证时,除非您已经存储密钥。

github建议通过HTTPS进行连接。可能是因为他们希望您使用Git凭据管理器核心。但是Git凭据管理器核心在Windows和macOS上运行。Linux支持(截至发布时)在早期预览中。

因此,我只提供Git和SSH解决方案。

Git的文档讨论了如何避免反复使用gitcredentials输入相同的凭据。

解决方案1

使用凭据助手缓存密码(在内存中短时间)。

git config --global credential.helper cache

解决方案2

使用凭据助手存储密码(无限期地存储在磁盘上)。

git config --global credential.helper 'store --file ~/.my-credentials'

您可以在文档中找到凭据将保存的位置(如果未使用--file显式设置)。

注:为了解决gitcredentials完全未加密(“原样”)存储凭据的问题,您可以在使用之前始终对文件进行加密和解密。

解决方案3

这几乎是从生成一个新的SSH密钥并将其添加到SSH代理的直接复制粘贴。我认为点击链接会比在这里阅读更好。无论如何,我会在这里复制粘贴命令。

使用ssh keygen-t ed25519-C创建ssh密钥“your_email@example.com“.您也可以使用ssh keygen-t RSA-b 4096-C使用RSA代替Ed25519”your_email@example.com"将SSH密钥添加到GitHub上的帐户。如果未启动,请在后台使用$eval“$(ssh代理-s)”启动ssh代理使用$SSH-Add~/.SSH/id_ed25519将SSH私钥添加到SSH代理。如果您使用不同的名称创建了密钥,或者正在添加具有不同名称的现有密钥,请将命令中的id_ed25519替换为私钥文件的名称。

git-config credential.helper存储git推/推https://github.com/xxx.git然后输入您的用户名和密码。多恩

设置全天(即24小时)的凭据。

git config --global credential.helper 'cache --timeout=86400'

否则1小时,将86400秒替换为3600秒。

OR

“缓存”身份验证助手的所有配置选项:

git帮助凭据缓存

有关详细信息:https://docs.github.com/en/get-started/getting-started-with-git/caching-your-github-credentials-in-git