您的位置:首页 > 移动开发 > Android开发

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

2016-01-14 10:32 495 查看
[摘要: 那段时光做一个老项目标进级战功效的增加,看代码的写法战类应当是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);

问题解决。哎,老古董代码问题多。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: