android 安装 apk 遭遇 java.lang.UnsupportedOperationException: Only file:// URIs are supported

本文记录了一次Android应用升级过程中遇到的问题及解决方案。主要问题是5.0及以上版本设备升级失败,原因是旧代码中URI处理不当导致。通过调整安装代码成功解决了这一问题。

   这段时间做一个老项目的升级和功能的添加,看代码的写法和类应该是2011年左右的代码,听讲原来是一个淘宝的老员工做的。我把新的功能的做上去了

过了一段时间版本就上线了。有一天我写着代码,运维突然跟我说出了现网问题,跟版本升级有关。大致是说5.0以上版本的android机器升级新版本失败,我

立即拿了个5.0的机器试了一下,新版本确实安装不上。我尝试打印日志,错误信息如下:

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.android.packageinstaller/com.android.packageinstaller.InstallAppProgress}: java.lang.UnsupportedOperationException: Only file:// URIs are supported

            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)

            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)

            at android.app.ActivityThread.access$800(ActivityThread.java:144)

            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)

            at android.os.Handler.dispatchMessage(Handler.java:102)

            at android.os.Looper.loop(Looper.java:135)

            at android.app.ActivityThread.main(ActivityThread.java:5221)

            at java.lang.reflect.Method.invoke(Native Method)

            at java.lang.reflect.Method.invoke(Method.java:372)

            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)

            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)

     Caused by: java.lang.UnsupportedOperationException: Only file:// URIs are supported

            at android.app.ApplicationPackageManager.installCommon(ApplicationPackageManager.java:1255)

            at android.app.ApplicationPackageManager.installPackageWithVerificationAndEncryption(ApplicationPackageManager.java:1220)

            at com.android.packageinstaller.InstallAppProgress.initView(InstallAppProgress.java:284)

            at com.android.packageinstaller.InstallAppProgress.onCreate(InstallAppProgress.java:182)

            at android.app.Activity.performCreate(Activity.java:5933)

            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)

            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)

            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)

            at android.app.ActivityThread.access$800(ActivityThread.java:144)

            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)

            at android.os.Handler.dispatchMessage(Handler.java:102)

            at android.os.Looper.loop(Looper.java:135)

            at android.app.ActivityThread.main(ActivityThread.java:5221)

            at java.lang.reflect.Method.invoke(Native Method)

            at java.lang.reflect.Method.invoke(Method.java:372)

            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)

            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)


      靠,什么情况?我读了一下他的升级安装代码,如下:

            Uri uri = Uri.parse(apk_path);
Intent intent = new Intent(Intent.ACTION_VIEW, uri);
intent.setData(uri);
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);

intent.setClassName("com.android.packageinstaller", "com.android.packageinstaller.PackageInstallerActivity");

                                        startActivity(intent);

按照日志的说法是本地路径转换Uri的问题,换了现在的常规写法

                    Intent intent = new Intent(Intent.ACTION_VIEW);
                    intent.setDataAndType(Uri.fromFile(new File(apk_path)), "application/vnd.android.package-archive");
                    startActivity(intent);

       问题解决。哎,老古董代码问题多。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值