基于MongoDB GridFS取二进制数据转换为图片在jsp页面显示


1.GridFS简介

GridFS是mongodb中用户存储大对象的工具,对于mongodb,BSON格式的数据(文档)存储有尺寸限制,最大为16M.但是在实际系统开发中,经常会有上传图片或者文件的功能,这些文件可能尺寸会很大,我们可以借用Gridfs来辅助实现这些文件的管理.GridFS会将大文件对象分割成多个小的chunk(文件片段),一般为256k/个,每个chunk将作为mongodb的一个文档(document)被存储在chunks集合中。gridfs模块会为每个文件创建chunks和files信息.每个文件的实际内容被存在chunks(二进制数据)中,和文件有关的meta数据(filename,content_type,还有用户自定义的属性)将会被存在files集合中.files集合中的文档就是BSON格式,可以使用mongodb的索引等等特性,当然可以对files文档做数据分析。

fs.files集合存放文件的信息,一个fs.files集合中的一条记录内容如下,即一个file的信息如下:

基于MongoDB GridFS取二进制数据转换为图片在jsp页面显示_第1张图片

对应的fs.chunks中的chunk如下:

基于MongoDB GridFS取二进制数据转换为图片在jsp页面显示_第2张图片

"fs.files"怎么知道它对应的文件二进制数据在哪些块呢?那是因为在"fs.chunks"中有个"files_id"键,它对应"fs.files"的"_id"。"fs.chunks"还有一个键(int型)"n",它表明这些块的先后顺序。这两个集合名中的"fs"也是可以通过参数自定义的。

2.项目实现代码

  • jsp页面代码

  • java后台代码
	@RequestMapping(value = "/img_detail", method = RequestMethod.GET)
	public void img_detail(HttpServletRequest request, HttpServletResponse response) throws UnknownHostException {
		
		try{
			String id = request.getParameter("id");				
			Mongo mongo = new Mongo("IP地址", 端口号);//连接数据库			
			DB db = mongo.getDB("数据库名");		
			//如果collection为blog,mongodb就会去找blog.files与blog.chunks两个块,默认为fs
			GridFS gridFS = new GridFS(db,"collection名");						
			GridFSDBFile gridFSDBFile = (GridFSDBFile)gridFS.findOne(new ObjectId(id));			
			if (gridFSDBFile != null) {			
				OutputStream sos = response.getOutputStream();	
				response.setContentType("application/octet-stream");
				// 获取原文件名
				String name = (String) gridFSDBFile.get("filename");
				String fileName = new String(name.getBytes("GBK"), "ISO8859-1");				
				// 设置下载文件名
				response.addHeader("Content-Disposition", "attachment; filename=\""	+ fileName + "\"");	
				// 向客户端输出文件
				gridFSDBFile.writeTo(sos);
				sos.flush();
				sos.close();
		    }
		}catch(Exception e){
			e.printStackTrace();
		}
	}





你可能感兴趣的:(java,mongoDB)