当前位置:   article > 正文

【GIT】GitHub密钥SSH keys添加_git ssh keys

git ssh keys

一、SSH密钥检查 

在生成SSH密钥之前,可以检查是否有任何现有的SSH密钥。

  • Mac打开终端:

  • 输入ls -al ~/.ssh以查看是否存在现有的SSH密钥。

    1. $ ls -al ~/.ssh
    2. # Lists the files in your .ssh directory, if they exist
  • Windows打开Git Bash:

  • 输入ls -al ~/.ssh以查看是否存在现有的SSH密钥。

    1. $ ls -al ~/.ssh
    2. # Lists the files in your .ssh directory, if they exist
  • Linux打开:

  • 输入ls -al ~/.ssh以查看是否存在现有的SSH密钥。

    1. $ ls -al ~/.ssh
    2. # Lists the files in your .ssh directory, if they exist

 检查目录列表,看看您是否已经有一个公共SSH密钥。默认情况下,GitHub支持的公钥的文件名是以下之一。

  • 提示:如果您收到~/.ssh不存在的错误,则默认位置中没有现有的SSH密钥对。您可以在下一步中创建新的SSH密钥对。

    • id_rsa.pub
    • id_ecdsa.pub
    • id_ed25519.pub​​​​​​​​​​​​​​

二、SSH密钥生成

生成SSH密钥时,可以添加密码来进一步保护密钥。当使用密钥时,必须输入密码。如果密钥有密码,并且不想每次使用密钥时都输入密码,可以将密钥添加到SSH代理中。SSH代理管理你的SSH密钥并记住你的密码。

可以在本地机器上生成新的SSH密钥。生成密钥后,可以在GitHub.com上将公钥添加到帐户中,以启用通过SSH对Git操作进行身份验证。

  • Mac打开终端:

  1. 粘贴下面的文本,用您的GitHub电子邮件地址替换示例中使用的电子邮件。

    ssh-keygen -t ed25519 -C "your_email@example.com"
    

    注意:如果您使用的是不支持Ed25519算法的传统系统,请使用:

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

    这将使用提供的电子邮件作为标签创建一个新的SSH密钥。

    > Generating public/private ALGORITHM key pair.
    

    当提示“输入要保存密钥的文件”时,可以按Enter键接受默认文件位置。请注意,如果之前创建了SSH密钥,ssh-keygen可能会要求重写另一个密钥,在这种情况下,建议创建自定义命名的SSH密钥。为此,请键入默认文件位置,并将id_ALGORITHM替换为你自定义密钥名称。

    > Enter a file in which to save the key (/Users/YOU/.ssh/id_ALGORITHM): [Press enter]
    
  2. 在提示符处,键入安全密码。

    1. > Enter passphrase (empty for no passphrase): [Type a passphrase]
    2. > Enter same passphrase again: [Type passphrase again]
  • Windows打开: 

  • 粘贴下面的文本,用GitHub电子邮件地址替换示例中使用的电子邮件。

    ssh-keygen -t ed25519 -C "your_email@example.com"
    

    注意:如果使用的是不支持Ed25519算法的传统系统,请使用:

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

    这将使用提供的电子邮件作为标签创建一个新的SSH密钥。

    > Generating public/private ALGORITHM key pair.
    

    当提示“输入要保存密钥的文件”时,可以按Enter键接受默认文件位置。请注意,如果之前创建了SSH密钥,ssh-keygen可能会要求重写另一个密钥,在这种情况下,我们建议创建自定义命名的SSH密钥。为此,请键入默认文件位置,并将id_ALGORITHM替换为自定义密钥名称。

    > Enter a file in which to save the key (/c/Users/YOU/.ssh/id_ALGORITHM):[Press enter]
    
  • 在提示符处,键入安全密码。

    1. > Enter passphrase (empty for no passphrase): [Type a passphrase]
    2. > Enter same passphrase again: [Type passphrase again]
  • Linux打开: 

  • 粘贴下面的文本,用GitHub电子邮件地址替换示例中使用的电子邮件。

    ssh-keygen -t ed25519 -C "your_email@example.com"
    

    注意:如果使用的是不支持Ed25519算法的传统系统,请使用:

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

    这将使用提供的电子邮件作为标签创建一个新的SSH密钥。

    > Generating public/private ALGORITHM key pair.
    

    当提示“输入要保存密钥的文件”时,可以按Enter键接受默认文件位置。请注意,如果之前创建了SSH密钥,ssh-keygen可能会要求重写另一个密钥,在这种情况下,建议创建自定义命名的SSH密钥。为此,请键入默认文件位置,并将id_ALGORITHM替换为自定义密钥名称。

    > Enter a file in which to save the key (/home/YOU/.ssh/ALGORITHM):[Press enter]
    
  • 在提示符处,键入安全密码。

    1. > Enter passphrase (empty for no passphrase): [Type a passphrase]
    2. > Enter same passphrase again: [Type passphrase again]

三、​​​​​​​向SSH代理添加新的SSH密钥 

  • Mac打开终端:

  • 在后台启动ssh代理。

    1. $ eval "$(ssh-agent -s)"
    2. > Agent pid 59566

    根据环境,可能需要使用不同的命令。例如,在启动ssh-agent之前,可能需要通过运行sudo -s -H来使用root访问,或者可能需要使用exec ssh-agent bashexec ssh-agent zsh来运行ssh-agent。

  • 如果使用的是macOS Sierra 10.12.2或更高版本,则需要修改~/.ssh/config文件以自动将密钥加载到ssh代理中并将密码存储在钥匙串中。

    • 首先,检查~/.ssh/config文件是否存在于默认位置。

      1. $ open ~/.ssh/config
      2. > The file /Users/YOU/.ssh/config does not exist.
    • 如果文件不存在,请创建该文件。

      touch ~/.ssh/config
      
    • 打开~/.ssh/config文件,然后修改文件以包含以下行。如果SSH密钥文件的名称或路径与示例代码不同,请修改文件名或路径以匹配当前的设置。

      1. Host github.com
      2. AddKeysToAgent yes
      3. UseKeychain yes
      4. IdentityFile ~/.ssh/id_ed25519

      备注:

      • 如果选择不为密钥添加密码,则应省略UseKeychain行。

      • 如果看到Bad configuration option: usekeychain错误,请在配置的Host *.github.com部分添加一行。

        1. Host github.com
        2. IgnoreUnknown UseKeychain
  • 将的SSH私钥添加到ssh代理中,并将密码存储在钥匙串中。如果使用不同的名称创建了密钥,或者如果正在添加具有不同名称的现有密钥,请将命令中的id_ed25519替换为的私钥文件的名称。

    ssh-add --apple-use-keychain ~/.ssh/id_ed25519
    

    注意:当将SSH密钥添加到ssh代理时,--apple-use-keychain选项会将密码存储在钥匙串中。如果选择不向密钥添加密码,请在不使用--apple-use-keychain选项的情况下运行该命令。

    --apple-use-keychain选项在苹果的标准版本的ssh-add。在Monterey(12.0)之前的MacOS版本中,--apple-use-keychain--apple-load-keychain标志分别使用语法-K-A

    如果没有安装苹果的标准版本ssh-add,可能会收到错误。

    如果继续收到输入密码的提示,可能需要将该命令添加到~/.zshrc文件(或bash的~/.bashrc文件)。

  • Windows打开: 

          如果安装了GitHub Desktop可以使用它来克隆存储库,而不是处理SSH密钥。

  1. 在新的管理提升终端窗口(PowerShell或CMD)中,确保ssh代理正在运行。可以使用“自动启动ssh代理”说明使用SSH密钥密码”,或手动启动它:

    1. # start the ssh-agent in the background
    2. Get-Service -Name ssh-agent | Set-Service -StartupType Manual
    3. Start-Service ssh-agent
  2. 在没有提升权限的终端窗口中,将SSH私钥添加到ssh代理中。如果使用不同的名称创建了密钥,或者如果正在添加具有不同名称的现有密钥,请将命令中的id_ed25519替换为私钥文件的名称。

    ssh-add C:\Users\YOU/.ssh/id_ed25519
    
  • Linux打开: 

  • 在后台启动ssh代理。

    1. $ eval "$(ssh-agent -s)"
    2. > Agent pid 59566

    根据环境,可能需要使用不同的命令。例如,在启动ssh-agent之前,可能需要通过运行sudo -s -H来使用root访问,或者您可能需要使用exec ssh-agent bashexec ssh-agent zsh来运行ssh-agent。

  • 将SSH私钥添加到ssh代理中。

    如果使用不同的名称创建了密钥,或者如果正在添加具有不同名称的现有密钥,请将命令中的id_ed25519替换为你的私钥文件的名称。

    ssh-add ~/.ssh/id_ed25519
    

四、SSH公钥添加到GitHub上的帐户中 

上一步生成密钥之后,会提示“Your public key has been saved in xxx”,把xxx里面的内容             复制出来。

 

  • 登录GitHub,进入Settings页面

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/374749
推荐阅读
相关标签
  

闽ICP备14008679号