Android Bitmap存入SQLite和如何无损取出

Android SQLite中Bitmap的存储与无损读取
本文介绍了在Android开发中遇到的Bitmap无法正常存入和从SQLite数据库中无损取出的问题。问题源于将图片转换为byte[]再转为String导致的图片失效。解决方案是使用Base64进行编码和解码,确保图片数据的完整性和可读性。

小鱼在做项目的时候,遇到直接把bitmap存入SQLite中

在取出导致图片无法显示的问题,小鱼标识十分不解。

之后跟了遍代码发现。原来存进去的数据和取出来的不同。

为什么会导致这个情况呢?


是因为 我项目使用的data类型才导致的。

(如果直接把图片类型的byte[] 变成String 会导致图片失效!)


我使用的解决办法是。把字节数组先编码成String在解码

<span style="white-space:pre">		</span>byte[] bitmap_byte=cursor.getBlob(columnIndex);
		//直接取出有传输问题,通过加解码解决
		BASE64Encoder encode = new BASE64Encoder();
		String encode_bitmap=encode.encode(bitmap_byte);


解码:

<span style="white-space:pre">		</span>String bitemap_string =(String) data.getRow(0).getValue(columnName);
		//解码器
		BASE64Decoder decode = new BASE64Decoder();
		byte [] bitemap_byte=null;
		try {
			//解码操作
			bitemap_byte=decode.decodeBuffer(bitemap_string);
		} catch (IOException e) {
			Log.e("转换图片失败", getClass().getName() + "");
			e.printStackTrace();
		}



加解密器下载地址:

http://download.youkuaiyun.com/detail/u010962482/8748905




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值