- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何安全在线存储敏感数据?
我想在公共(public)文件夹中在线存储一些极其敏感的信息,但我不确定如何去做。
具体来说,我想将比特币私钥存储在公共(public)文件夹中名为“walletData.json”的 .json 文件中。该文件包含明文形式的钱包地址和公钥,以及私钥的加密版本。
假设任何人都可以访问该文件并尝试使用他们的“ super 计算机”破解加密密码,那么安全加密私钥的最佳方法是什么?
我知道较长的密码是一个好的开始,但理想情况下我不想需要超过 10 个字符的密码。
我正在考虑将密码散列 1000 次,然后使用该散列+密码作为 AES 加密 key 。但是,由于每个人都可以看到 key 生成方法,我不确定这会有帮助吗?我也在考虑用其他一些随机数据填充加密的私钥,但同样,我不知道它是否真的有帮助??
有安全的方法吗?
编辑 - 在 Reid 的回答之后:
我正在尝试 100% 在 Javascript/jQuery 中执行此操作。
当我导出 CoinPrism.com 钱包时,我得到这个:
{"keys":[{"addr":"1PNLiLgW2fBokCB2wmfhZTtbmioitkqtMm","priv":"172655af193edeb54467a52fc6eb94c67eeeff8cd03555767e5cf12df694bb88f9c8b25c4019147d9e4993405274c96a","encryptionMode":"PKBDF2-SHA256","iterations":2000}],"salt":"2222b67fc7255aaf0b4027bfcabffb5e62f39e9e0aa13e8ad70f2dc75a484f26 "
“priv”值是加密的私钥。我不知道它是如何加密的,但我确信有一种方法可以只使用我的 10 个字符的密码来解密它。
有人知道他们是怎么做到的吗?
在线存储这些信息安全吗?
最佳答案
好吧,我会直截了本地说,您不需要编写代码来执行此操作 — 搞砸太容易了,您的帖子提出了建议有关。 (例如,您描述了一种临时 key 派生方案,但保护不足。)
因此,您需要某种图书馆来为您处理这项业务。
我的建议:使用带有 ASCII 装甲选项的 GPG。例如:
gpg --symmetric --armor --cipher-algo AES file.txt
这将 symmetrically encrypt (--symmetric
) 使用 AES 密码 (--cipher-algo AES
) 的文件(file.txt
)并存储结果ASCII armored format 中的加密文件(--盔甲
)。 注意:生成的加密文件将存储在文件名加上扩展名.asc
;例如,在这里,它将结果放入 file.txt.asc
。您可以使用 --output
选项更改它。
现在,上面的命令将提示您输入密码 — 这个密码需要非常安全,恐怕要超过 10 个字符。这是基于密码的加密的负担:您需要强大的密码。理想情况下,您需要一个又长又复杂、难以猜测且难以暴力破解的密码。
由于我们使用的是 StackOverflow,您可能希望自动输入密码(使用脚本)。为此,GPG 有几个与 --passphrase
相关的选项。例如,
gpg --batch --passphrase "test" --symmetric --armor --cipher-algo AES file.txt
将使用密码 test
而不是提示用户。但是,命令行参数在系统上并不安全,因此最好使用 --passphrase-from-file
选项,该选项将单个文件作为参数。该文件的第一行是要使用的密码。
关于security - 在线安全存储加密的敏感数据 'publicly'?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24111186/
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: When should [assembly: InternalsVisibleTo()] be used?
问题与微服务有关,当我有多个微服务提供将被订购和计费的功能/服务时。 我正在确定采用哪种方法, a) 每个可计费微服务有一个订单和一个计费服务,有各自的数据库。b) 跨所有微服务的通用订单管理和计费服
我正在尝试使用 gcloud图书馆。 (ns firengine.state (:import [com.google.cloud AuthCredentials] [com.goog
Java 允许定义以下一对类。 class Class1 { ... } public Class2 { public Class2(Class1 c1) { ... } } 如果因为 Class1
我正在尝试查找文件 1 和文件 2 中的共同行。如果公共(public)行存在,我想写入文件 2 中的行,否则打印文件 1 中的非公共(public)行。fin1 和 fin2 是这里的文件句柄。它读
好吧,这是一个满口的标题。不过,这让我明白了。这是我的代码的要点,在 jar 里: public class NetworkShared { public static class Login
我在使用 ltree 时遇到 PHP 问题来自 PostgreSQL .我在 SQL 中这样做: SELECT * FROM tabla t WHERE t.parent_path " for "OP
我知道如何为类/接口(interface)/包的子集生成 Javadoc。但是有没有办法只为公共(public)方法的一个子集生成 Javadoc? 我更喜欢能够将方法(Javadoc 标记或注释)标
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicates: c#: why have empty get set properties instead of usin
在我们的每个项目中,都有一个文件用于存储该项目中使用的各种SQL 语句。类的声明方式和字符串的声明方式有一些变化。 示例类声明: internal sealed class ClassName int
我根据 http://docs.jquery.com/Plugins/Authoring 定义了我的插件 (function( $ ){ var methods = { init : fu
我正在使用 Inno Setup 来构建我的安装程序,我有 C:\Users\Public文件夹硬编码在我的 [Files] 中放置一些文件的部分(Inno Setup 没有此文件夹的常量) 我的目标
我有一个 dataframe1 包含像 'ID', 'A', 'B', 'C', 'D', 'E', 'F', 'G' 这样的列. 现在,我创建了两个数据框, dataframe2 包含 'ID',
我有一个抽象类,不幸的是我无法更改它的定义,它基本上提供了一个抽象方法,有点像。 public abstract void do(Data someData, BaseInterface interf
我刚刚在重构时偶然发现了一段奇怪的代码。它看起来像是分解出两个 readString() 方法的共同部分的候选者,只是它似乎是不可能的(这对我来说是一个令人毛骨悚然的脑筋急转弯): private f
是否有解析为公用文件夹的属性?显然,我不想在目录结构中对“c:\users\public”进行硬编码,但我找不到预定义的 Property解决这个问题。是否有一种可接受的方式来指定要在此处安装和/或在
我试图将值从一个类传递到另一个类。 subPanel1 类读取全局变量,但当我通过调整监听器更新这些变量时,它不会更改值。我试图将 rc、gc 和 bc 变量从 subPanel2 类传递到 subP
我想使用具有自动属性的干净且编码较少的类。所有属性(property)都是公共(public)的。在同一类的方法中我也使用了该属性。因此,我认为这种方法是可混搭的,因为我将公共(public)属性用于
不久前,我在 Android 应用程序中创建了一个 SQLiteHelper 类。我不是 100% 确定原因,但表名和列名是嵌套公共(public)静态抽象类中的公共(public)静态最终字段。我记
这个问题已经有答案了: Cannot make a static reference to the non-static method (8 个回答) 已关闭 3 年前。 我正在为类(class)做一
我是一名优秀的程序员,十分优秀!