android图片下载问题

============问题描述============


哪位大神帮我看看下面的代码,为什么传入Url最后得到的drawable是空呢?

// 网络图片先下载到本地cache目录保存,以imagUrl的图片文件名保存。如果有同名文件在cache目录就从本地加载

	public static Drawable loadImageFromUrl(Context context, String imageUrl) {

		Drawable drawable = null;

		if (imageUrl == null)

			return null;

		String imagePath = "";

		String fileName = "";



		// 获取url中图片的文件名与后缀

		if (imageUrl != null && imageUrl.length() != 0) {

			fileName = imageUrl.substring(imageUrl.lastIndexOf("/") + 1);

		}



		// 图片在手机本地的存放路径,注意:fileName为空的情况

		imagePath = context.getCacheDir() + "/" + fileName;



		Log.i(TAG, "imagePath = " + imagePath);

		File file = new File(context.getCacheDir(), fileName);// 保存文件

		System.out.println("cachedir = " + context.getCacheDir());

		Log.i(TAG, "file.toString()=" + file.toString());

		if (!file.exists() && !file.isDirectory()) {

			try {

				// 可以在这里通过文件名来判断,是否本地有此图片

				FileOutputStream fos = new FileOutputStream(file);

				InputStream is = new URL(imageUrl).openStream();

				int data = is.read();

				while (data != -1) {

					fos.write(data);

					data = is.read();

				}

				fos.close();

				is.close();

				// drawable = Drawable.createFromStream(

				// new URL(imageUrl).openStream(), file.toString() ); //

				// (InputStream) new URL(imageUrl).getContent();

				drawable = Drawable.createFromPath(file.toString());

				Log.i(TAG, "file.exists()不文件存在,网上下载:" + drawable.toString());

			} catch (IOException e) {

				Log.e(TAG, e.toString() + "图片下载及保存时出现异常!");

			}

		} else {

			drawable = Drawable.createFromPath(file.toString());

			Log.i("test", "file.tostring():" + file.toString());

			Log.i("test", "file.exists()文件存在,本地获取:" + drawable);

		}

		return drawable;

	}



下面是输出:

============解决方案1============


引用 4 楼 u014274707 的回复:
Quote: 引用 3 楼 svenwang 的回复:

Quote: 引用 2 楼 u014274707 的回复:

Quote: 引用 1 楼 svenwang 的回复:

你的问题是这么产生的:
1.第一次调用函数,因为在本地不存在,所以去网络下载。
2.因为你在UI线程中访问网络,所以导致异常,并在本地生成一个长度为0的空文件。
3.第二次调用函数,因为本地文件存在,所以执行的是else分支
4.因为文件内容为空,所以Drawable.createFromPath返回null

解决方法:
1.不要在UI线程中下载文件。
2.下载文件发生异常时删除残留文件。
可问题是我并没有在UI线程里下载啊,logcat里也没有报exception,我是在线程池里调用上面的方法的。如下:

	executor = new ThreadPoolExecutor(1, 50, 180, TimeUnit.SECONDS, queue);



// 用线程池来做下载图片的任务

		executor.execute(new Runnable() {

			@Override

			public void run() {

				Drawable drawable = loadImageFromUrl(context, imageUrl);

				imageCache.put(imageUrl, new SoftReference<Drawable>(drawable));

				Message message = handler.obtainMessage(0, drawable);

				handler.sendMessage(message);

			}

		});




那可能是下载失败导致本地文件内容不完整导致的。你可以检查一下/data/data/com.roy.activity/cache/test01_upload_1.jpg
这个文件。
下载失败的原因是什么?我该怎么做才能让图片正确显示呢?

你是不是检查了本地的/data/data/com.roy.activity/cache/test01_upload_1.jpg文件有问题?
因为网络原因下载中断或失败是很常见的事情,具体的原因要看异常里的信息。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。