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

[摘要: 那段时光做一个老项目标进级战功效的增加,看代码的写法战类应当是2011年摆布的代码,听讲本来是一个淘宝的老员工做的。我把新的功效的做上往了 过了一段时光版本便上线了。] 

   这段时间做一个老项目的升级和功能的添加,看代码的写法和类应该是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.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、付费专栏及课程。

余额充值