2013.11.28 Base64编码后的图片信息在JSP页面中的显示[JFinal框架项目]

本文详细介绍了如何处理Base64编码后的图片,包括直接使用编码字符串显示和后台转码后通过流写出来的两种方法。重点讨论了不同场景下的适用性和限制,如IE8浏览器的兼容性问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

图片经Base64编码后会生成一个特定的字符串,显示时就把这个字符串解码。有两种方式来处理:

1.<img id="img" alt="" src="data:image/gif;base64,${record.bpic}" title="点击看大图">

直接从数据库取出字段数据,放在img标签的src中:src="data:image/gif;base64,${record.bpic}",图片就可以显示了

但是当图片过大时,在IE8下无法查看(IE8只能通过这种方式显示小于32k的图片)

2.<img id="img" alt="" src="${ctx }/build/getImgByte?id=${record.bid}" title="点击看大图">

在后台转码后通过流写出来:

A.

public void getImgByte() {
// 接收施工场地的ID
String bid = getPara("id");
System.out.println(" getImgByte ");
// 数据库读取该条施工场地的数据
Build build = BuildService.service.findFirstByPropertity("bid", bid);
OutputStream os;
try {
os = getResponse().getOutputStream();
// 调用方法将图片内容转成byte并且通过流写出去
GenerateImage(build.getStr("bpic"),os);

} catch (IOException e) {
e.printStackTrace();
}
// 获取的图片信息已经通过流写出去了,因此不再需要跳转
renderNull();
}

B.

 public static boolean GenerateImage(String imgStr,OutputStream out) {
 if (imgStr == null) // 图像数据为空
 return false;
 
 // Base64解码
 BASE64Decoder decoder = new BASE64Decoder();
 try {
 byte[] b = decoder.decodeBuffer(imgStr);
 for (int i = 0; i < b.length; ++i) {
 if (b[i] < 0) {// 调整异常数据
 b[i] += 256;
 }
 }
out.write(b);
out.flush();
out.close();
return true;
 } catch (Exception e) {
 return false;
 }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

未来的我比现在的我更优秀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值