Mac下使用SSH(密钥)访问Github

1,终端中输入:cd ~/.ssh 如果出现 -bash: cd: /Users/glamor/.ssh: No such file or directory,说明你之前没有用过。直接执行第二步。

如果之前用过需要清理原来的rsa,执行命令:mkdir key_backup $ cp id_rsa* key_backup $ rm id_rsa*

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #000000; background-color: #ffffff }
span.s1 { }

  Last login: Mon Dec  5 20:27:47 on ttys000

  GlamordeMac-mini:~ glamor$ cd ~/.ssh

  -bash: cd: /Users/glamor/.ssh: No such file or directory

  GlamordeMac-mini:~ glamor$ ssh -keygen -t rsa -c "[email protected]"

  Bad escape character ‘ygen‘.

2,执行命令:ssh-keygen -t rsa -C [email protected]

  GlamordeMac-mini:~ glamor$ ssh-keygen -t rsa -C [email protected]

  Generating public/private rsa key pair.

  Enter file in which to save the key (/Users/glamor/.ssh/id_rsa):

  Created directory ‘/Users/glamor/.ssh‘.

  Enter passphrase (empty for no passphrase):

  Enter same passphrase again:

  Your identification has been saved in /Users/glamor/.ssh/id_rsa.

  Your public key has been saved in /Users/glamor/.ssh/id_rsa.pub.

  The key fingerprint is:

  SHA256:JB+WpQ364sLLU17H8sYoQdIq1YmOWZNntFCdnAftjfI [email protected]

  The key‘s randomart image is:

  +---[RSA 2048]----+

  |     ..oo=.      |

  |    . ..=*o      |

  |     Boo*o.o     |

  |    B O*..o .    |

  |   * B. S+       |

  |  +.o.o.o E      |

  |   .oo.o *       |

  |   ..oo . +      |

  |    o. . .       |

  +----[SHA256]-----+

  GlamordeMac-mini:~ glamor$

3.通过/Users/glamor/.ssh/id_rsa.pub. 路径找到刚刚生成的公钥。如果默认有些隐藏的文件不显示的话,使用 defaults write com.apple.finder AppleShowAllFiles -bool true

命令,如果无法实时生效,建议点击小苹果,强制退出Finder,重启Finder后自然所有文件都看的到。

4,登录Github账号,点击Settings,点进去找到Personal settings。点击SSH and GPG keys。向SSH服务器(github.com)Add自己的SSH Public Key后,github.com将这个SSH Key与

你的github账号关联起来,你的机器(Mac git client)将有写权限向你github账号名下的remote repository进行push提交代码。

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #000000; background-color: #ffffff }
span.s1 { }

点击New SSH key,如图所示:

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #000000; background-color: #ffffff }
span.s1 { }

填写标题,把刚才生成的公钥内容粘贴到Key中。点击Add SSH key。

  

5. 测试连接:ssh -T [email protected] ,出现 Hi JackLearning! You‘ve successfully authenticated, but GitHub does not provide shell access.说明连接成功。

but GitHub does not provide shell access”是因为github提供的HTTPS方式,而不是SSH方式,查一下你设置的git库的remote url,看看使用的是哪种连接方式。

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #000000; background-color: #ffffff }
span.s1 { }

   GlamordeMac-mini:~ glamor$ ssh -T [email protected]

   The authenticity of host ‘github.com (192.30.253.112)‘ can‘t be established.

   RSA key fingerprint is SHA256:nThbg6kXUpJWGl7E1IGOCspRomTxdCARLviKw6E5SY8.

   Are you sure you want to continue connecting (yes/no)? y

   Please type ‘yes‘ or ‘no‘: yes

   Warning: Permanently added ‘github.com,192.30.253.112‘ (RSA) to the list of known hosts.

   Hi JackLearning! You‘ve successfully authenticated, but GitHub does not provide shell access.

6. 设置用户信息。

  

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #000000; background-color: #ffffff }
span.s1 { }

  GlamordeMac-mini:~ glamor$ git config --global user.name "JackLearning"

  GlamordeMac-mini:~ glamor$ git config --global user.email "[email protected]"

7. git clone  yii2

  在配置SSH之前,可以通过:git clone https://github.com/yiisoft/yii2.git 来获得yii开源框架

在配置SSH之后,可以通过:git clone [email protected]:yiisoft/yii2.git 和 git clone https://github.com/yiisoft/yii2.git 来获得yii开源框架

附录:

  Mac上预装的git和OpenSSH  

  SSH——Secure SHell(安全外壳协议)

  SSH是建立在应用层和传输层基础上,默认端口是22,为远程登录会话和其他网络服务提供安全性的协议。SSH是替代Telnet(默认端口是23)和其他远程控制台管理应用程序的行业标准。

  SSH服务最早是由芬兰的一家公司开发的UNIX系统上的一个程序,后来迅速扩展到其他操作平台,现在已经发展到SSH2版本。SSH只是一种协议,存在多种实现,既有商业实现,也有开源实现。由于版权和加密算法等因素的影响,很多人开始转用

  开源免费的openSSH(Linux/Mac OS X标配)。

  SSH提供基于密钥的认证机制,你必须为自己创建一对非对称密钥(public/private key pair),并把公钥放到需要访问的服务器上进行授权。SSH1使用RSA(RonRivest、AdiShamir、LeonardAdleman)加密密钥,SSH2使用

  DSA(Digital Signature Algorithm,数字签名算法)密钥保护连接和认证。RSA和DSA这两种加密算法都是非对称加密算法。

  所谓“SSH公钥认证免密码登录认证机制”,原理如下:

(1)SSH客户端提前将SSH公钥储存在远程SSH服务器上,然后SSH客户端携带公钥向远程SSH服务器(known_hosts)发起登录请求。

(2)远程SSH服务器收到该请求之后,先在该服务器上的authorized_keys寻找你上传授权过的公钥,然后把它和你发送过来的公钥进行比较。

(3)如果两个公钥一致(Key Exchange Success),远程SSH服务器会向用户发送一段使用SSH公钥加密过的随机字符串进行身份质询(Challenge)。

(4)SSH客户端用自己的私钥解密后再发回给远程SSH服务器,远程SSH服务器对比回包中解密出来的随机字符串是否一致。如果一致,则证明用户(公钥或身份)是可信的,直接允许登录shell,不再要求密码。

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #000000; background-color: #ffffff }
span.s1 { }

时间: 2024-10-11 05:23:36

Mac下使用SSH(密钥)访问Github的相关文章

Mac下修改hosts 解决访问github慢的问题

Mac下修改hosts 解决访问github慢的问题 mac下hosts文件在 /etc/hosts.所以先打开终端.然后输入如下命令,打开hosts文件. su vim /etc/hosts 输入mac管理员密码,就可以使用vim打开hosts文件.将如下github的host放到hosts文件中.在 vim 编辑中,按 "i"建进入插入模式,就可以将下面的 hosts 修改粘贴进入到hosts文件中. http://github.com 204.232.175.94 http://

关于Mac下的SSH客户端iterm2等配置

linux后台开发的同学们晓得,在windows下有xshell\securecrt这样优秀的ssh客户端软件.mac下查找了下,有securecrt mac版,网上也有破解的,试用了一段时间,一个问题始终没有能解决——ssh链接偶尔会断掉.关于这个问题,先说下leby的工作环境吧:我们是不能直接ssh目标主机的,必须用ssh代理中转,于是搭建了一个HTTP的proxy,这之前在windows下xshell工作很好.在mac的scrt下,总是会随机掉线,一些超时配置当然是试过的,不能解决问题.

Mac下使用ssh、scp

Windows下我习惯用PUTTY来ssh登录,Mac直接使用Terminal即可. ssh的一些常用命令: 使用root账号登录指定ip的服务器.下面需要把ip换成你自己服务器的ip.ssh [email protected] 如果服务器使用的不是标准端口,比如是4567端口,则是:ssh [email protected] -p 4567 MAC下还有窗口方式: 先打开一个终端,在菜单栏点选 Shell  - 新建远程连接. 这时候会出新一个窗口. 选择安全Shell(ssh),输入服务器i

使用SSH密钥连接Github

使用Github,也许大家觉得比较麻烦的就是在每次push的时候,都需要输入用户名和密码.如果使用SSH,就可以记住用户名,并创建属于自己的密码来保证安全操作,还有神奇的一招可以“不用输入密码”哦.下面将介绍如何创建SSH Keys并将公钥加到GitHub账户中,使用SSH Keys在本机和GitHub之间建立一个安全的连接. 一.Windows环境下生成SSH key且连接GitHub 第一步.看看是否存在SSH密钥(keys) 首先,我们需要看看是否看看本机是否存在SSH keys,打开Gi

添加SSH密钥到GitHub

$ clip < ~/.ssh/id_rsa.pubbash: /c/Users/huangxi/.ssh/id_rsa.pub: No such file or directory [转]Generating SSH keys 生成 SSH 密钥 Step 1.检查本机现有的SSH密钥 检查~/.ssh看看是否有名为d_rsa.pub  和id_dsa.pub的2个文件.如果你什么都没得到这些文件,转到  步骤2 ;否则,请跳到  第3步. 打开你的Git Bash,输入: $ ls -al

Mac 下配置 SSH 免密码安全登录

Win下个人常使用 SecureCRT ,Mac 下感觉 SecureCRT 并不好使,常用 iTerm2+zsh 搭配使用.A连接B 无密码登陆,则A上面执行 ssh-keygen 一路回车,把 ~/.ssh/id_rsa.pub 内容拷贝到B的 ~/.ssh/authorized_keys里面即可### 本地机器创建公钥ssh-keygen -t rsa -C  'your [email protected]'### 复制公钥到ssh服务器使用ssh-copy-id-for-OSX工具将公钥

MAC如何生成SSH key与GitHub关联

一.检查 SSH key 是否存在 在终端输入如下代码: ls -al ~/.ssh 如果没有,终端显示如下: No such file or directory 如果有,终端显示如下: ? ~ ls -al ~/.ssh total 24 drwx------ 5 ant staff 160 1 11 11:12 . drwxr-xr-x+ 91 ant staff 2912 1 11 11:32 .. -rw------- 1 ant staff 1675 1 11 11:09 id_rsa

mac下生成ssh keys 并上传github仓储

使用github仓储需要本机生成一个公钥key 添加到自己的git账户SSH keys中 mac 生成方法: 1. 打开终端 输入 ssh-keygen 然后系统提示输入文件保存位置等信息,连续敲三次回车即可,生成的SSH key文件保存在中-/.ssh/id_rsa.pub 2. 然后用文本编辑工具打开该文件,我用的是vim,所以命令是: vim ~/.ssh/id_rsa.pub 将内容拷贝到github里起个名字就可以了. 注意:拷贝.pub中的内容时候需要将"ssh-rsa"这

Linux下通过SSH无法访问另外一台Linux服务

我们在192.168.5.21的计算机上使用ssh登录192.168.5.20提示错误 我们ping目标计算机192.168.5.20也是通的 而且目标计算机的selinux和防火墙都已经开放了相关端口,为什么登录不了呢 原因:一台主机上有多个Linux系统,会经常切换,那么这些系统使用同一ip,登录过一次后就会把ssh信息记录在本地的~/.ssh/known_hsots文件中,切换该系统后再用ssh访问这台主机就会出现冲突警告,需要手动删除修改known_hsots里面的内容. 另外若是公钥文