- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我已经在 Internet 上搜索了我的问题的答案,但不幸的是我还没有找到解决我的问题的方法。在这种情况下,我什至在 official forum 上写过, 不幸的是,主持人无法解决这个问题。下面我描述一下问题,希望有人遇到过类似的问题并知道解决方案。
我制作了一个在 Android 4.1 上运行良好的应用程序,这就是为什么我拒绝与缺少“某物”相关的问题。目前,在较新版本的 android 中似乎是一个错误,因为在更新到 Android 4.3+ (API 18+) 后,我的应用程序显示消息:
/cache/recovery/command: open failed: EACCESS (permission denied)
我的应用程序是系统应用程序,所以文件 *.apk
被放在目录/system/app/
连同合适的文件访问权限 (chmod),以便 context.getApplicationInfo().flags & ApplicationInfo.FLAG_SYSTEM
等于 1。
因为应用程序使用了方法 RecoverySystem.installPackage(...)
我添加了权限:
<uses-permission android:name="android.permission.ACCESS_CACHE_FILESYSTEM" />
<uses-permission android:name="android.permission.REBOOT" />
<uses-permission android:name="android.permission.DELETE_CACHE_FILES" />
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
超过最低要求,因为除其他外,我的应用程序使用了方法 RecoverySystem.verifyPackage(...)
另外,该方法在更新到Android 4.3+后出现了问题,但添加其中一个(或所有)权限后这些问题都解决了:
<uses-permission android:name="android.permission.WRITE_MEDIA_STORAGE"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />
注意:为了进行测试,我还向 list 文件添加了所有可能的可用权限,但这并不能解决问题。
我想再次强调,在更新到 android 4.3+ 之前,应用程序可以正常工作。更新后出现错误消息:
/cache/recovery/command: open failed: EACCESS (permission denied)
调用方法RecoverySystem.installPackage(...)
时出现此错误.( FileWriter command = new FileWriter(COMMAND_FILE);
其中 COMMAND_FILE
== /cache/recovery/command
)
我不确定,但我认为可能的原因之一可能是“bootable/recovery/recovery.c”中的错误,但我找不到任何确认。
如果有人能提供帮助,我将不胜感激。
附言为避免互联网困惑,请勿发布诸如“使用 Google”、“已经是 - 我在某处看到过 - 但不记得在哪里”、“我有同样的问题/也不适合我”之类的文字,以及其他无助于解决问题的帖子。
@shiri-hrw 感谢回复。
将 android:sharedUserId="com.google.uid.shared" 添加到我的应用程序 list (AndroidManifest.xml) 后,发生错误:
Installation error: INSTALL_FAILED_SHARED_USER_INCOMPATIBLE Please check logcat output for more details. Launch canceled!
LogCat
Package com.example.test has no signatures that match those in shared user com.google.uid.shared; ignoring!
和/或
Package com.example.test has no signatures that match those in shared user android.uid.system; ignoring!
你写道:
...as your app isn't signed with google signatures...
但在签署申请后,使用文件 *.pk8 和 *.x509.pem,可以在 pulbic sdk 的 build/target/product/security 下找到。
java -jar SignApk.jar platform.x509.pem platform.pk8 Application.apk Application_signed.apk
和/或
java -jar SignApk.jar shared.x509.pem shared.pk8 Application.apk Application_signed.apk
错误仍然存在。
当我将我的应用程序推送到系统/应用程序(并重新启动)时,该应用程序在应用程序中不可见。
最佳答案
我遇到了同样的问题,但是已经解决了。如果你的固件是 4.3+ 那么,您应该在您的应用程序 list 中添加 android:sharedUserId="com.google.uid.shared"
,并将您的应用程序推送到 system/app。
为此你可以root你的设备但是在添加这个之后,你不会被安装,因为在安装期间 PackageManagerService 的 verifySignaturesLP 方法将返回 false 因为你的应用程序没有用谷歌签名签名,所以你必须对该方法进行更改以检查你的应用程序包并在那里返回 true .
您收到该错误是因为您的应用没有与 Google 的签名相匹配的签名。尽管您已使用 *.pk 为您的应用签名,但该/那些文件不包含 Google 用于为其应用签名的签名。
所以要安装您的应用程序,您需要修改您的框架代码,如我之前提到的。例如您可以修改您的 verifySignaturesLP
方法,为您的应用程序返回 true。
或第二种选择如果您不能这样做,那么我不确定,但您可以尝试另一件事。不要使用该共享 ID,而是使用您设备中其他系统应用程序的共享 ID。例如我使用了 android:sharedUserId="android.uid.system"
然后通过给出以下命令使您的设备宽容
1. adb shell
2. setenforce 0
请记住,在执行上述命令后,对于 getenforce
,您应该获得 Permissive 而不是 Enforcing。然后尝试。对于第二个选项,我不是 100% 确定。希望第二个选项适用于您的情况。
关于android - RecoverySystem.installPackage-/cache/recovery/command : open failed: EACCESS (permission denied) - missing permission after update Android to 4. 3+,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23288149/
我想通过恢复从 sdcard 安装 zip,我写了一个名为 command 的文件: --update_package=/sdcard/my-rom.zip 将文件放入/cache/recovery
在 recovery.conf 中,如果我们将 recovery_target_time 设置为 2018-09-07 03:25:46(无 EST)并重新启动 PostgreSQL,恢复。 conf
据说nosteal是指事务提交之前更新的缓冲区不会写入磁盘,noforce也有类似的定义,那么它们之间有什么区别呢? 最佳答案 假设事务 T1 想要读取数据对象 X,但工作内存已被所有其他事务的工作填
不管我是如何到达这里的,我都可以从备份中恢复 SVN 存储库。不幸的是,备份略有损坏,在超过 19000 次修订中,大约有 80 次丢失。备份是一个 bzip2 文件,我能够使用 bzip2recov
使用 mariaDB 作为支持数据库创建了一个 VPS 来处理多个 WordPress 站点。在安装用于站点统计的 matomo 的过程中,不知怎的,整个 mysql 区域(考虑到 mariadb 和
每次运行查询时,我的数据库都不会立即响应第二个查询并提示它处于恢复模式(尽管它除了数据库名称之外没有显示任何内容)。这会发生大约 5-10 分钟,之后一切都会恢复正常。 我预计会发生重大崩溃,因此我将
我需要编写一个程序,在可能状态的大空间中执行并行搜索,在此过程中发现了新区域(并开始了他们的探索),并且由于在其他地方获得的中间结果消除了可能性,因此提前终止了对某些区域的探索在其中发现新的有用结果。
如何编写可以恢复 FAT32 文件的程序? 最佳答案 这很复杂,但是 FAT32 有很好的文档记录: 我只使用这些资源编写了一个直接访问 FAT32 的工具: http://en.wikipedia.
1、概述 Password Recovery Bundle Pro 是一个方便的工具,可以轻松恢复所有丢失的密码或忘记密码。使用 Password Recovery Bundle 时
由于服务器上的数据库使用很长时间了日志文件已经是好几个了 数据库服务器的一直采用的备份我想应该可以放弃以前的日志文件了所以清理以前的日志文件 我现在想的问题是在利用备份文件恢复的时候 要不要使
在teamcity中运行构建时出现以下错误。 Failed to collect changes, error: '"C:\Program Files\TortoiseHg\hg.exe" --con
作业系统:Win 2012 R2 你好 我尝试设置某些服务,以便当它们第二次失败时,将触发Powershell脚本向某些人发送电子邮件。这是通过services > (specific service
在 Azure 站点恢复服务的 REST API 中,位于此处:Get a list of replication protected items in Azure Site Recovery我找不到
我昨天在我的开发机器上恢复了一个 35Gb 的数据库,一切都很顺利,直到今天早上我的客户端应用程序无法连接。所以我打开 SQL Management Studio 来查找数据库“In Recovery
在 Azure 站点恢复服务的 REST API 中,位于此处:Get a list of replication protected items in Azure Site Recovery我找不到
当我尝试打开 Excel 文件时,会出现一个消息框提示,例如 “我们发现文件名中的某些内容存在问题。您希望我们尝试尽可能恢复吗?如果您信任此工作簿的来源,请单击"is"。”。实际上,我设计了一个 Ex
我可以使用 cs50 中关于此 pset 的一些指导。下面是我到目前为止的代码。我被困在这一点上,我不知道如何继续。当我运行该程序时,它确实输出了 16 个 jpg 文件,但我无法查看它们,所以一定有
我终于设法使重启代码正常工作。我使用了以下代码: Runtime runtime = Runtime.getRuntime(); Process proc = null
我正在尝试向我的应用程序添加一个默认处理程序,以便我可以从其他未处理的异常中恢复。 我发现了 Android/MonoDroid 提供的三种机制,据我所知,应该可以实现这一点,但我无法让其中任何一种发
我正在使用 rabbit mq 3.4.1 java 客户端库,但无法使自动恢复机制正常工作。 这就是我创建 rabbit mq 连接工厂的方式: factory = new ConnectionFa
我是一名优秀的程序员,十分优秀!