【Git】保姆级详解:Git配置SSH Key(密钥和公钥)到github

在这里插入图片描述

  • 博主简介:22级计算机科学与技术本科生一枚🌸
  • 博主主页:是瑶瑶子啦
  • 每日一言🌼: “当人们做不到一些事情的时候,他们会对你说你也同样不能。”——《当幸福来敲门》
    克里斯加德纳

一、什么是Git?

Git是一个开源的分布式版本控制系统,可以有效、高速的处理从很小到非常大的项目版本管理1。Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件

在这里插入图片描述

二、什么是SSL?什么是公钥和密钥?

SSH (Secure Shell) 密钥是用于身份验证和加密通信的一对加密密钥。它由两个部分组成:私钥(private key)和公钥(public key)。这对密钥是通过非对称加密算法生成的,其中私钥用于加密数据,而公钥用于解密数据,公钥加密的数据只能用私钥解密,反之亦然

在 SSH 中,私钥应该保存在你的本地计算机上,并且必须保持安全和保密。公钥则可以被分享给其他人或服务器。当你连接到一个远程服务器时,你可以将你的公钥添加到服务器上,以便服务器可以使用该公钥对你的身份进行验证。

当你使用 SSH 协议连接到远程服务器时,身份验证过程如下:

  1. 你的本地计算机向服务器发送请求。

  2. 服务器要求提供身份验证凭据。

  3. 你的本地计算机将使用你的私钥对一个随机生成的数字进行加密,并将加密后的数字发送给服务器。

  4. 服务器使用你之前提供的公钥对加密后的数字进行解密。
    如果解密后的数字与服务器生成的数字匹配,服务器将验证你的身份并允许你登录。
    在这里插入图片描述

使用 SSH 密钥对身份验证具有以下优势:

安全性: SSH 密钥使用非对称加密算法,提供更高的安全性,比密码身份验证更难以被破解。

方便性:你不需要记住复杂的密码,只需要使用你的私钥来访问远程服务器。

可信任性 公钥可以在多个服务器之间共享,而不需要使用相同的密码。

通过生成 SSH 密钥对并将公钥添加到服务器上,你可以实现更安全和方便的远程访问。

三、Git配置

首先打开Git Bash

  • 1.配置用户名和邮箱信息
git config --global user.name “username”
git config --global user.email “email”

注意“username”“email”和前面单词之间有一个空格!

  • 2.生成SSH Key
# 你的Github绑定的邮箱
ssh-keygen -t rsa -C "***@gmail.com"
  • 3.获取SSH Key

根据命令行提示,进入文件夹,获取以ssh-rsa的字符串(包括ssh-rsa)
在这里插入图片描述
在这里插入图片描述

  • 4.在github添加SSH Key

在这里插入图片描述
在这里插入图片描述

title:自定
SSH:复制刚才拷贝的

  • 5.检测是否配置成功
    本地git-bash输入以下命令
$ ssh -T git@github.com

若显示如下,则代表配置成功!🎉🎉🎉
在这里插入图片描述


在这里插入图片描述

### Git生成SSH密钥失败的解决方案 在中文环境下,如果遇到Git生成SSH密钥失败的情况,可能是由于多种原因引起的。以下是详细的解决方案: #### 检查并修复本地环境设置 确保系统的区域语言设置正确无误。有时,操作系统中的字符编码问题可能导致命令行工具无法正常工作。可以尝试更改系统默认的语言地区设置为英文,再进行操作。 #### 验证安装路径与权限 确认使用的Git版本及其安装目录是否存在问题。部分情况下,在`C:\Program Files\GitWP\bin`这样的特殊位置运行可能会因为文件夹权限不足而造成命令执行异常。建议切换至用户的主目录或其他具有写入权限的位置来发起`ssh-keygen`指令[^2]。 #### 处理用户名及环境变量中的潜在冲突 当本机存在含有中文字符的用户名或者其他环境变量时,这可能干扰到SSH密钥的生成过程。可以通过临时修改这些参数或者调整注册表项(仅限Windows平台),以排除此类因素的影响[^3]。 #### 步骤指导:重新生成SSH密钥 为了安全起见,并且考虑到之前的操作未成功,推荐按照标准流程再次尝试创建新的SSH密钥对: ```bash # 执行此命令启动交互式的密钥生成向导 $ ssh-keygen -t rsa -b 4096 -C "your_email@example.com" ``` 在此过程中,可以选择按回车键接受所有的默认选项,除非有特别的需求指定保存位置或设定密码短语。完成上述步骤后,应能在用户家目录下的`.ssh/`子文件夹内找到新产生的私钥(`id_rsa`)对应的公钥(`id_rsa.pub`)。 #### 将公钥添加到远程仓库服务提供商处 最后一步是把刚刚生成的公共密钥上传给目标代码托管站点(Bitbucket/GitHub),以便建立信任关系从而实现无缝的身份验证。具体方法取决于所选的服务商文档说明[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是瑶瑶子啦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值