- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
背景
我正在使用原生 C++11 开发一个简单的应用程序,它使用 Microsoft 的 Cassablanca REST 框架与各种远程端点进行通信。为此,我必须使用目标 API 提供的一些 secret 对各种请求进行加密签名。通过链接 Cassablanca,我已经有了 OpenSSL,所以实际的加密相当简单。
现在,棘手的部分是如何存储 secret 本身。我的计划是使用来自用户大脑的对称 key (读取:密码)对包含所有好东西的 JSON 文件进行 AES 加密,这样它就不必存储在磁盘上。
问题
在应用程序执行期间将解密的 secret 存储在内存中的安全方法是什么?这不是另一个“我如何将 secret 存储在磁盘上以便用户不必做什么”的问题。
我最担心的是有人能够从外部检查我的应用程序的内存并找到包含好东西的适当区域。我知道 Windows 提供了 credstores 和 protected 内存,但是我在 Linux 上,如果可能的话,我更喜欢与平台无关的解决方案。这也很有可能会部署到 VM 集群,因此 protected 内存可能只能购买有限的保证(尽管总比没有好)。
最后,我知道任何密码系统都可以通过足够多的金钱+时间或足够大的橡胶软管来破解。话虽这么说,我仍然希望尽可能安全,就像 Good™ 编码实践中的练习一样。
我的约束是:
必须能够访问 secret 以快速签署各种请求。毫秒在这里很重要,但如果安全性真正得到改善,我愿意接受减速。
我希望尽可能少地使用外部库,并尽可能使用原生 C++11。我觉得这应该可以用我已有的东西来实现(Cassablanca,它需要 OpenSSL、Boost、libcrypt)。
最后,它应该能够容纳相当多的 secret /请求。我的应用领域基本上是一个巨大的并行化问题,可扩展性是关键。
我已经知道要做什么:
切勿在未加密的情况下将敏感资料存储在磁盘上。这包括使用磁盘支持的容器等等。
一个古老但有用的技巧:附加调试器实例以防止从外部进程进行远程调试。
在没有调试符号的情况下构建并剥离最终可执行文件。
尽量减少应用程序内对数据的访问,仅让真正需要它的部分访问。
敏感信息不再需要时立即销毁(例如,解密完成后立即清空用户密码等)。
不要相信任何人会为我清理内存。用 NULL/垃圾手动覆盖区域。
类似问题
特定于 PHP 并建议编写一些不在 PHP 中的东西来存储凭据...这正是我要解决的问题。
特定于 Android 应用程序生命周期。我已经知道我的 secret 的存储期限将是应用程序的生命周期。
最佳答案
我会有一个静态内存区域(您的应用程序中的较大缓冲区,其中包含每个应用程序启动的加密 key 。
这会导致......
该方案保留了三个内存区域,静态的加密 secret 和部分图像内存。
一般的应用端数据——使用正常的新建/删除。
加密数据,使用自定义的new/delete,是一个mmap,不会和普通的new/delete共享地址
关于c++ - 将解密后的数据暂存在内存中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44932578/
初学者 android 问题。好的,我已经成功写入文件。例如。 //获取文件名 String filename = getResources().getString(R.string.filename
我已经将相同的图像保存到/data/data/mypackage/img/中,现在我想显示这个全屏,我曾尝试使用 ACTION_VIEW 来显示 android 标准程序,但它不是从/data/dat
我正在使用Xcode 9,Swift 4。 我正在尝试使用以下代码从URL在ImageView中显示图像: func getImageFromUrl(sourceUrl: String) -> UII
我的 Ubuntu 安装 genymotion 有问题。主要是我无法调试我的数据库,因为通过 eclipse 中的 DBMS 和 shell 中的 adb 我无法查看/data/文件夹的内容。没有显示
我正在尝试用 PHP 发布一些 JSON 数据。但是出了点问题。 这是我的 html -- {% for x in sets %}
我观察到两种方法的结果不同。为什么是这样?我知道 lm 上发生了什么,但无法弄清楚 tslm 上发生了什么。 > library(forecast) > set.seed(2) > tts lm(t
我不确定为什么会这样!我有一个由 spring data elasticsearch 和 spring data jpa 使用的类,但是当我尝试运行我的应用程序时出现错误。 Error creatin
在 this vega 图表,如果我下载并转换 flare-dependencies.json使用以下 jq 到 csv命令, jq -r '(map(keys) | add | unique) as
我正在提交一个项目,我必须在其中创建一个带有表的 mysql 数据库。一切都在我这边进行,所以我只想检查如何将我所有的压缩文件发送给使用不同计算机的人。基本上,我如何为另一台计算机创建我的数据库文件,
我有一个应用程序可以将文本文件写入内部存储。我想仔细看看我的电脑。 我运行了 Toast.makeText 来显示路径,它说:/数据/数据/我的包 但是当我转到 Android Studio 的 An
我喜欢使用 Genymotion 模拟器以如此出色的速度加载 Android。它有非常好的速度,但仍然有一些不稳定的性能。 如何从 Eclipse 中的文件资源管理器访问 Genymotion 模拟器
我需要更改 Silverlight 中文本框的格式。数据通过 MVVM 绑定(bind)。 例如,有一个 int 属性,我将 1 添加到 setter 中的值并调用 OnPropertyChanged
我想向 Youtube Data API 提出请求,但我不需要访问任何用户信息。我只想浏览公共(public)视频并根据搜索词显示视频。 我可以在未经授权的情况下这样做吗? 最佳答案 YouTube
我已经设置了一个 Twilio 应用程序,我想向人们发送更新,但我不想回复单个文本。我只是想让他们在有问题时打电话。我一切正常,但我想在发送文本时显示传入文本,以确保我不会错过任何问题。我正在使用 p
我有一个带有表单的网站(目前它是纯 HTML,但我们正在切换到 JQuery)。流程是这样的: 接受用户的输入 --- 5 个整数 通过 REST 调用网络服务 在服务器端运行一些计算...并生成一个
假设我们有一个名为 configuration.js 的文件,当我们查看内部时,我们会看到: 'use strict'; var profile = { "project": "%Projec
这部分是对 Previous Question 的扩展我的: 我现在可以从我的 CI Controller 成功返回 JSON 数据,它返回: {"results":[{"id":"1","Sourc
有什么有效的方法可以删除 ios 中 CBL 的所有文档存储?我对此有疑问,或者,如果有人知道如何从本质上使该应用程序像刚刚安装一样,那也会非常有帮助。我们正在努力确保我们的注销实际上将应用程序设置为
我有一个 Rails 应用程序,它与其他 Rails 应用程序通信以进行数据插入。我使用 jQuery $.post 方法进行数据插入。对于插入,我的其他 Rails 应用程序显示 200 OK。但在
我正在为服务于发布请求的 API 调用运行单元测试。我正在传递请求正文,并且必须将响应作为帐户数据返回。但我只收到断言错误 注意:数据是从 Azure 中获取的 spec.js const accou
我是一名优秀的程序员,十分优秀!