SSH 是 Secure Shell 的缩写,由 IETF 的网络小组(Network Working Group)所制定;是建立在应用层基础上的安全协议。

SSH 是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。利用 SSH 协议可以有效防止远程管理过程中的信息泄露问题。

现在大多数 Git 托管平台除了使用 HTTPS 协议连接用户外,还会选择更加安全的 SSH 协议来进行 Git 服务器与用户之间的授权。

检查现有的SSH

为了向 Git 服务器提供 SSH 公钥,用户需要有自己的公钥,如果用户尚未拥有密钥,必须事先生成一份。 这个过程在所有操作系统上都是相似的。首先,你需要确认自己是否已经拥有密钥。

在正式开始之前,建议 Windows 用户使用 Git 程序包自带的 git bash 命令行工具进行操作。

进入 .ssh 目录并列出其中内容,你便可以快速确认自己是否已拥有密钥:

# Linux
$ cd ~/ .ssh
$ ls
> id_rsa id_rsa.pub known_hosts # Windows
$ cd C:/Users/Administrator/.ssh
$ ls
> id_rsa id_rsa.pub known_hosts

以上目录仅为默认目录,不同用户实际目录可能有所不同

关键是看有没有用 something 和 something.pub 来命名的一对文件,这个 something 通常就是 id_dsa 或 id_rsa。有 .pub 后缀的文件就是公钥,另一个文件则是密钥。

生成新的SSH密钥

假如没有这些文件,或者干脆连 .ssh 目录都没有,这个时候你就需要用 ssh-keygen 来进行创建。

$ ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

> The key fingerprint is:
> d0:82:24... Your Email Address 或者是 SHA256:a6d-... Your Email Address

键入命令回车后, ssh-keygen 首先会向你确认密钥的存储位置(牢记)。然后它会要求你输入两次密钥口令。如果你不想在使用密钥时输入口令,将其留空即可。

查看已有密钥

现在,进行完上述操作的用户就可以将各自的公钥配置到 Git 仓库;或者发送给你的 Git 服务器管理员。

通常你只需要复制 .pub 文件的内容用于配置,或者发邮件给管理员。

# Linux
$ cat ~/.ssh/id_rsa.pub
> ssh-rsa AAAAB3NzaC1yc2... == Your Email Address # Windows
$ cd C:/Users/Administrator/.ssh
$ cat id_rsa.pub
> ssh-rsa AAAAB3NzaC1yc2... == Your Email Address

添加SSH密钥

完成上述操作拿到你的密钥之后,你就可以将你的 SSH 密钥添加到你的 Git 仓库。

下边分别以 GitHubCODING 为示例简单介绍一下如何添加 SSH 公钥。

SSH 密钥分为账户密钥和项目密钥,分别用于连接整个账户和连接单个项目。两者的设置是相似的,以下仅对账户 SSH 密钥进行说明。

注:示例图片来自各平台线上帮助文档。

GitHub平台

  1. 复制已经生成的 SSH 密钥。

    1. 如果您的SSH密钥文件的名称与示例代码不同,请修改文件名以匹配当前设置。
    2. 复制密钥时,请勿添加任何换行符或空格。
  2. 登录到你的 GitHub 账号,在任意页面的右上角,点击你的账户头像,然后单击“设置”。

  3. 在用户设置侧栏中,单击SSH和GPG密钥。

  4. 单击“新建SSH密钥”或“添加SSH密钥”。

  5. 在“标题”字段中,为新密钥添加描述性标签。
  6. 将密钥粘贴到“密钥”字段中。

  7. 单击“添加SSH密钥”。

  8. 根据提示,确认您的GitHub密码(如果没有提示可以略过)。

CODING平台

  1. 复制已经生成的 SSH 密钥。

    1. 如果您的 SSH 密钥文件的名称与示例代码不同,请修改文件名以匹配当前设置。
    2. 复制密钥时,请勿添加任何换行符或空格。
  2. 登录到你的 CODING 账号,在页面的右上角,点击你的账户头像,然后单击“个人设置”。
  3. 在用户设置侧栏中,单击 SSH 公钥。
  4. 单击右上角的“新增公钥”。

  5. 将第一步中复制的内容填写到「公钥内容」一栏,公钥名称可随意填写。
  6. 设定公钥有效期,可选择具体日期或设置永久有效。

  7. 单击添加,根据提示,确认您的 CODINNG 密码。

测试SSH链接

完成 SSH 密钥添加后后,你可以对你的连接进行测试,同时建立与 Git 仓库的身份认证。

# GitHub
$ ssh -T git@github.com # CODING
$ ssh -T git@git.coding.net

在验证的过程中系统可能提示你:无法建立主机 github.com / coding.net(IP ADDRESS)的真实性

像这样的:

The authenticity of host github.com (IP ADDRESS) can not be established.
RSA key fingerprint is 16:27:ac...
Are you sure you want to continue connecting (yes/no)?

或者这样的:

The authenticity of host github.com (IP ADDRESS) can not be established.
RSA key fingerprint is SHA256:nThbg6k...
Are you sure you want to continue connecting (yes/no)?

这个时候,你只需要验证您看到的消息中的 RSA 密钥指纹是否与 生成新的 SSH 密钥 中的 RSA 密钥指纹匹配,然后输入yes即可:

# GitHub
Hi yourname! You hove successfully authenticated. # CODING
Hello yourname! You hove connected to Coding.net by SSH successfully!

当验证生成的消息返回并包含您的用户名,就说明 SSH 公钥设置成功。

如何配置 SSH 密钥连接 Git 仓库的更多相关文章

  1. [原创]SSH密钥访问Git仓库配置

    SSH密钥并非为了解决拉取git仓库代码时,需要频繁输入密码的问题. SSH是一种比较安全的协议,可以用来免去远程登录Linux等服务器时需要输入密码的繁琐过程. 命令: ssh user@serve ...

  2. 使用TortoiseGit,设置ssh方式连接git仓库。

    开始设置之前的准备:建立项目文件夹,初始化git仓库(右键 git  init),右键打开 git bash ,git pull “仓库地址”, 把网站上的仓库代码拉取下来. TortoiseGit使 ...

  3. mac系统下用ssh方式连接git仓库

    1.应用程序-终端,键入命令  ssh-keygen -t rsa -C "xxxxx@xxxxx.com"  ,后面是你的邮箱地址.一直回车,生成密钥. 2.键入  open ~ ...

  4. Sourcetree配置ssh密钥 - git图形化工具(二)

    这里主要介绍Sourcetree如何导入已经生成好的ssh私钥,如何生成ssh私钥自行百度. 如果Sourcetree没有配置ssh密钥,克隆时会提示如下错误: 仓库类型:这是一个无效的源路径/URL ...

  5. 使用SSH密钥连接Github

    使用Github,也许大家觉得比较麻烦的就是在每次push的时候,都需要输入用户名和密码.如果使用SSH,就可以记住用户名,并创建属于自己 的密码来保证安全操作,还有神奇的一招可以“不用输入密码”哦. ...

  6. Jenkins连接Git仓库时候报错Permission denied, please try again.

    一.连接GIT仓库报错 Failed to connect to repository : Command : stdout: stderr: Permission denied, please tr ...

  7. CentOS配置SSH远程连接

    本文为大家介绍Centos中配置SSH远程连接的方法,只是简单配置,供初学者参考. 1.配置IP#setup 选择 NetWork configuration 选择 Device configurat ...

  8. Git管理多个SSH密钥,Git多帐号配置

    版权声明:转载须标明本文转自严振杰的博客 https://blog.csdn.net/yanzhenjie1003/article/details/69487932版权声明:转载必须注明本文转自严振杰 ...

  9. github配置ssh密钥的方法

    配置用户名和邮箱 初次安装git需要配置用户名和邮箱,否则git会提示:please tell me who you are. 你需要运行命令来配置你的用户名和邮箱: $ git config --g ...

随机推荐

  1. 给自己挖坑——DateWay

    参考文章 官方手册 官方博客 填坑 目录 简介 使用 1. 引入相关依赖 2. 配置 Dataway,并初始化数据表 3. 配置数据源 4. 把数据源设置到 Hasor 容器中 5. 在SprintB ...

  2. setTimeout、clearTimeout、setInterval

    setTimeout(cb, ms) setTimeout(cb, ms) 全局函数在指定的毫秒(ms)数后执行指定函数(cb).:setTimeout() 只执行一次指定函数. 返回一个代表定时器的 ...

  3. 机器学习笔记簿 降维篇 LDA 01

    机器学习中包含了两种相对应的学习类型:无监督学习和监督学习.无监督学习指的是让机器只从数据出发,挖掘数据本身的特性,对数据进行处理,PCA就属于无监督学习,因为它只根据数据自身来构造投影矩阵.而监督学 ...

  4. 一次django内存异常排查

    起因 Django 作为 Python著名的Web框架,相信很多人都在用,自己工作中也有项目项目在用,而在最近几天的使用中发现,部署Django程序的服务器出现了内存问题,现象就是运行一段时间之后,内 ...

  5. 字节数组X中存放着 0~F共16个十六进制数,请将这些数以十六进制形式显示在屏幕上。

    问题 字节数组X中存放着 0~F共16个十六进制数,请将这些数以十六进制形式显示在屏幕上. 代码 data segment x db 0,1,2,3,4,5,6,7,8,9,0ah,0bh,0eh,0 ...

  6. Python os.unlink() 方法

    概述 os.unlink() 方法用于删除文件,如果文件是一个目录则返回一个错误.高佣联盟 www.cgewang.com 语法 unlink()方法语法格式如下: os.unlink(path) 参 ...

  7. PHP readlink() 函数

    定义和用法 readlink() 函数返回符号连接的目标. 如果成功,该函数返回连接的目标.如果失败,则返回 FALSE. 语法 readlink(linkpath) 参数 描述 linkpath 必 ...

  8. PHP stat() 函数

    定义和用法 stat() 函数返回关于文件的信息. 该函数将返回一个包含下列元素的数组: [0] 或 [dev] - 设备编号 [1] 或 [ino] - inode 编号 [2] 或 [mode] ...

  9. PHP hex2bin() 函数

    实例 把十六进制值转换为 ASCII 字符: <?phpecho hex2bin("48656c6c6f20576f726c6421");?> 以上实例输出结果: He ...

  10. 牛客练习赛60 D 斩杀线计算大师

    LINK:斩杀线计算大师 给出a,b,c三个值 求出 ax+by+cz=k的x,y,z的正整数解 保证一定有解. 考虑两个数的时候 ax+by=k 扩展欧几里得可以解决. 三个数的时候 一个暴力的想法 ...