- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在尝试找出在桌面应用程序中应该将应用程序 secret 和 key 存储在何处或如何存储。
例如 facebook 应用程序 key 或 dropbox key 和 secret 。
所以我读到我应该对这些值进行散列、加盐、加密等操作。这是为了防止有人对我的代码进行逆向工程并看到 key 。
一切都很好,但是对于所有这些方法,我最终只是在某处存储盐值或哈希值而不是 key 本身。当然,如果黑客可以获取 salt/hash 和可能的源代码,他们将能够解密加密 key 并获取我的密码/ key / secret ?
我读过的一个似乎最安全的选项是根本不将此值存储在桌面应用程序中,而是调用 Web 服务来获取 key (可能已加密)。但我的问题是,即使在这种情况下,一个体面的黑客肯定只会进行内存转储或其他操作以查看从 Web 服务返回的值是什么,然后我们回到第 1 个方 block 。
下一个最佳选择似乎是默默无闻。
我是否完全遗漏了什么?
附带说明一下,facebook/twitter/dropbox/etc key / secret 对黑客有什么用?他们肯定仍然需要用户的凭据或访问 token 才能使用它吗?
如有任何意见或建议,我们将不胜感激。
最佳答案
当每个用户帐户成功登录到您的服务时,为应用程序生成一个新的访问 token 。您的登录服务应该设计得非常像网站的登录:
您的 API 提供的此授权 token 仅适用于个人帐户,因此应该只允许用户对其个人帐户执行操作。因此,例如,如果用户想要执行操作,他们必须能够提供有效的身份验证 token 才能完成操作。使用这种方法,攻击者仍然可以获得授权 key ,但该授权 key 只能对生成它的帐户执行操作。它将无法对任何其他帐户执行操作。这里的想法是让他们弄乱数据,但将不良 Activity 隔离在一个帐户中。
从那里开始,如果您确实有从多个帐户访问数据的通用 API 调用(比如图像搜索),请确保您永远不会返回或允许任何帐户访问所有中的数据你的系统彻底。仅提供有限数量的记录。在这种情况下,系统仍在执行其工作,但绝不会允许访问系统中的所有记录。
我通常实现这样的服务:
使用这些方法,您应该能够制作一个功能完备的桌面应用程序。此功能有异常值,如果您有任何异常值,请在评论中发布,我们可以进一步深入研究该问题,看看该解决方案是否仍然适合您。
关于java - 在桌面应用程序中存储散列、盐、键的位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28251867/
这显然有可能导致一场激烈的 war ,但无论如何,我试一试……(目前)还没有任何明确的答案。 在我的一台机器上,我确实被切换/升级到 Matlab 2012b。这是一个漂亮的新桌面,好吧。但出于很多原
当我的 Docker 容器启动时,我收到以下通知: Docker Desktop has detected that you shared a Windows file into a WSL 2 co
我希望能够(从服务器)连接到远程 PC 并能够访问其文件。我正在尝试使用 PHP 或 JavaScript 来完成此操作。 所以我想知道 1) 是否可能以及 2) 如何做到。 有人有任何示例/解决方案
我想使用 DirectX 为 Windows 7 制作动画桌面背景。我正在使用 C#、SlimDX 和几个 Windows API 函数的 P/Invoke 导入。我对 native Windows
是否可以为 Mac 开发动态桌面?我所说的“动态”是指其图像采用系统参数(例如时间和作业信息)并使用此信息来更新图像的桌面。有关图像状态的信息也将在 session 之间保留。我不是在谈论电影或随机但
我正在 LibGDX 中构建一个仅限桌面的应用程序。该游戏内置了一个 map 编辑器,您可以切换到并更改游戏 map 。我想添加一个功能,如果用户单击关闭窗口并且有未保存的编辑,它会提示您是否要在关闭
有没有像样的Windows桌面JSON lines (JSONL)格式查看器? 这种格式也称为: 行分隔的 JSON (LDJSON) 换行符分隔的 JSON (NDJSON) 我正在寻找至少能够从
我有一个UITableView,它在单元格中显示大量图像,并且我对滚动性能并不满意。我的 UITableView 类似于 iPhone 上的照片应用程序。有谁知道为什么 iphone 照片应用程序滚动
let img1 = document.createElement('img'); img1.setAttribute('src', 'https://caniuse.com/img/browsers
我在同一窗体上有两个不同的网格控件。它们共享相同的上下文菜单。当我选择上下文菜单项时,我无法确定哪个控件是所有者。 最佳答案 ContextMenuStrip 类的 SourceControl 属性将
我已经安装了 Docker Desktop ( version : 2.3.0.4 ) 并启用了 Kubernetes . 我部署了几个 PODS,一切正常,从昨天开始,我遇到了下面提到的一个奇怪的问
我正在制作需要实现TableView的应用程序。 我想将背景图像应用到桌面 View 。 谁能帮我解决这个问题。我正在使用下面的代码来创建 TableView Titanium.UI.setBackg
我在同一窗体上有两个不同的网格控件。它们共享相同的上下文菜单。当我选择上下文菜单项时,我无法确定哪个控件是所有者。 最佳答案 ContextMenuStrip 类的 SourceControl 属性将
您能建议一些库在我的桌面 Java 应用程序中创建雷达图吗? 谢谢 最佳答案 似乎JFreeChart提供了SpiderWebPlot 。 images for which看起来像雷达图。 关于jav
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: Not possible to launch a file on a network using Java Desk
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我想知道是否可以(使用JAVA)识别用于发出请求的计算机类型,例如:服务器、台式机、PDA(平板电脑、手机等)? 谢谢! 最佳答案 取决于您使用什么来接受请求。对于 http 请求,信息位于请求 he
我添加了一个事件处理程序,用于滚动到我的桌面 View ,但它仅在我使用滚轮滚动时才起作用,但我也需要它在您单击并拖动滚动条时起作用。任何想法有什么问题吗?我尝试使用不同的方法来处理该事件,但没有一个
我想开始开发桌面 Java 应用程序,并且我想知道 Java 社区使用什么。 我从 Swing 开始,但发现它非常初级。 我习惯于在 Visual Studio 2010 中使用 .net c# WP
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我是一名优秀的程序员,十分优秀!