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

在我的前一篇博文已经介绍了$.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()实现图片动态获取”

你可能感兴趣的:(java,jquery,Web,Ajax,图片,struts2.0)