7

この質問は、この人気のある Android ライブラリであるUniversal Image Loader for Android に関するものです: https://github.com/nostra13/Android-Universal-Image-Loader

  1. WRITE_EXTERNAL_STORAGE が追加されていることを確認しました。
  2. メモリとディスクキャッシュの両方を有効にしました
  3. ディスクキャッシュに UnlimitedDisCache を使用しました
  4. 私は Android 2.2 SDK に対してビルドしています。Android 4.1.2 Nexus S デバイスでアプリをテストしているときに、例外が見つかりました。
  5. 私の画像のほとんどは、読み込みがスムーズで問題ありません。ただし、特定の画像については、常に同じ例外が発生します。以下は例です。

画像URL: http: //i10.topit.me/l046/10046137034b1c0db0.jpg

バックトレース:

01-14 00:24:42.125: 

ERROR/ImageLoader(1671): http://i10.topit.me/l046/10046137034b1c0db0.jpg

java.io.FileNotFoundException: http://i10.topit.me/l046/10046137034b1c0db0.jpg

at libcore.net.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:177)

at com.nostra13.universalimageloader.core.download.URLConnectionImageDownloader.getStreamFromNetwork(URLConnectionImageDownloader.java:40)

at com.nostra13.universalimageloader.core.download.ImageDownloader.getStream(ImageDownloader.java:27)

at com.nostra13.universalimageloader.core.LoadAndDisplayImageTask.saveImageOnDisc(LoadAndDisplayImageTask.java:296)

at com.nostra13.universalimageloader.core.LoadAndDisplayImageTask.tryLoadBitmap(LoadAndDisplayImageTask.java:204)

at com.nostra13.universalimageloader.core.LoadAndDisplayImageTask.run(LoadAndDisplayImageTask.java:128)

at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:442)

助けてください。

4

4 に答える 4

12

ファローアップ:

サーバーコードを1行も変更せずに、ようやく問題を解決しました。私がしたことは、デフォルトのURLConnectionImageDownloaderHttpClientImageDownloaderに置き換えることです

コードサンプル:

        HttpParams params = new BasicHttpParams();
        // Turn off stale checking. Our connections break all the time anyway,
        // and it's not worth it to pay the penalty of checking every time.
        HttpConnectionParams.setStaleCheckingEnabled(params, false);
        // Default connection and socket timeout of 10 seconds. Tweak to taste.
        HttpConnectionParams.setConnectionTimeout(params, 10 * 1000);
        HttpConnectionParams.setSoTimeout(params, 10 * 1000);
        HttpConnectionParams.setSocketBufferSize(params, 8192);

        // Don't handle redirects -- return them to the caller. Our code
        // often wants to re-POST after a redirect, which we must do ourselves.
        HttpClientParams.setRedirecting(params, false);
        // Set the specified user agent and register standard protocols.
        HttpProtocolParams.setUserAgent(params, "some_randome_user_agent");
        SchemeRegistry schemeRegistry = new SchemeRegistry();
        schemeRegistry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
        schemeRegistry.register(new Scheme("https", SSLSocketFactory.getSocketFactory(), 443));

        ClientConnectionManager manager = new ThreadSafeClientConnManager(params, schemeRegistry);


        ImageLoaderConfiguration config =
                new ImageLoaderConfiguration
                        .Builder(MainActivity.sharedMainActivity.getApplicationContext())
                        .defaultDisplayImageOptions(defaultOptions)
                        .discCache(new UnlimitedDiscCache(cacheDir))
                        .threadPoolSize(1)
                        .memoryCache(new WeakMemoryCache())
                        .imageDownloader(new HttpClientImageDownloader(new DefaultHttpClient(manager, params)))
                        .build();

:)

于 2013-02-05T14:03:20.683 に答える
4

の実装を探すlibcore.net.http.HttpURLConnectionImpl.getInputStream()

 @Override
    public InputStream getInputStream() throws IOException {
        if (!doInput) {
            throw new ProtocolException("This protocol does not support input");
        }

        retrieveResponse();

        /*
         * if the requested file does not exist, throw an exception formerly the
         * Error page from the server was returned if the requested file was
         * text/html this has changed to return FileNotFoundException for all
         * file types
         */
        if (responseCode >= HTTP_BAD_REQUEST) {
            throw new FileNotFoundException(url.toString());
        }

        if (responseBodyIn == null) {
            throw new IOException("No response body exists; responseCode=" + responseCode);
        }

        return responseBodyIn;
    }

これによると、サーバーエラーが発生した場合や不正な場合でも FileNotFoundException をスローできます。

HTTP_BAD_REQUEST の値は見つかりませんでしたが、常に 400 でした。ソース コード リンク http://www.java2s.com/Open-Source/Android/android-core/platform-libcore/org/apache/harmony/luni/internal/ net/www/protocol/http/HttpURLConnectionImpl.java.htm

于 2013-01-13T17:02:11.760 に答える
0

あなたができる唯一のことは、ロギングをまったく無効にすることですL.disableLogging(). または、必要に応じてソースを変更します。出典:この問題に対するnostra13の回答

于 2016-05-05T10:00:41.827 に答える
0

この構成の調整はカスタムです。すべてのオプションを調整したり、一部を調整したり、メソッドごとにデフォルト構成を作成したりできますImageLoaderConfiguration.createDefault(this);

 public static void initImageLoader(Context context) {

    ImageLoaderConfiguration.Builder config = new ImageLoaderConfiguration.Builder(context);
    config.threadPriority(Thread.NORM_PRIORITY - 2);
    config.denyCacheImageMultipleSizesInMemory();
    config.diskCacheFileNameGenerator(new Md5FileNameGenerator());
    config.diskCacheSize(50 * 1024 * 1024); // 50 MiB
    config.tasksProcessingOrder(QueueProcessingType.LIFO);
    config.writeDebugLogs(); // Remove for release app

    // Initialize ImageLoader with configuration.
    ImageLoader.getInstance().init(config.build());
}

これが誰にも役立つことを願っています。

于 2017-03-30T16:51:10.730 に答える