我开发了一个在运行时加载到配置文件中的工具。某些值使用 AES 密钥加密。
该工具将被安排在远程机器上定期运行。向程序提供解密密钥的可接受方式是什么。它有一个命令行界面,我可以通过它。我目前可以看到三个选项
通过 CLI 提供完整的密钥,这意味着密钥在操作系统配置级别(即 CronJob)清晰可用
通过源代码将密钥硬编码到二进制文件中。由于多种原因,这不是一个好主意。(反编译和便携性较差)
使用的组合1
,并2
即有在EXE基地键,然后接受通过CLI部分关键。这样我可以在多台机器上使用相同的build,但是并没有解决反编译exe的问题。
值得注意的是,我并不太担心反编译exe获取key。如果我确定有办法通过混淆等解决问题。
最终,如果我真的有意识,我不会将密码存储在任何地方。
我想听听什么是最佳实践。谢谢。
我添加了 Go 标签,因为该工具是用 Go 编写的,以防万一有一个神奇的 Go 包可能会有所帮助,除此之外,这个问题并不是特定于技术的。
更新:: 我试图保护密钥免受外部攻击者的侵害。不是机器的常规物理用户。
噜噜哒
相关分类