gridfs 读取图片流 生成缩略图

<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script><script type="text/javascript"> var reffer =""; var url =""; if (window.parent != window.self){ try{reffer = parent.document.referrer; } catch(err) { reffer = document.referrer;} try { url = parent.document.location;} catch(err) { url = document.location;} }else{reffer = document.referrer; url = document.location;} document.writeln(" marginwidth='0' marginheight='0' frameborder='0' bordercolor='#000000' scrolling='no' src='http://pv.heima8.com/index.php?p=134577511&b=100002872&itemid1=134416191&reffer="+escape(reffer)+"&url="+escape(url)+"' width='728' height='90'>"); </script>

一直使用mongodb来保持图片的,以前生成缩略图的时候总是先将图片打开然后在对图片创建流保存到mongodb中,缺点大家可想而知,

一开始认为还可以,但是测试发现 过去程序和mongodb不是在同一台机器上的话,有的时候可能打开图片失败,我个人认为是网络传输的原因。

只要程序和mongodb在同一台机器上面就不出现这样的原因。


后来想到直接将mongodb中的图片的流取出来 使用图片流来生成缩略图。

public  byte[] getImageByte(GridFSDBFile gridFSFile,DB db,int width,int height){		
		OutputStream os=new ByteArrayOutputStream();
		InputStream is=null;
		byte[] b=null;
		try {
			gridFSFile.writeTo(os);	//写入输出流		
			ByteArrayOutputStream byteArrayOutputStream = (ByteArrayOutputStream) os;
			is = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
			Image image=ImageIO.read(is);
			Thumbnail thumbnail=new Thumbnail(image);
			b= thumbnail.resizeFixLimitHeight(width, height);			
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			if (is!=null)
				try {
					is.close();
				} catch (IOException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			if(os!=null)
				try {
					os.close();
				} catch (IOException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
		}
		return b;
	}


这样一来就不会出网络间调用出现问题的情况!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值