安装.apk文件时出现解析错误

3
我正在使用DownloadManager从服务器下载.apk文件。当我手动安装应用程序时,出现解析错误,并显示“解析包时出现问题”消息。
然而,当我通过浏览器下载同样的apk并将其复制到SD卡上进行安装,它就可以成功安装。
因此,希望不是minsdkversion的问题,我已经检查了Unknown Sources。
我下载apk文件的代码如下:
        public class UpdateCheckerService extends Service {


    UpdateChecker update_checker;
    DownloadManager downloadManager;
    String Download_path="http://www.xxxxx.com/mobile_api/xxxxxx.apk";

    SharedPreferences preferenceManager;
    String Download_ID = "100";


    @Override
    public IBinder onBind(Intent arg0) {
        // TODO Auto-generated method stub
        return null;
    }
    public void onCreate()
    {
        System.out.println("SERVICE ************ CREATED");

    }
    public void onStart(Intent intent1, int start_id)
    {
        System.out.println("Service started");
        IntentFilter intentFilter = new IntentFilter(DownloadManager.ACTION_DOWNLOAD_COMPLETE);
         registerReceiver(downloadReceiver, intentFilter);
         System.out.println("Service started");

        if(isNetworkAvailable())
        {


            if(true)
            {
                System.out.println("Update AVAAILLL:");
                preferenceManager = PreferenceManager.getDefaultSharedPreferences(this);
                 downloadManager = (DownloadManager)getSystemService(DOWNLOAD_SERVICE);
                 Environment
                  .getExternalStoragePublicDirectory(Environment.DIRECTORY_DOWNLOADS)
                  .mkdirs();

                   Uri Download_Uri = Uri.parse(Download_path);


                    DownloadManager.Request request = new DownloadManager.Request(Download_Uri);

                    long download_id = downloadManager.enqueue(request.setTitle("Downloading...")
                            .setDescription("xxxx").setMimeType("application/vnd.android.package-archive").setDestinationInExternalPublicDir(Environment.DIRECTORY_DOWNLOADS,
                                    "xxxxx.apk"));


                    Editor PrefEdit = preferenceManager.edit();
                    PrefEdit.putLong(Download_ID, download_id);
                    PrefEdit.commit();
            }
        }   
    }
    public void onDestroy()
    {

    }



    private BroadcastReceiver downloadReceiver = new BroadcastReceiver() {

          @Override
          public void onReceive(Context arg0, Intent arg1) {
           // TODO Auto-generated method stub
           DownloadManager.Query query = new DownloadManager.Query();
           query.setFilterById(preferenceManager.getLong(Download_ID, 0));
           Cursor cursor = downloadManager.query(query);

           if(cursor.moveToFirst()){
            int columnIndex = cursor.getColumnIndex(DownloadManager.COLUMN_STATUS);
            int status = cursor.getInt(columnIndex);
            int columnReason = cursor.getColumnIndex(DownloadManager.COLUMN_REASON);
            int reason = cursor.getInt(columnReason);

            if(status == DownloadManager.STATUS_SUCCESSFUL){
             //Retrieve the saved download id
             long downloadID = preferenceManager.getLong(Download_ID, 0);

             ParcelFileDescriptor file;

             try {
              file = downloadManager.openDownloadedFile(downloadID);
              Toast.makeText(UpdateCheckerService.this,
                "File Downloaded: " + file.toString(),
                Toast.LENGTH_LONG).show();

             } catch (FileNotFoundException e) {
              // TODO Auto-generated catch block
              e.printStackTrace();
              Toast.makeText(UpdateCheckerService.this,
                e.toString(),
                Toast.LENGTH_LONG).show();
             }

            }else if(status == DownloadManager.STATUS_FAILED){
             Toast.makeText(UpdateCheckerService.this,
               "FAILED!\n" + "reason of " + reason,
               Toast.LENGTH_LONG).show();
            }else if(status == DownloadManager.STATUS_PAUSED){
             Toast.makeText(UpdateCheckerService.this,
               "PAUSED!\n" + "reason of " + reason,
               Toast.LENGTH_LONG).show();
            }else if(status == DownloadManager.STATUS_PENDING){
             Toast.makeText(UpdateCheckerService.this,
               "PENDING!",
               Toast.LENGTH_LONG).show();
            }else if(status == DownloadManager.STATUS_RUNNING){
             Toast.makeText(UpdateCheckerService.this,
               "RUNNING!",
               Toast.LENGTH_LONG).show();
            }
           }
          }

         };

}

这里是logcat

11-25 16:31:58.195: D/asset(3422): failed to open Zip archive '/mnt/sdcard/Download/SavariLocal.apk'
11-25 16:31:58.210: W/PackageParser(3422): Unable to read AndroidManifest.xml of /mnt/sdcard/Download/SavariLocal.apk
11-25 16:31:58.210: W/PackageParser(3422): java.io.FileNotFoundException: AndroidManifest.xml
11-25 16:31:58.210: W/PackageParser(3422):  at android.content.res.AssetManager.openXmlAssetNative(Native Method)
11-25 16:31:58.210: W/PackageParser(3422):  at android.content.res.AssetManager.openXmlBlockAsset(AssetManager.java:486)
11-25 16:31:58.210: W/PackageParser(3422):  at android.content.res.AssetManager.openXmlResourceParser(AssetManager.java:454)
11-25 16:31:58.210: W/PackageParser(3422):  at android.content.pm.PackageParser.parsePackage(PackageParser.java:402)
11-25 16:31:58.210: W/PackageParser(3422):  at com.android.packageinstaller.PackageUtil.getPackageInfo(PackageUtil.java:79)
11-25 16:31:58.210: W/PackageParser(3422):  at com.android.packageinstaller.PackageInstallerActivity.onCreate(PackageInstallerActivity.java:242)
11-25 16:31:58.210: W/PackageParser(3422):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
11-25 16:31:58.210: W/PackageParser(3422):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1615)
11-25 16:31:58.210: W/PackageParser(3422):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
11-25 16:31:58.210: W/PackageParser(3422):  at android.app.ActivityThread.access$1500(ActivityThread.java:117)
11-25 16:31:58.210: W/PackageParser(3422):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
11-25 16:31:58.210: W/PackageParser(3422):  at android.os.Handler.dispatchMessage(Handler.java:99)
11-25 16:31:58.210: W/PackageParser(3422):  at android.os.Looper.loop(Looper.java:130)
11-25 16:31:58.210: W/PackageParser(3422):  at android.app.ActivityThread.main(ActivityThread.java:3687)
11-25 16:31:58.210: W/PackageParser(3422):  at java.lang.reflect.Method.invokeNative(Native Method)
11-25 16:31:58.210: W/PackageParser(3422):  at java.lang.reflect.Method.invoke(Method.java:507)
11-25 16:31:58.210: W/PackageParser(3422):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
11-25 16:31:58.210: W/PackageParser(3422):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
11-25 16:31:58.210: W/PackageParser(3422):  at dalvik.system.NativeStart.main(Native Method)
11-25 16:31:58.210: W/PackageInstaller(3422): Parse error when parsing manifest. Discontinuing installation

请建议我如何解决这个问题,以及我错在了哪里...
感谢您的提前帮助。

尝试清理你的项目。 - GrIsHu
我清理了项目,问题仍然存在... - savari
你有没有可能从logcat中获取更多的细节? - fasteque
@fasteque 我添加了logcat,请检查。 - savari
调试时:我尝试了这样的方法,我将apk下载到SD卡/下载文件夹中,然后手动进入该文件夹,点击apk文件,然后它告诉我解析错误,并且在logcat中它告诉我Manifest.xml文件丢失。因此,我怀疑downloadManager没有正确下载文件。 - savari
显示剩余2条评论
2个回答

0

我之前也遇到过这个问题。以下是我的调试方法。首先,通过终端安装APK adb install path_to_your_app/name_of_your_app.apk 如果你收到错误消息:adb: failed to install name_of_your_app.apk: Failure [INSTALL_FAILED_NO_MATCHING_ABIS: Failed to extract native libraries 这意味着您正在构建的架构与模拟器架构不匹配。

由于这是来自外部来源的APK,您可能需要重新打包并根据您的设备架构进行构建。您可以使用此工具:https://ibotpeaches.github.io/Apktool/

希望这有所帮助


0

我曾经遇到过同样的问题,后来发现卸载应用程序,然后重新安装 APK 可以解决。

还有另一种解决方案,我没有尝试过,但可能会有用。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接