rage

rage

Rust实现的简单安全文件加密工具 支持多平台

rage是Rust语言实现的age格式文件加密工具,具有简单、安全和跨平台特性。它使用小型显式密钥,无需配置,支持UNIX风格组合。rage可通过多种方式安装,支持多接收者加密、密码保护和SSH密钥兼容。该工具还提供Rust库接口,方便开发者集成。rage采用Apache 2.0或MIT开源许可证发布。

rage文件加密age格式密钥管理跨平台Github开源项目
<p align="center"><img alt="age标志,罗马圣彼得大教堂穹顶的线框图,附有文字:age,文件加密" width="600" src="https://yellow-cdn.veclightyear.com/87312a0a/760c8ae2-bc0a-41af-a71f-1e03463b5707.png"></p> # rage: Rust实现的age加密工具

rage是一个简单、现代且安全的文件加密工具,使用age格式。它具有小巧明确的密钥、无配置选项以及类UNIX的组合性。

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

可互操作的Go参考实现见filippo.io/age

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

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

安装

环境CLI命令
Cargo (Rust 1.65+)cargo install rage
Homebrew (macOS或Linux)brew install rage
Alpine Linux (edge)apk add rage
Arch Linuxpacman -S rage-encryption
DebianDebian软件包
NixOS添加到配置:environment.systemPackages = [ pkgs.rage ];<br>或运行 nix-env -i rage
openSUSE Tumbleweedzypper install rage-encryption
Ubuntu 20.04+Debian软件包
FreeBSDpkg install rage-encryption
Scoop (Windows)scoop bucket add main<br>scoop install main/rage

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

欢迎新的打包者提供帮助。请使用软件包名称rage;只有在使用全局命名空间的软件包系统中不可避免地出现名称冲突时,才应使用备用软件包名称rage-encryption。不要重命名任何二进制文件;相反,使用你的软件包系统的冲突包机制来防止同时安装两个软件包。

使用方法

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

参数:
[输入]  要读取的文件路径。

选项:
-h, --help                    打印此帮助信息并退出。
-V, --version                 打印版本信息并退出。
-e, --encrypt                 加密输入(默认)。
-d, --decrypt                 解密输入。
-p, --passphrase              使用密码而非接收者进行加密。
--max-work-factor <WF>    允许密码解密的最大工作因子。
-a, --armor                   加密为PEM编码格式。
-r, --recipient <接收者>   加密到指定接收者。可重复。
-R, --recipients-file <路径>  加密到路径列出的接收者。可重复。
-i, --identity <身份>     使用身份文件位于身份。可重复。
-j <插件名称>              使用age-plugin-插件名称作为默认模式的身份。
-o, --output <输出>         将结果写入路径输出的文件。

输入默认为标准输入,输出默认为标准输出。
如果输出文件存在,将被覆盖。

接收者可以是:
- 由rage-keygen生成的age公钥("age1...")。
- SSH公钥("ssh-ed25519 AAAA...","ssh-rsa AAAA...")。

路径是包含age接收者的文件路径,每行一个
(忽略"#"开头的注释和空行)。"-"可用于
从标准输入读取接收者。

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

多个接收者

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

$ rage -o example.png.age -r age1uvscypafkkxt6u2gkguxet62cenfmnpc0smzzlyun0lzszfatawq4kvf2u \ -r age1ex4ty8ppg02555at009uwu5vlk5686k3f23e7mac9z093uvzfp8sxr5jum example.png

接收者文件

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

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

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

密码

使用-p/--passphrase可以用密码加密文件。默认情况下,rage会自动生成一个安全的密码。

$ rage -p -o example.png.age example.png 输入密码(留空则自动生成安全密码):[隐藏] 使用自动生成的密码: kiwi-general-undo-bubble-dwarf-dizzy-fame-side-sunset-sibling $ rage -d example.png.age >example.png 输入密码:[隐藏]

如果在$PATH中有名为pinentry的二进制文件,它将用于询问用户密码。可以使用PINENTRY_PROGRAM环境变量设置要使用的二进制文件名或路径。如果没有pinentry二进制文件可用,或PINENTRY_PROGRAM设置为空字符串,rage将回退到CLI。

密码保护的身份文件

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

$ rage -p -o key.age <(rage-keygen)
公钥:age1pymw5hyr39qyuc950tget63aq8vfd52dclj8x7xhm08g6ad86dkserumnz
输入密码(留空则自动生成安全密码):[隐藏]
使用自动生成的密码:
flash-bean-celery-network-curious-flower-salt-amateur-fence-giant
$ rage -r age1pymw5hyr39qyuc950tget63aq8vfd52dclj8x7xhm08g6ad86dkserumnz secrets.txt > secrets.txt.age
$ rage -d -i key.age secrets.txt.age > secrets.txt
输入密码:[隐藏]

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

SSH密钥

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

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

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

功能标志

使用Cargo构建时,可以通过--no-default-features--features comma,separated,flags配置rage,启用或禁用以下功能标志:

  • mount启用rage-mount工具,可以将age加密的TAR或ZIP存档挂载为只读。目前仅在Unix系统上可用,因为它依赖于libfuse
  • ssh(默认启用)支持重用现有SSH密钥文件进行age加密。
  • unstable启用开发中的功能。此功能标志后的任何内容都没有稳定性或互操作性保证。

Rust库

希望将rage作为库使用的应用程序应使用age crate,rage就是建立在它之上的。

许可证

根据以下两种许可之一使用:

由你选择。

贡献

除非你明确声明,否则你有意提交以包含在作品中的任何贡献, 如Apache-2.0许可证中定义,均应按上述方式双重许可, 无任何额外条款或条件。

编辑推荐精选

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

即梦AI

即梦AI

一站式AI创作平台

提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作

扣子-AI办公

扣子-AI办公

AI办公助手,复杂任务高效处理

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
蛙蛙写作

蛙蛙写作

AI小说写作助手,一站式润色、改写、扩写

蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。

AI辅助写作AI工具蛙蛙写作AI写作工具学术助手办公助手营销助手AI助手
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

下拉加载更多