6

アプリにキャッシュを実装し、4.2.x デバイスに展開する際に問題があります。

アプリのキャッシュ ディレクトリにファイルを保存すると、それを読み取ることができません。ルート権限を持つファイル マネージャーを使用してキャッシュ フォルダーを探索すると、ファイルはキャッシュ フォルダーに正しく存在しますが、それらを読み取ろうとすると、ファイルが見つからないというエラーが表示されます

この問題は 4.2 android バージョンのみに関連しています。4.1-すべて正常に動作します

これは、ファイルを書き込むために使用するコードです

public static void writeFile(Bitmap bmp, File f) {

        if (bmp == null)
            return;

        FileOutputStream out = null;

        try {
            out = new FileOutputStream(f);
            boolean res = bmp.compress(Bitmap.CompressFormat.PNG, 80, out);

        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                if (out != null)
                    out.close();
            } catch (Exception ex) {
            }
        }
        f.setReadable(true, false);
    }

これは、ファイルオブジェクトを構築する方法です

File bitmapFile = new File(ImageManager.getInstance().getCacheDir(), key);

これは、キャッシュパスを取得する方法です

if (Config.USE_INTERNAL_CACHE == false && sdState.equals(android.os.Environment.MEDIA_MOUNTED)) {
        cacheDir = MyApp.getInstance().getExternalCacheDir();
    } else {
        cacheDir = MyApp.getInstance().getCacheDir();

    }
    if (!cacheDir.exists()) {
        cacheDir.mkdirs();
    }

この時点で、私のファイルは正しく書き込まれています

/data/data/my.app.package/cache/

これは、ファイルを読み取るために使用するコードです

public BitmapDrawable readFile(String fileName) {
    FileInputStream in = null;
    try {
        in = new FileInputStream(getCacheDir()+"/"+fileName);
    } catch (FileNotFoundException e) {
        e.printStackTrace();
    }
    Bitmap bmp = BitmapFactory.decodeStream(in);

    if (bmp == null) {
        return null;
    }
    return new BitmapDrawable(MyApp.getInstance().getResources(), bmp);
}

これにより、常に次のエラーが生成されます。

01-22 11:23:47.158: W/System.err(20660): java.io.FileNotFoundException: /data/data/my.app.package/cache/File Name: open failed: ENOENT (No such file or directory)
01-22 11:23:47.158: W/System.err(20660):    at libcore.io.IoBridge.open(IoBridge.java:416)
01-22 11:23:47.158: W/System.err(20660):    at java.io.FileInputStream.<init(FileInputStream.java:78)
01-22 11:23:47.158: W/System.err(20660):    at java.io.FileInputStream.<init(FileInputStream.java:105)
01-22 11:23:47.158: W/System.err(20660):    atmy.app.package.instanceManager.ImageManager.readFile(ImageManager.java:246)
01-22 11:23:47.158: W/System.err(20660):    atmy.app.package.instanceManager.ImageManager$ImageQueueManager.run(ImageManager.java:186)
01-22 11:23:47.158: W/System.err(20660):    at java.lang.Thread.run(Thread.java:856)
01-22 11:23:47.158: W/System.err(20660): Caused by: libcore.io.ErrnoException: open failed: ENOENT (No such file or directory)
01-22 11:23:47.158: W/System.err(20660):    at libcore.io.Posix.open(Native Method)
01-22 11:23:47.158: W/System.err(20660):    atlibcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
01-22 11:23:47.158: W/System.err(20660):    at libcore.io.IoBridge.open(IoBridge.java:400)
01-22 11:23:47.158: W/System.err(20660):    ... 5 more

この行に関連:

in = new FileInputStream(getCacheDir()+"/"+fileName);

私はすでにこの権限を追加しています

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

このエラーに関連するパスと名前のファイルは正しく、ファイルはキャッシュ フォルダーに存在するのに、なぜそれらを読み取れないのですか? ** Android 4.2 で導入された新しいマルチユーザー機能により、ユーザー権限に関連する問題である可能性があると思いますが、わかりません。**ファイルも設定しようとしました.setReadable(true, false)が、何もしません。ありがとう

4

0 に答える 0