GPG 用法
GPG (GnuPG) 是一种加密工具,用于数据加密和数字签名。
密钥配置
# 生成密钥
gpg --full-generate-key
# 列出密钥
gpg --list-keys # 列出公钥
gpg --list-secret-keys # 列出私钥
# 导出密钥
gpg --armor --export [email/ID] > public.asc # 导出公钥
gpg --export-secret-keys -a [email/ID] > private.asc # 导出私钥
gpg --dearmor <key_file> # 将文本密钥转换为二进制密钥
# 导入密钥
gpg --import [key_file] # 导入密钥
gpg --sign-key [email/ID] # 为导入的密钥签名(信任)
# 删除密钥
gpg --delete-key [email/ID] # 删除公钥
gpg --delete-secret-key [email/ID] # 删除私钥
# 编辑密钥
gpg --edit-key [email/ID]
# 更改密钥密码
gpg --passwd [email/ID]
密钥 ID 是密钥指纹的后 8 位或者后 16 位,或者完整的密钥指纹。三者之一都可以用来表示密钥 ID。
加密/签名
# 加密
gpg --recipient [email/ID] --encrypt [input_file] # 将生成一个 .gpg 文件,包含了加密的文件
# 解密
gpg --decrypt [gpg_file] > [output_file]
# 签名
gpg --sign --local-user [email/ID] [input_file] # 将生成一个 .gpg 文件,包含了明文文件和文件签名
## 使用分离签名
gpg --detach-sign --local-user [email/ID] [input_file] # 将生成一个 .sig 二进制文件
gpg --armor --detach-sign --local-user [email/ID] [input_file] # 将生成一个 .asc 文本文件
# 验证签名
gpg --verify [signature_file] [input_file] # 可以省略 input_file,此时会以 signature_file 的文件名推测输入文件名
# 另外,也可以使用 --decrypt 在解密的同时验证签名
# 签名并加密
gpg --sign --recipient [email/ID] --encrypt [input_file]
# 解密并验证签名(和仅解密的命令一样)
gpg --decrypt [gpg_file] > [outputfile]
使用样例
列出所有公钥
$ gpg --list-keys
[keyboxd]
---------
pub ed25519 2023-12-28 [SC]
564B356F76DEDA922C87D9A6ADA20CA03D7C43B
uid [ 绝对 ] User Name (Default GPG Key) <example@email.com>
sub cv25519 2023-12-28 [E]
pub
: 这行表示一个公钥 (pubkey) 的记录开始。ed25519
: 这是公钥使用的加密算法,ed25519 是一个采用 Edwards-curve Digital Signature Algorithm (EdDSA) 的签名算法,它著名的特点是速度快且安全。这种算法特别适用于创建数字签名。2023-12-28
: 这个日期是公钥的生成日期。[SC]
: 这里的 S 表示签名(Sign),C 表示证书(Certify)。这意味着这个公钥可以用于数字签名和证书其他密钥。564B356F76DEDA922C87D9A6ADA20CA03D7C43B
: 这是公钥的指纹,是识别公钥的一种更精确的方式。它是公钥的一个散列值,可用于在密钥服务器上查找公钥或验证公钥。uid
: 这个字段代表用户身份(User ID),包括名称和电子邮件地址。在这个例子中,表示公钥的拥有者是 “User Name” 且电子邮件地址为 “example@email.com”。[ 绝对 ]
: 这表明信任级别为 “绝对”。在 GPG 中,你可以给一个密钥指定信任级别,以标识你对此密钥所有人身份验证的信任程度。“绝对” 表示你完全信任此密钥。sub
: 这表示一个附属密钥 (subkey),它关联到上面的主公钥。附属密钥可以用于加密,而主密钥仍然保持签名和证书的任务。cv25519
: 这是附属密钥使用的加密算法,Curve25519 是一种用于创建公钥加密密钥的算法。cv25519 通常用于加密。[E]
: 这表示这个附属密钥用于加密 (Encrypt)。
总的来说,这个输出表示你有一个用 ed25519 算法生成的 GPG 主公钥,它在 2023 年 12 月 28 日生成,并有一个用户身份名为 “User Name” 和对应的电子邮件地址。你还有一个用 cv25519 算法生成的附属密钥用于加密,它也是在同一天生成的。
列出所有私钥
$ gpg --list-secret-keys
[keyboxd]
---------
sec ed25519 2023-12-28 [SC]
564B356F76DEDA922C87D9A6ADA20CA03D7C43B
uid [ 绝对 ] User Name (Default GPG Key) <example@email.com>
ssb cv25519 2023-12-28 [E]
keyboxd
部分是内部的,通常你不需要关心;它跟 GPG 的密钥存储有关。sec
表示这是一段私钥(secret key)的信息。ed25519 是私钥使用的加密算法,这里采用的是 Ed25519,一种基于 EdDSA 签名算法的公钥加密算法。Ed25519 被认为是非常安全的,主要用于签名操作。2023-12-28
表示私钥的生成日期是 2023 年 12 月 28 日。[SC]
表示这把私钥具有签名(S)和证书(C)的能力。签名用于保护信息和验证作者的身份,而证书能力意味着这把钥匙可以用来为其他的公钥签名,建立信任网络。56EBD36FC71AEDC622DE749A43DA00CC0D17643C
是私钥的指纹。这是一个独特的标识,用于确切地指代这把私钥。在 GPG 的使用中,指纹用来验证密钥的真实性。uid
表示用户 ID,这是密钥所有者的身份说明。[ 绝对 ] 表示对该密钥的信任等级是绝对的,即这把密钥完全被信任。User Name (Default GPG Key) example@email.com 包含名字、评论(这里用作标识默认的 GPG 密钥)、以及电子邮件地址,这是用来标识密钥所有者的信息。ssb
是指私钥下的子密钥(secret subkey)。cv25519 指明了子密钥使用的加密算法是 Curve25519,这通常用于加密操作。2023-12-28 是子密钥的生成日期。[E]
表示子密钥的用途是加密(E)。
加密文件
gpg --recipient example@email.com --encrypt my_file
解密文件
gpg --decrypt my_file.gpg > my_file
对文件签名
gpg --armor --detach-sign --local-user example@email.com my_file
--local-user
及之后的 email/ID 可以省略
验证文件签名
gpg --verify myfile.asc my_file
my_file
可以省略
GPG 用法的更多相关文章
- gpg签名用法
– 在CentOS 6上生成公钥/私钥对 [root@localhost ~]# gpg --gen-key gpg (GnuPG) ; Copyright (C) Free Software Fou ...
- Git的用法
Git的用法 Git 的也可以理解为版本控制器.版本控制器(维基的解释):维护工程蓝图的标准作法,能追踪工程蓝图从诞生一直到定案的过程.此外,版本控制也是一种软件工程技巧,借此能在软件开发的过程中,确 ...
- [Linux] yum和apt-get用法及区别
一般来说著名的linux系统基本上分两大类: 1.RedHat系列:Redhat.Centos.Fedora等 2.Debian系列:Debian.Ubuntu等 RedHat 系列 1 常见的安装包 ...
- git用法
chapter: 8 add 添加文件内容至索引 用法:git add [选项] [--] ... -n, --dry-run 演习 -v, --verbose 冗长输出 -i, --interact ...
- Linux中yum和apt-get用法及区别
Linux中yum和apt-get用法及区别 一般来说著名的linux系统基本上分两大类: 1.RedHat系列:Redhat.Centos.Fedora等 2.Debian系列:Debi ...
- (转载)OC学习篇之---协议的概念和用法
在前一篇文章中我们介绍了OC中类的延展,这一篇文章我们在来看一下OC中协议的概念以及用法,协议也是OC中的一个重点,Foundation框架以及我们后面在写代码都会用到. OC中的协议就是相当于Jav ...
- RPM常见用法
rpm常见的用法: 命令 说明 rpm -i <.rpm file name> 安装指定的 .rpm 文件 rpm -U <.rpm file name> 用指定的.rpm文件 ...
- git基本用法
基本用法(下) 一.实验说明 本节实验为 Git 入门第二个实验,继续练习最常用的git命令. 1.1 实验准备 在进行该实验之前,可以先clone一个练习项目gitproject ...
- java continue break 关键字 详解 区别 用法 标记 标签 使用 示例 联系
本文关键词: java continue break 关键字 详解 区别 用法 标记 标签 使用 示例 联系 跳出循环 带标签的continue和break 嵌套循环 深入continue ...
- gpg的使用
[gpg的使用] 在Linux系统中,gpg程序可以实现非对称加密. 下面简单介绍gpg命令的用法:一.创建密钥:$ gpg --gen-key Please select what kind of ...
随机推荐
- Nuxt3 的生命周期和钩子函数(七)
title: Nuxt3 的生命周期和钩子函数(七) date: 2024/6/30 updated: 2024/6/30 author: cmdragon excerpt: 摘要:文章阐述了Nuxt ...
- 手把手带你使用JWT实现单点登录
JWT(英文全名:JSON Web Token)是目前最流行的跨域身份验证解决方案之一,今天我们一起来揭开它神秘的面纱! 一.故事起源 说起 JWT,我们先来谈一谈基于传统session认证的方案以及 ...
- OPC 详解 第一篇 基础概念
一 .概述 OPC 的全称是OPC(OLE for Process Control), 用于过程控制的OLE,OLE(Object Linking and Embedding)大家都知道是对象连接与嵌 ...
- 用StabilityMatrix一键安装Stable Diffusion
Stable Diffusion是2022年发布的深度学习文字到图像生成模型,它既能免费使用,又能部署在本地端,又有非常多的模型可以直接套用,在使用体验上比Midjourney和DALL-E更加强大. ...
- Solo 开发者周刊 (第8期):Claude公司再度上新产品,成交额将超73亿美元
这里会整合 Solo 社区每周推广内容.产品模块或活动投稿,每周五发布.在这期周刊中,我们将深入探讨开源软件产品的开发旅程,分享来自一线独立开发者的经验和见解.本杂志开源,欢迎投稿. 好文推荐 Cla ...
- 开源免费又好用的中式数据报表:UReport2是一款高性能的架构在Spring之上纯Java报表引擎,通过迭代单元格可以实现任意复杂的中国式报表。
北润乾.南帆软,数加发力在云端. uReport 身何安?中式报表真开源. 报表江湖之中,uReport安身立命的产品品类定位是什么? 说来很简单,uReport的价值在于填补了这样一个市场空白:开源 ...
- 【原创软件】第2期:CAD文字快速批量替换工具CFR(CAD_FastReplace_V4)
01 背景 由于工作需要,开发了一套CAD文字快速批量替换软件CFR.主要目的是:实现dwg文件一次性完成单对/多对词组快速批量替换. 02 主要功能特色 (1)无需打开CAD,快速实现文字批量替换. ...
- AT_arc154_b 题解
洛谷链接&Atcoder 链接 本篇题解为此题较简单做法及较少码量,并且码风优良,请放心阅读. 题目简述 给定两个长度为 \(n\) 的字符串 \(S,T\),定义一次操作可取出 \(S\) ...
- 数组的创建-数组-C
数组内存是连续的 数组是一个整体,它的内存是连续的:也就是说,数组元素之间是相互挨着的,彼此之间没有一点点缝隙.下图演示了int a[4];在内存中的存储情形: 「数组内存是连续的」这一点很重要,所以 ...
- Docker Engine在Centos下的安装
实践环境 Centos7.8 先决条件 CentOS 7.8. 必须开启 centos-extrasyum仓库源.默认是开启的,如果关闭了,需要重新开启,如下 编辑 /etc/yum.repos.d/ ...