解决Android INSTALL_FAILED_VERSION_DOWNGRADE

先汇总一下我查阅相关问题的解决案例
【不是解决方法没用,而是需要根据个人的实际情况选择合适的方式】

1)android 6.0之后这个targetversion就不能再降级了。 (具体可以看这位大佬的笔记)https://blog.csdn.net/weizongwei5/article/details/51708676

2)若是两个人开发一款app或者新拿来的机器想把apk run进去就会出现这总问题,解决办法如 下:

1、打开cmd,进入sdk/platform-tools,执行adb shell命令

2、在root下执行cd /system/app,再执行rm xxxx.apk和rm xxxx.odex(若有.odex最好移除,没有就不管,对		于.odex做如下解释:

有很多时候,我们在修改bug的时候,发现代码明明修改了,编译也ok了,但是将编译的结果 push 到手机上去之	后,发现经常没效,纳闷了……

ODEX是安卓上的应用程序apk中提取出来的可运行文件,是通过apk安装包的中的dex优化过的,再把apk包里的dex文件删除。

这样做可以加快软件的启动速度,预先提取,减少对RAM的占用,因为没有odex的话,系统要从apk包中提取dex再运行。

3、重新打开一个cmd或者退出adb shell,执行adb push <local> /system/app下,即可解决问题

原因分析:此问题是apk签名在作怪,新机器上面的原始apk的签名与你的签名不一致,从新移除push之后签名就是你的了,即可正常使用

3)在安装APK过程中,因为VersionName(版本)过程中,因为现安装的版本低于你机器版本,所以会出现Android Failure [INSTALL_FAILED_VERSION_DOWNGRADE]
解决方案:adb install -r -d C:\Users\YJ.Huang\Desktop\EEntry.apk(包名)

4)INSTALL_FAILED_VERSION_DOWNGRADE。翻译是安装失败版本太低了。这时突然想到之前把android:versionCode=“2” android:versionName=“2.0” 这两个属性设置过一个较高的值,然后又改回来的。然后,真机运行,手机上已经有一个较高的版本了,安装运行的这个版本太低,导致运行不成功。 调高版本号,重新运行成功
看到这里我在想我也没有修改过versionCode的版本啊,然后去看了一下自己的versionCode版本,尝试的提高了一个版本,可结果还是失败

后来还是想了想,是不是我修改了一个版本还是不够呢,可能性不大啊,我一直没有修改versionCode版本呢,然后就找到了之前的apk查看一下里面的版本信息,意外收获
在这里插入图片描述
在这里插入图片描述
(图1)是我用AS 2.3.3打包的apk版本,可以看到versionCode=51,versionName=3.7.2,
(图2)使用AS 3.5打包的apk,versionCode=3,versionName=3.7.3,
看到这里我懵圈了,我没有在AndroidManifest设置versionCode版本啊,我是在gradle里面设置的,而且版本也没有那么高,versionCode=3,这就奇怪了,网上也没有找到类似的问题,难道是2.3.3的打包方式会自增?有待研究。

于是乎我在gradle里面把versionCode设置成了跟3.7.2对应的版本,再运行,问题解决。。。

上面的解决方案各异,根据自己的实际原因选择解决的方案
(本人菜鸟一枚,大家共同学习)

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Vue3中,可以将setup函数从组件文件中分离出来,以提高代码的可维护性和可复用性。分离setup函数可以让组件的逻辑和模板更清晰地分离开来,并且可以更好地组织和重用代码。 要分离setup函数,可以将其定义在一个单独的文件中,然后将其导入到组件文件中。例如,可以创建一个名为"useSetup.js"的文件,并在其中定义setup函数。然后,在组件文件中使用import语句将其导入,并在组件的setup选项中使用。 下面是一个示例: 在"useSetup.js"文件中: ```javascript import { ref, onMounted } from 'vue'; export function useSetup() { let test = ref('123'); onMounted(() => { console.log(test); }); const fn = () => { test.value = '无法预测的舞台'; }; return { test, fn }; } ``` 在组件文件中: ```javascript import { defineComponent } from 'vue'; import { useSetup } from './useSetup.js'; export default defineComponent({ props: { name: String }, setup(props, { attrs, slots, emit, expose }) { const { test, fn } = useSetup(); return { test, fn }; } }); ``` 通过将setup函数分离到单独的文件中,可以更好地组织和管理组件的逻辑代码,并使代码更加可读和可维护。同时,由于setup函数是组件内部使用组合式API的入口点,这种分离还可以使组件更加灵活和可复用。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [[深入vue3之setup] setup与组合式 API](https://blog.csdn.net/lijiahui_/article/details/122536316)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [vue3 setup 组合式api使用 操作文件单独提出 类似后台的控制器](https://blog.csdn.net/qq_40095911/article/details/124091752)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值