您的位置:首页 > Web前端 > JQuery

关于在struts2中利用jquery中如何动态从数据库中加载图片并显示

2015-11-25 00:40 921 查看
在我的前一篇博文已经介绍了$.ajax()从数据库中得到信息:struts中利用jquery的$.ajax方法来动态获得图片以及信息

本来我一开始总是在想,我该如何利用jquery的$ajax()方法来动态获得图片然后在改变现有img标签图片的内容呢?

查了好久,但一直没发现满意的,突然我从最基本的获得图片得到灵感。

首先,我是直接把图片以blob类型存到数据库中的,利用hibernate配置好的。

只需在$.ajax()的相应方法的方法体开头加上:$("#zp").attr("src","getInfo_zp?stuNum=" + num);

也就是利用改变其新地址来相应一个新的action。这个问题就可以解决了

我的action里是这样:

/**
* 处理照片
*
* @return
* @throws Exception
*/
public String zp() throws Exception {
Xsb xsb = xsbDaoImpl.getByNum(stuNum);

// 处理图片逻辑
InputStream is = xsb.getZp().getBinaryStream();
// 从数据库中读出来到指定的数组。
byte[] img = IOUtils.toByteArray(is);
response.setContentType("image/jpeg");
ServletOutputStream os = response.getOutputStream();
if (img != null && img.length != 0) {
for(int i = 0;i < img.length;i++){
os.write(img[i]);
}
}
return NONE;
}
这个action在struts.xml并不用配置结果,这样就可以解决“$.ajax()实现图片动态获取”
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: