2017-11-10 66 views
1

APKアップデートをリモートサーバから内部ストレージにダウンロードしてデバイスにインストールしようとするアプリケーションを作成しました。 私はAPI24デバイスでそれをテストし、すべて正常に動作します。マニフェストの解析時に解析エラーが発生する

私はAPI 19デバイス上でテストしています(アプリの古いアップデート方法に関するコードの部分をテストするため)、私は "マニフェストの解析時に解析エラー"を受け取り続けます。私が困惑しているのは、デバイスに手動でAPKをインストールでき、解析エラーがないため、問題が実際のマニフェストファイルにあるとは思わないということです。内部ストレージにダウンロードしたAPKファイルの長さを確認したところ、完全にダウンロードされたようです。 APKをダウンロードするコードは、すべてのAPIバージョンで同じです。

コード:

​​

エラー:

W/PackageParser: Unable to read AndroidManifest.xml of /data/data/my.package.name/files/update.apk 
    java.io.FileNotFoundException: AndroidManifest.xml 
    at android.content.res.AssetManager.openXmlAssetNative(Native Method) 
    at android.content.res.AssetManager.openXmlBlockAsset(AssetManager.java:501) 
    at android.content.res.AssetManager.openXmlResourceParser(AssetManager.java:469) 
    at android.content.pm.PackageParser.parsePackage(PackageParser.java:544) 
    at com.android.packageinstaller.PackageUtil.getPackageInfo(PackageUtil.java:73) 
    at com.android.packageinstaller.PackageInstallerActivity.onCreate(PackageInstallerActivity.java:467) 
    at android.app.Activity.performCreate(Activity.java:5350) 
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1088) 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2320) 
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2417) 
    at android.app.ActivityThread.access$800(ActivityThread.java:151) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1342) 
    at android.os.Handler.dispatchMessage(Handler.java:110) 
    at android.os.Looper.loop(Looper.java:193) 
    at android.app.ActivityThread.main(ActivityThread.java:5322) 
    at java.lang.reflect.Method.invokeNative(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:515) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:829) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:645) 
    at dalvik.system.NativeStart.main(Native Method) 
11-10 10:16:24.213 4140-4140/? W/PackageInstaller: Parse error when parsing manifest. Discontinuing installation 

のAndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
package="my.package.name"> 

<uses-permission android:name="android.permission.CAMERA" /> 
<uses-permission android:name="android.permission.INTERNET" /> 

<application 
    android:allowBackup="true" 
    android:icon="@mipmap/ic_launcher" 
    android:label="@string/app_name" 
    android:supportsRtl="true" 
    android:theme="@style/AppTheme"> 
    <activity 
     android:name=".main.activities.UpdateActivity" 
     android:screenOrientation="portrait"> 
     <intent-filter> 
      <action android:name="android.intent.action.MAIN" /> 
      <category android:name="android.intent.category.LAUNCHER" /> 
     </intent-filter> 
    </activity> 

    <provider 
     android:name="android.support.v4.content.FileProvider" 
     android:authorities="${applicationId}.provider" 
     android:exported="false" 
     android:grantUriPermissions="true"> 
     <meta-data 
      android:name="android.support.FILE_PROVIDER_PATHS" 
      android:resource="@xml/provider_paths" /> 
    </provider> 
</application> 
</manifest> 

EDIT

解答を参照してください。

+0

:これに

OutputStream os = new FileOutputStream(pathToApk) 

は、この行を変更しました。 – KeLiuyue

+0

"android.permission.INSTALL_PACKAGES"をマニフェストに追加しましたが、Androidスタジオで "Permission only to system apps"が表示されます。ツールを追加した後:ignore = "ProtectedPermissions"とアプリを実行すると、同じエラーメッセージが表示される "パッケージの解析中に問題が発生しました。" – HomeIsWhereThePcIs

答えて

0

に権限を追加します。私のAPIのアプリケーションの< = 23。 修正はかなり簡単でした。あなたが要求許可を追加する必要があります

boolean old = Build.VERSION.SDK_INT < Build.VERSION_CODES.N; 
OutputStream os = old ? 
    openFileOutput("update.apk", Context.MODE_WORLD_READABLE) 
    : new FileOutputStream(pathToApk) 
0

ここにリクエストを追加してください。 Manifest.permission.READ_EXTERNAL_STORAGE

  • ため

    1. checkSelfPermission付与された場合、あなたはreadFile();

  • ない場合は、あなたがrequestPermissionsすべきを行うことができます。

2.dealあなたのコード内のonRequestPermissionsResult

/** 
* permission code 
*/ 
private static final int MY_PERMISSIONS_REQUEST_READ_EXTERNAL_STORAGE = 1; 

/** 
* requestPermissions and do something 
* 
*/ 
public void requestRead() { 
    if (ContextCompat.checkSelfPermission(this, 
      Manifest.permission.READ_EXTERNAL_STORAGE) 
      != PackageManager.PERMISSION_GRANTED) { 

     ActivityCompat.requestPermissions(this, 
       new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, 
       MY_PERMISSIONS_REQUEST_READ_EXTERNAL_STORAGE); 
    } else { 
     readFile(); 
    } 
} 

/** 
* do you want to do 
*/ 
public void readFile() { 
    // do something 
} 

/** 
* onRequestPermissionsResult 
* 
* @param requestCode 
* @param permissions 
* @param grantResults 
*/ 
@Override 
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { 

    if (requestCode == MY_PERMISSIONS_REQUEST_READ_EXTERNAL_STORAGE) { 
     if (grantResults[0] == PackageManager.PERMISSION_GRANTED) { 
      readFile(); 
     } else { 
      // Permission Denied 
      Toast.makeText(ToolbarActivity.this, "Permission Denied", Toast.LENGTH_SHORT).show(); 
     } 
     return; 
    } 
    super.onRequestPermissionsResult(requestCode, permissions, grantResults); 
} 

での問題は、システムがプライベート内部ストレージからAPKを読んでいないということでしたマニフェスト

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> 
+0

内部ストレージからAPKをダウンロードして実行しています - getFilesDir() – HomeIsWhereThePcIs

+0

ファイルを読みたい場合は、最初にリクエストしてください。 – KeLiuyue

+0

apkが内部ストレージにダウンロードされます。 READ_EXTERNAL_STORAGEは内部ストレージから読み取る必要はありません。 – HomeIsWhereThePcIs

関連する問題