- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
感谢您花时间阅读本文,我是一名年轻的开发人员,在 Web 项目和服务器端编码方面拥有一些专业经验,但我现在正在构建我的第一个移动应用程序,经过在线深入研究后我无法澄清我对移动应用程序数据传输安全的一些疑问。
以下是我认为我理解正确的内容:通过实现 SSL 证书(以及可选的客户端上的 SSL 固定),您可以在很大程度上防止在开放网络上嗅探用户信息以及冒充其他用户(中间人等)。任何进一步的安全层都是为了保护服务器并防止某人深入了解您的交易结构和详细信息。进一步的安全层包括在处理消息之前对消息进行身份验证的消息身份验证(例如 HMAC),以及“隐藏”消息内容的加密。
我想实现先加密后 HMAC 流程以进一步保护交易,这是我关于此流程的问题:如何在客户端上存储 key / secret ?我意识到这将根据应用程序的具体情况及其希望实现的安全程度而有所不同。因此,我添加了一些细节:没有关于被存储或转移的用户的高度敏感信息(SSN、银行业务等),但该应用程序确实处理付款,因此如果有人开始破坏服务器,可能会产生高额成本和支付系统。因此,我希望在客户端和服务器之间实现安全传输,而不需要做一些不寻常的事情或不成比例的工作。
我已经阅读了很多有关该主题的内容,并且从我收集到的信息来看,无论您以哪种方式导出 key 或 secret ,在某些时候它都会以明文形式呈现给加密/散列逻辑,因此有人会能够调试应用程序、对该步骤设置断点并泄露 key / secret 。你如何解决这个问题(你能)吗?什么被认为是“适当的”(硬编码?从表结构或其他元素派生?其他?)。
这个问题确实是高层次和概念性的,所以我认为我正在讨论哪个平台并不重要,但无论如何,目前我正在编写 iOS 应用程序,后端是.NET
非常感谢您抽出宝贵时间,我们将不胜感激任何帮助或见解。如果我能澄清申请的任何方面,我会很乐意这样做。最好的,米歇尔
最佳答案
您已经很好地认识到处理 key 实际上是困难的部分。
有一个错误,可能有一个永远不会暴露 key 的系统,而这正是银行业所做的。这是因为每个阶段的加密/解密都是由硬件完成的。硬件内部拥有 key ,因此无法从设备中提取 key 。一个简单的例子是欧洲手机中的智能卡和信用卡/借记卡。另一个是银行和通信链中其他金融实体使用的 HSM(硬件安全模块)。甚至 ATM 上的密码键盘也在键盘本身的硬件中执行加密。我提到这一切是因为您声明该应用程序涉及货币交易。
如果客户端是 iOS 设备,您可以将 key 存储在钥匙串(keychain)
中,它是硬件的加密安全部分,相当于 TPM ( Trusted Platform Module )。它受设备 PIN 码的 PIN 保护,请注意,PIN 码可以设置为多于默认的四位数字。设备上的攻击,即使是在越狱的手机上,也必须使用钥匙串(keychain),并且每次尝试都有最短时间(根据设计),从而确保基于 PIN 复杂性的最短平均攻击时间。在设备之外,唯一可用的攻击是暴力破解,这是不可行的。
缺点是在加密和解密过程中 key 是明文的。如果 key 位于 Foundation 对象(例如:NSString/NSData)中,则它有可能在使用后仍然存在,最好保留“c”字符数组并在使用后清除它们。
好的,实用的解决方案:如果您确实想要安全性,请聘请加密领域专家。我至少雇佣一个人来提供建议并审查设计和实现。寻找 CISSP 的人加密领域的认证和经验。 CISSP 要求至少五年在直接监督下 100% 在该领域工作,六小时的测试,通常每年约 160 小时的测试学习时间和 40 小时的继续教育。
关于ios - 保护移动连接 - 存储 secret 和 key ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20948645/
只是想知道 Jquery Mobile 是否足够稳定以用于实时生产企业移动应用程序。 有很多 HTML5 框架,因为我们的团队使用 JQuery 已经有一段时间了,我们更愿意使用 Jquery 移动框
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 3 年前。 Improve t
所以我尝试在 JavaScript 中对元素进行拖放。我使用的视频教程在这里; https://www.youtube.com/watch?v=KTlZ4Hs5h80 。我已经按照它的说明进行了编码,
无法在移动 iOS(safari 和 chrome)上自动播放以前缓存的 mp3 音频 我正在 Angular 8 中开发一个应用程序,在该应用程序的一部分中,我试图在对象数组中缓存几个传入的音频 m
Git 基于内容而不是文件,所以我目前理解以下行为,但我想知道是否有特殊选项或 hack 来检测此类事情: git init mkdir -p foo/bar echo "test" foo/a.tx
我正在寻找语义 ui 正确的类来隐藏例如移动 View 中的 DIV。在 Bootstrap 中,我们有“visible-xs”和“hidden-xs”。 但是在语义ui上我只找到了“仅移动网格” 最
我正在使用 ubuntu 和 想要移动或复制大文件。 但是当我与其他人一起使用服务器时,我不想拥有所有内存并使其他进程几乎停止。 那么有没有办法在内存使用受限的情况下移动或复制文件? 最佳答案 如果你
这些指令有什么区别?以 ARM9 处理器为例,它不应该是: ASM: mov r0, 0 C: r0 = 0; ASM: ld r0, 0 C: r0 = 0; ? 我不知道为什么要使用一个或另一个:
我有一个文件夹,其中包含一些随机命名的文件,其中包含我需要的数据。 为了使用数据,我必须将文件移动到另一个文件夹并将文件命名为“file1.xml” 每次移动和重命名文件时,它都会替换目标文件夹中以前
我经常在 IB/Storyboard 中堆叠对象,几乎不可能拖动其他对象后面的对象而不移动前面的对象。无论如何我可以移动已经选择但位于其他对象后面的对象吗?当我尝试移动它时,它总是选择顶部的对象,还是
几个月前,我看到 Safari 7 允许推送通知,它似乎是一个非常有用的工具,除了我看到的每个示例都专注于桌面浏览,而不是移动设备。 Safari 推送通知是否可以在移动设备上运行,如果没有,是否有计
我有一个简单的 View 模型,其中包含修改后的 ObservableCollection使用 SynchronizationContext.Current.Send在 UI 线程上执行对集合的更改。
关于cassandra创建的数据文件和系统文件的位置,我需要移动在“cassandra.yaml”配置文件中设置的“commitlog_directory”、“data_file_directorie
我有这个代码 $(function() { var message = 'Dont forget us'; var original; var txt1 = ' - '; $(wind
我的客户报告说他的网站有一个奇怪的问题。该网站的 URL 是 your-montenegro.me 在 基于 Android 的浏览器 上加载时,页面底部会出现一个奇怪的空白区域。以下是屏幕截图: 华
我有这个 HTML 标记: Express 300 bsf Sign Up 我需要将元素从 DOM 上的一个
我有一个可重新排序的 TableView (UITableView 实例)。尽管我已经实现了 UITableViewDataSource 方法: tableView:moveRowAtIndexPat
我的客户报告说他的网站有一个奇怪的问题。该网站的 URL 是 your-montenegro.me 在 基于 Android 的浏览器 上加载时,页面底部会出现一个奇怪的空白区域。以下是屏幕截图: 华
我需要在拖放或复制/剪切和粘贴(复制与移动)期间获取操作类型。它是一个 Swing 应用程序,并且实现了 TransferHandle。我在操作结束时需要此信息,在 importData 方法中。 对
我编写了一个具有 add 和 get 方法的 SortedIntList 类。 我调用以下四个方法: SortedIntList mySortedIntList = new SortedIntList
我是一名优秀的程序员,十分优秀!