github中的SSH and GPG keys

在GitHub中,SSH和GPG密钥是用于提高账户和代码安全性的两种主要工具。以下是详细介绍:

SSH Keys

SSH(Secure Shell)密钥是一种加密密钥,用于在你的计算机和GitHub之间建立安全连接。通过SSH密钥,可以在无需输入用户名和密码的情况下与GitHub进行安全通信。

设置SSH密钥的步骤:
  1. 生成SSH密钥对

    • 在本地计算机上打开终端或命令行工具。

    • 运行以下命令来生成新的SSH密钥对:

      bash 复制代码
      ssh-keygen -t ed25519 -C "your_email@example.com"

      如果你的系统不支持ed25519算法,可以使用rsa

      bash 复制代码
      ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
    • 按提示操作并保存密钥文件。

  2. 添加SSH密钥到SSH代理

    • 确保SSH代理正在运行:

      bash 复制代码
      eval "$(ssh-agent -s)"
    • 将SSH私钥添加到SSH代理:

      bash 复制代码
      ssh-add ~/.ssh/id_ed25519
  3. 将SSH公钥添加到GitHub

    • 复制SSH公钥到剪贴板:

      bash 复制代码
      cat ~/.ssh/id_ed25519.pub
    • 登录到GitHub,进入"Settings"。

    • 在左侧菜单中选择"SSH and GPG keys",点击"New SSH key"。

    • 将公钥粘贴到Key字段中,点击"Add SSH key"。

  4. 测试SSH连接

    • 运行以下命令测试是否成功连接到GitHub:

      bash 复制代码
      ssh -T git@github.com

GPG Keys

GPG(GNU Privacy Guard)密钥用于对Git提交进行签名,以验证提交的真实性和完整性。通过使用GPG密钥,可以确保代码提交确实是由你本人完成的,并且在传输过程中没有被篡改。

设置GPG密钥的步骤:
  1. 生成GPG密钥对

    • 在本地计算机上打开终端或命令行工具。

    • 运行以下命令生成GPG密钥对:

      bash 复制代码
      gpg --full-generate-key
    • 按提示操作并选择合适的选项(一般选择RSA和RSA,长度4096,密钥有效期可以根据需要设置)。

  2. 获取GPG密钥ID

    • 运行以下命令查看生成的GPG密钥:

      bash 复制代码
      gpg --list-secret-keys --keyid-format LONG
    • 找到类似sec rsa4096/XXXXXXXXXXXXXXXX 2021-01-01 [SCA]的输出,其中XXXXXXXXXXXXXXXX就是你的GPG密钥ID。

  3. 导出GPG公钥并添加到GitHub

    • 运行以下命令导出GPG公钥:

      bash 复制代码
      gpg --armor --export XXXXXXXXXXXXXXXX
    • 复制输出的公钥内容。

    • 登录到GitHub,进入"Settings"。

    • 在左侧菜单中选择"SSH and GPG keys",点击"New GPG key"。

    • 将公钥粘贴到Key字段中,点击"Add GPG key"。

  4. 配置Git使用GPG签名

    • 运行以下命令配置Git使用你的GPG密钥进行签名:

      bash 复制代码
      git config --global user.signingkey XXXXXXXXXXXXXXXX
      git config --global commit.gpgSign true
验证GPG签名:
  • 在提交代码时,使用-S选项来签名:

    bash 复制代码
    git commit -S -m "Your commit message"

通过配置和使用SSH和GPG密钥,你可以大大增强GitHub账户和代码仓库的安全性,确保代码传输和提交的安全性和真实性。

相关推荐
君穆南2 小时前
基于 NFS 与 Rsync 实现跨服务器 Seafile 数据平滑迁移实战
linux·运维·git
bloglin999992 小时前
scp、rsync远程文件同步
linux·运维·服务器
迦南的迦 亚索的索2 小时前
LINUX环境
linux·运维·服务器
yuanjj882 小时前
linux下调试域格CLM920 NC5等9x07平台模块 QMI拨号
linux·运维·服务器
IMPYLH3 小时前
Linux 的 printenv 命令
linux·运维·服务器·bash
SilentSamsara3 小时前
SSH 远程管理:密钥登录 + 隧道转发,一次性配置好
linux·运维·服务器·ubuntu·centos·ssh
Jurio.3 小时前
本机开发 + 多机执行的极简远端运行工具
linux·git·python·github·远程工作
Cx330❀4 小时前
Linux命名管道(FIFO)通信:从原理到实操,一文搞懂跨进程通信
大数据·linux·运维·服务器·elasticsearch·搜索引擎
嵌入式×边缘AI:打怪升级日志4 小时前
嵌入式Linux应用开发快速入门(从零到第一个程序)
linux·运维·notepad++
AI、少年郎5 小时前
MiniMind第 2 篇:破除大模型 “神秘感“, 环境搭建|Win/Linux 本地快速部署
linux·运维·服务器·ai·大模型训练·大模型微调·大模型原理