我试图通过编辑androidmanifest.xml文件来改变我的默认/main/startup(不管你叫它什么)活动。我所做的只是改变了android:name属性。然而,这完全破坏了整个应用程序。当我试图安装它失败和读取。
安装错误:INSTALL_PARSE_FAILED_NO_CERTIFICATES
当我试图把它改变回以前的状态时,它仍然给我同样的错误…我做了什么?
我试图通过编辑androidmanifest.xml文件来改变我的默认/main/startup(不管你叫它什么)活动。我所做的只是改变了android:name属性。然而,这完全破坏了整个应用程序。当我试图安装它失败和读取。
安装错误:INSTALL_PARSE_FAILED_NO_CERTIFICATES
当我试图把它改变回以前的状态时,它仍然给我同样的错误…我做了什么?
当前回答
大多数答案都是正确的。另一个原因是
►你的min SDK比设备SDK小。 ►您的设备中有具有相同包名的旧应用程序
其他回答
对我来说,我忘记将新的签名配置添加到
项目结构->默认配置->签名配置
我也面临着同样的问题。首先,我使用V2生成构建,并将其安装在运行OS 5.1的移动设备上,我得到了相同的问题。但是build在运行于OS 7.0的平板电脑上运行得很好。所以我用V1 Jar签名生成构建,它在两个设备上都工作得很好。
结论:如果您支持android OS 7.0以下的设备。使用V1 jar签名来生成构建。
大多数答案都是正确的。另一个原因是
►你的min SDK比设备SDK小。 ►您的设备中有具有相同包名的旧应用程序
你直接在。apk文件中编辑AndroidManifest.xml了吗?如果是这样,那就行不通了。
每个Android .apk如果要安装在手机上,即使你没有通过市场安装,也需要签名。开发工具通过签署开发证书来解决这个问题,但.apk仍然是签名的。
这样做的一个用途是,设备可以判断.apk是否是已安装应用程序的有效升级,因为如果是的话,证书将是相同的。
因此,如果你对你的应用程序做了任何更改,你需要重新构建.apk,以便正确签名。
解决(为我)使用keytool的参数
-sigalg MD5withRSA -keyalg RSA -keysize 1024
在jarsigner中使用
-sigalg MD5withRSA -digestalg SHA1
解决方案
Android APK签名存在哪些隐患?