Project Icon

age

简洁高效的跨平台文件加密解决方案

age是一款简单高效的文件加密工具和格式。它采用小型显式密钥设计,无需配置,支持UNIX风格组合使用。age提供多接收者加密、密码保护和SSH密钥兼容等功能,适用于多种操作系统平台。该项目由Benjojo12和FiloSottile设计开发,完整规范可在age-encryption.org查阅。作为开源项目,age为用户提供了一种现代化、安全可靠的文件加密方案。

age标志,罗马圣彼得大教堂的线框图,文字: age,文件加密

Go参考 man页面 C2SP规范

age是一个简单、现代且安全的文件加密工具、格式和Go库。

它具有小巧明确的密钥、无配置选项以及UNIX风格的可组合性。

$ age-keygen -o key.txt
公钥: age1ql3z7hjy54pw3hyww5ayyfg7zqgvc7w3j2elw8zmrj2kg5sfn9aqmcac8p
$ tar cvz ~/data | age -r age1ql3z7hjy54pw3hyww5ayyfg7zqgvc7w3j2elw8zmrj2kg5sfn9aqmcac8p > data.tar.gz.age
$ age --decrypt -i key.txt data.tar.gz.age > data.tar.gz

📜 格式规范在age-encryption.org/v1。age由@Benjojo12@FiloSottile设计。

📬 通过订阅维护者通讯关注本项目的维护情况!

🦀 在github.com/str4d/rage可获得一个可互操作的Rust替代实现。

🔑 通过age-plugin-yubikey插件支持YubiKey等硬件PIV令牌。

✨ 更多插件、实现、工具和集成,请查看awesome age列表。

💬 作者发音为[aɡe̞]硬音g,如同GIF,始终使用小写字母拼写。

安装

Homebrew (macOS或Linux) brew install age
MacPorts port install age
Alpine Linux v3.15+ apk add age
Arch Linux pacman -S age
Debian 12+ (Bookworm) apt install age
Debian 11 (Bullseye) apt install age/bullseye-backports (启用backports以获取age v1.0.0+)
Fedora 33+ dnf install age
Gentoo Linux emerge app-crypt/age
NixOS / Nix nix-env -i age
openSUSE Tumbleweed zypper install age
Ubuntu 22.04+ apt install age
Void Linux xbps-install age
FreeBSD pkg install age (security/age)
OpenBSD 6.7+ pkg_add age (security/age)
Chocolatey (Windows) choco install age.portable
Scoop (Windows) scoop bucket add extras && scoop install age
pkgx pkgx install age

在Windows、Linux、macOS和FreeBSD上,你可以使用预编译的二进制文件。

https://dl.filippo.io/age/latest?for=linux/amd64
https://dl.filippo.io/age/v1.1.1?for=darwin/arm64
...

如果你的系统有支持的Go版本,你可以从源代码构建。

go install filippo.io/age/cmd/...@latest

欢迎新的打包者提供帮助。

验证发布签名

如果你下载预编译的二进制文件,你可以检查它们的Sigsum证明,这类似于带有额外透明度的签名:你可以加密验证每个证明都记录在公共的仅追加日志中,所以你可以让age项目对我们发布的每个二进制文件负责。这与Go校验和数据库提供的类似。

cat << EOF > age-sigsum-key.pub
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIEjDYFJ4WVbxRLcgbppmPaMFS/Wbq+1r9cl4qdJTyRVL
EOF
cat << EOF > sigsum-trust-policy.txt
log 154f49976b59ff09a123675f58cb3e346e0455753c3c3b15d465dcb4f6512b0b https://poc.sigsum.org/jellyfish
witness poc.sigsum.org/nisse 1c25f8a44c635457e2e391d1efbca7d4c2951a0aef06225a881e46b98962ac6c
witness rgdd.se/poc-witness  28c92a5a3a054d317c86fc2eeb6a7ab2054d6217100d0be67ded5b74323c5806
group  demo-quorum-rule all poc.sigsum.org/nisse rgdd.se/poc-witness
quorum demo-quorum-rule
EOF

curl -JO "https://dl.filippo.io/age/v1.2.0?for=darwin/arm64"
curl -JO "https://dl.filippo.io/age/v1.2.0?for=darwin/arm64&proof"

go install sigsum.org/sigsum-go/cmd/sigsum-verify@v0.6.2
sigsum-verify -k age-sigsum-key.pub -p sigsum-trust-policy.txt \
    age-v1.2.0-darwin-arm64.tar.gz.proof < age-v1.2.0-darwin-arm64.tar.gz

你可以在Sigsum文档中了解更多关于上述内容的信息。

使用方法

完整文档请阅读age(1) man页面

用法:
    age [--encrypt] (-r 接收者 | -R 路径)... [--armor] [-o 输出] [输入]
    age [--encrypt] --passphrase [--armor] [-o 输出] [输入]
    age --decrypt [-i 路径]... [-o 输出] [输入]

选项: -e, --encrypt 将输入加密到输出。如果省略则为默认选项。 -d, --decrypt 将输入解密到输出。 -o, --output OUTPUT 将结果写入路径为OUTPUT的文件。 -a, --armor 加密为PEM编码格式。 -p, --passphrase 使用密码进行加密。 -r, --recipient RECIPIENT 加密到指定的RECIPIENT。可重复使用。 -R, --recipients-file PATH 加密到PATH列出的收件人。可重复使用。 -i, --identity PATH 使用PATH处的身份文件。可重复使用。

INPUT默认为标准输入,OUTPUT默认为标准输出。 如果OUTPUT已存在,将被覆盖。

RECIPIENT可以是由age-keygen生成的age公钥("age1...") 或SSH公钥("ssh-ed25519 AAAA...","ssh-rsa AAAA...")。

收件人文件包含一个或多个收件人,每行一个。空行 和以"#"开头的行被忽略作为注释。可使用"-"从标准输入 读取收件人。

身份文件包含一个或多个密钥("AGE-SECRET-KEY-1..."), 每行一个,或一个SSH密钥。空行和以"#"开头的行被 忽略作为注释。可以使用密码加密的age文件作为 身份文件。可以提供多个密钥文件,未使用的将被 忽略。可使用"-"从标准输入读取身份。

当明确指定--encrypt时,-i也可用于对身份文件进行 对称加密,可替代或补充正常的收件人。

多个收件人

文件可以通过重复使用-r/--recipient来加密给多个收件人。每个收件人都能解密该文件。

$ age -o example.jpg.age -r age1ql3z7hjy54pw3hyww5ayyfg7zqgvc7w3j2elw8zmrj2kg5sfn9aqmcac8p \
    -r age1lggyhqrw2nlhcxprm67z43rta597azn8gknawjehu9d9dl0jq3yqqvfafg example.jpg

收件人文件

多个收件人也可以在一个或多个文件中每行列出一个,通过-R/--recipients-file标志传递。

$ cat recipients.txt
# Alice
age1ql3z7hjy54pw3hyww5ayyfg7zqgvc7w3j2elw8zmrj2kg5sfn9aqmcac8p
# Bob
age1lggyhqrw2nlhcxprm67z43rta597azn8gknawjehu9d9dl0jq3yqqvfafg
$ age -R recipients.txt example.jpg > example.jpg.age

如果-R(或-i)的参数是-,则从标准输入读取文件。

密码

可以使用-p/--passphrase用密码加密文件。默认情况下,age会自动生成一个安全的密码。在解密时会自动检测密码保护的文件。

$ age -p secrets.txt > secrets.txt.age
输入密码(留空以自动生成安全密码):
使用自动生成的密码"release-response-step-brand-wrap-ankle-pair-unusual-sword-train"。
$ age -d secrets.txt.age > secrets.txt
输入密码:

密码保护的密钥文件

如果传递给-i的身份文件是密码加密的age文件,它将被自动解密。

$ age-keygen | age -p > key.age
公钥:age1yhm4gctwfmrpz87tdslm550wrx6m79y9f2hdzt0lndjnehwj0ukqrjpyx5
输入密码(留空以自动生成安全密码):
使用自动生成的密码"hip-roast-boring-snake-mention-east-wasp-honey-input-actress"。
$ age -r age1yhm4gctwfmrpz87tdslm550wrx6m79y9f2hdzt0lndjnehwj0ukqrjpyx5 secrets.txt > secrets.txt.age
$ age -d -i key.age secrets.txt.age > secrets.txt
输入身份文件"key.age"的密码:

对于大多数用例,密码保护的身份文件并不必要,因为访问加密的身份文件意味着可以访问整个系统。但是,如果身份文件存储在远程,它们可能会有用。

SSH密钥

作为一个便利功能,age还支持加密到ssh-rsa和ssh-ed25519 SSH公钥,并使用相应的私钥文件解密。(不支持ssh-agent。)

$ age -R ~/.ssh/id_ed25519.pub example.jpg > example.jpg.age
$ age -d -i ~/.ssh/id_ed25519 example.jpg.age > example.jpg

请注意,SSH密钥支持使用更复杂的加密技术,并在加密文件中嵌入公钥标签,使得可以跟踪加密到特定公钥的文件。

加密到GitHub用户

结合SSH密钥支持和-R,您可以轻松地将文件加密到GitHub个人资料上列出的SSH密钥。

$ curl https://github.com/benjojo.keys | age -R - example.jpg > example.jpg.age

请记住,人们可能不会长期保护SSH密钥,因为当仅用于身份验证时它们是可撤销的,而且存储在YubiKey上的SSH密钥无法用于解密文件。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号