问题标签 [android-security]
For questions regarding programming in ECMAScript (JavaScript/JS) and its various dialects/implementations (excluding ActionScript). Note JavaScript is NOT the same as Java! Please include all relevant tags on your question; e.g., [node.js], [jquery], [json], [reactjs], [angular], [ember.js], [vue.js], [typescript], [svelte], etc.
java - 从另一个 Android 应用程序访问公共对象
鉴于后一个应用程序具有第一个应用程序的源代码,公共类或其任何公共(静态)方法/公共变量是否有可能被另一个应用程序访问/调用?
或者至少,也许在有根设备上,是否可以从内存中确定它们的值?
android - 我可以将 android 的 release.keystore 文件存储在 assets 文件夹中吗?
在 android 开发者页面 ( http://developer.android.com/tools/publishing/app-signing.html#secure-key ) 中,它声明:
将包含您的私钥的密钥库文件保存在安全的地方。
这是否意味着我们应该将 release.keystore 文件保存在本地计算机上的某个位置(而不是应用程序内部)?
或者我可以将它保存在src/main/assets
文件夹中,因为密钥库受密码保护?但另一方面,keyPassword
和storePassword
存储在 build.gradle 文件中,因此将 release.keystore 文件存储在其中src/main/assets
不是一个好主意?最安全的方法是什么?
android - 在 Android 设备上安全地隐藏字符串
问题: 我需要在设备本地存储一个秘密密钥(字符串)。我该如何合理地做到这一点?
保持本地存储的 100% 安全私密的东西是不可能的,但我想让某人尽可能难以提取密钥。我有哪些选择?
要求
- 不应该涉及 UI 操作。
- 密钥不应该以微不足道的方式提取。
可能的解决方案
混淆
Android KeyChain 类 http://developer.android.com/reference/android/security/KeyChain.html http://nelenkov.blogspot.com/2011/11/using-ics-keychain-api.html
我认为 KeyChain 需要用户交互,所以它不起作用。
ssl - Google Play 警告:WebViewClient.onReceivedSslError 处理程序
我最近收到了一封来自 Google 的电子邮件,主题如下:“Google Play 警告:SSL 错误处理程序漏洞”。在这封电子邮件中,Google 解释说我的应用程序有一个 ["不安全的 WebViewClient 实现。onReceivedSslError处理程序。具体来说,该实现忽略所有 SSL 证书验证错误,使您的应用程序容易受到中间人攻击。攻击者可以更改受影响的 WebView 的内容,读取传输的数据(例如登录凭据),并使用 JavaScript 在应用程序内部执行代码。"] ...................
我在我的代码中使用:
// 我的代码
为什么 Google Play 会发送有关 SSL 的警告?这是我的代码问题还是 PayUMoney 问题?
android - 处理 Android Webview 中的证书错误并清除证书首选项
我正在尝试找到一种正确的方法来处理 Android Webview 中的 SSL 证书错误。我的目标是提供一种加载带有 SSL 证书错误的页面的方法,但让用户在尝试加载带有证书错误的 URL 时警告他安全性后选择加载页面。
我在线程中找到的最接近的解决方案建议覆盖 WebViewClient 如下:
但是,这基本上会在未经用户同意的情况下禁用 WebView 中的 SSL。
以下是我找到该解决方案的线程供参考:
在 Android 中使用 WIFI 时,Web 视图在加载 URL 后显示空白/白页
Android WebView 阻止从 https 重定向到 http
我继续实施了一个稍微不同的版本,它会提示用户:
该实现询问用户两次是否要加载页面,如果他两次回答是,则忽略错误并加载页面,否则取消页面加载。
第一次加载带有证书错误的 URL 时,WebViewClient.onReceivedSslError
会被调用,但是如果用户继续遇到证书错误并被SslErrorHandler.proceed()
调用,则以下次数相同的 URL 将WebViewClient.onReceivedSslError
永远不会被再次调用:仅终止应用程序会重置此行为。
我希望WebViewClient.onReceivedSslError
在加载带有证书错误的 URL 时被系统地调用,而不仅仅是第一次。我尝试调用这些方法但没有成功:
有人知道如何在调用WebViewClient.onReceivedSslError
同一个 URL 后SslErrorHandler.proceed()
多次调用 WebView 吗?
java - 使用 DevicePolicyManager 在 android 上隐藏应用程序
我正在尝试使用 DevicePolicyManager 从我的应用程序中隐藏我设备上的 Facebook。现在,我已经设法通过调用 setCameraDisabled 方法来禁用相机。
现在我试图隐藏 Facebook,所以我调用了 setApplicationHidden 方法并将 Facebook 的 bundleId 指定为参数之一。当我运行我的代码时,我得到一个 java 安全异常,说我的管理员不拥有该配置文件。
如何获得用户权限,以便停止此安全异常?有没有更好的方法来以编程方式限制 3rd 方应用程序?
谢谢
android - 控制第三方 API 对 Android 系统资源的访问?
当您在 Android 项目中导入第三方 API(数据包依赖注入、生成的库、源代码等)时,您会假设它们的行为与宣传的一样。大多数时候代码不是开源的,它被混淆或只是编译。
有没有办法控制这些 API 对网络、联系人、视频和音频、位置等重要系统资源的访问?
最好的方法是为proxy
他们提供系统资源。这将有以下好处:
- 可以通过在代理中提供模拟数据来执行测试
- 如果不需要,您的应用程序不必提供 API 所需的所有权限,并且代理将通过模拟授予的权限允许 API 不会因为权限而中断
- 过滤在本地收集的关于用户的可能数据并发送到 API 主存储库,用于广告或恶意意图
由于用户定义的活动和服务无法控制第三方 API 的服务,甚至无法阻止它们直接调用任何 Android 公共接口,因此我无法找到如何实现这样的解决方案。
该解决方案不需要 root 访问权限,因为您不希望在您自己的应用程序边界之外拥有此控件。
这个问题的内容与几个问题相关联,这些问题解决了这个广泛问题的特殊性(内容提供者的日志数据、网络请求——这让我在研究这个问题的答案时想到了这个问题)
注意:简短的回答是否定的,但一个人可以有足够的创造力(也许去本地级别的黑客可能会解决这个问题 - idk)
android - Google Play security alert for insecure TrustManager
In one of my apps I'm using HTTPS with a self-signed certificate and followed the sample code from the android developer training site (https://developer.android.com/training/articles/security-ssl.html#UnknownCa).
I recently got the following alert saying that the current implementation is not secured:
Security alert
Your app is using an unsafe implementation of the X509TrustManager interface with an Apache HTTP client, resulting in a security vulnerability. Please see this Google Help Center article for details, including the deadline for fixing the vulnerability.
Can someone provide more details on what should be updated beyond the sample code linked above?
Should I implement a custom TrustManager
? If so, what should it verify?