git提交代码报443错误之Mac git ssh 的配置和使用

问题:git提交代码或者拉取代码报443错误

之所以出现这种报错是因为git采用了双重验证:密码+SSH

可查看以下文章了解相关内容:
https://github.blog/2020-12-15-token-authentication-requirements-for-git-operations/
https://github.blog/2020-07-30-token-authentication-requirements-for-api-and-git-operations/

Mac解决方案:

git-ssh 配置和使用如下:
1、设置Git的user name和email:(第一次需执行,否则无需执行以下两条命令)

#引号内为git用户名
$ git config --global user.name "***"

#引号内为git邮箱
$ git config --global user.email "***@**.com"

2、生成密钥

#双引号内是你的git内的邮箱
$ ssh-keygen -t rsa -C "***@**.com"

连续3个回车。如果不需要密码的话。
最后得到了两个文件:id_rsa和id_rsa.pub。

在这里插入图片描述

如果不是第一次,就选择overwrite.

在这里插入图片描述

3、添加密钥到ssh-agent
确保 ssh-agent 是可用的。ssh-agent是一种控制用来保存公钥身份验证所使用的私钥的程序,其实ssh-agent就是一个密钥管理器,运行ssh-agent以后,使用ssh-add将私钥交给ssh-agent保管,其他程序需要身份验证的时候可以将验证申请交给ssh-agent来完成整个认证过程。
 

# start the ssh-agent in the background
eval "$(ssh-agent -s)"
Agent pid 59566

添加生成的 SSH key 到 ssh-agent。

$ ssh-add ~/.ssh/id_rsa

在这里插入图片描述

4、登陆Github, 添加 ssh 。
把id_rsa.pub文件里的内容复制到这里 

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

**加粗样式**

5、测试:

$ ssh -T git@github.com

你将会看到:

The authenticity of host 'github.com (207.97.227.239)' can't be established.
RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.
Are you sure you want to continue connecting (yes/no)?

选择 yes

Hi ***! You've successfully authenticated, but GitHub does not provide shell access.

如果看到Hi后面是你的用户名,就说明成功了

在这里插入图片描述

6、最后一步

如果是用sourcetree的话,只需要在设置中修改远程仓库地址即可,如图所示:

只需要

如果你是git命令行操作,执行以下操作:

修改.git文件夹下config中的url。
修改前

[remote "origin"]
url = https://github.com/***/***
fetch = +refs/heads/*:refs/remotes/origin/*

修改后

[remote "origin"]
url = git@github.com:**/**.github.io.git
fetch = +refs/heads/*:refs/remotes/origin/*

 参考:https://blog.csdn.net/lhb_11/article/details/90217640

 

 

### 在Mac系统中为Git配置SSH密钥 在Mac系统中为Git配置SSH密钥是一个相对简单的过程,主要包括生成SSH密钥对、将公钥添加到GitHubGit服务器以及验证连接是否成功。以下是详细的说明: #### 1. 检查现有的SSH密钥 首先需要检查是否存在已有的SSH密钥。打开终端并运行以下命令以查看是否存在默认的SSH密钥文件: ```bash ls -al ~/.ssh ``` 如果看到类似`id_rsa``id_rsa.pub`的文件,则表示已经存在SSH密钥对[^2]。 #### 2. 生成新的SSH密钥 如果没有找到现有的SSH密钥,或者想要生成一个新的密钥对,可以运行以下命令: ```bash ssh-keygen -t rsa -b 4096 -C "[email protected]" ``` 此命令会提示指定保存密钥的位置(通常使用默认路径)以及设置密码(可选)。完成之后,会在`~/.ssh/`目录下生成私钥公钥文件[^3]。 #### 3. 将公钥添加到GitHubGit服务器 复制生成的公钥内容到剪贴板: ```bash pbcopy < ~/.ssh/id_rsa.pub ``` 然后登录到GitHub或其他Git托管服务,在账户设置中找到“SSH and GPG keys”部分,并点击“New SSH key”。将之前复制的内容粘贴到公钥框内,并保存[^4]。 #### 4. 测试SSH连接 为了确保SSH密钥配置正确,可以通过以下命令测试与GitHub的连接: ```bash ssh -T git@github.com ``` 如果一切正常,应该会收到类似下面的消息: ``` Hi username! You've successfully authenticated, but GitHub does not provide shell access. ``` 这表明SSH密钥配置成功[^5]。 #### 5. 配置Git使用SSH 最后确认本地Git仓库是否通过SSH地址克隆。如果是HTTPS地址,可以将其更改为SSH格式: ```bash git remote set-url origin git@github.com:username/repository.git ``` ### 注意事项 - 确保在生成SSH密钥时使用的邮箱与GitHub账户关联。 - 如果遇到权限问题,可能需要调整`.ssh`目录及其内部文件的权限,例如:`chmod 700 ~/.ssh && chmod 600 ~/.ssh/*`[^6]。 ```bash # 调整权限示例 chmod 700 ~/.ssh chmod 600 ~/.ssh/id_rsa chmod 644 ~/.ssh/id_rsa.pub ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值