MongoDB中对图片的常见操作有哪些,怎么实现
Admin 2022-06-06 群英技术资讯 668 次浏览
以下是对于图片的一些基本操作:
1、存储图片
// 存储文件信息 GridFS gridFS = new GridFS(MongoDBUtil.getDB(), "test"); File localFile = new File("d://test.jpg"); GridFSInputFile oneFile = gridFS.createFile(localFile); oneFile.setFilename("test.jpg"); // 配置文件属性 SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//设置日期格式 BasicDBObject metadata = new BasicDBObject(); metadata.put("uploadDate", df.format(new Date())); oneFile.setMetaData(metadata);//添加属性 oneFile.save();//保存文件
2、根据文件ID读取图片
// 存储文件信息 GridFS gridFS = new GridFS(MongoDBUtil.getDB(), "test"); // 读取文件 GridFSDBFile outFile = gridFS.findOne(new ObjectId(request.getParameter("id"))); //System.out.println(outFile);
3、根据MetaData属性查找图片
// GridFS gridFS = new GridFS(MongoDBUtil.getDB(), "test"); //查找条件 BasicDBObject query = new BasicDBObject("metadata.pkid", "1123"); List<GridFSDBFile> listFiles = gridFS.find(query); System.out.println(listFiles); System.out.println(listFiles.size());
4、显示图片
@RequestMapping(value = "/show") public void show(HttpServletRequest request, HttpServletResponse response){ try { OutputStream out = response.getOutputStream(); response.setContentType("image/jpg"); GridFS gridFS = new GridFS(MongoDBUtil.getDB(), "test"); // 读取文件 GridFSDBFile outFile = gridFS.findOne(new ObjectId(request.getParameter("id"))); //System.out.println(outFile); if(outFile!=null){ outFile.writeTo(out); out.flush(); out.close(); } } catch (Exception e) { e.printStackTrace(); } }
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
很多人对于mongodb修改器可能比较陌生,其实mongodb修改器是比较实用的,下面小编就给大家分享关于mongodb修改器的使用,感兴趣的朋友可以了解一下。
主要介绍了图片的基本操作:1、存储图片,主要用gridFS.createFile();2、根据文件ID读取数据;3、根据MetaData属性查找图片;4、显示图片。
mongodb中插入图片的方法:使用GridFS类即可插入图片,先使用new GridFS(db)方法获取gridFS对象,然后使用gridFS.createFile()方法写入图片。
mongodb是一个基于分布式文件存储的数据库,如果使用过mongodb,应该了解新安装的mongodb是没有账号设置的,也就意味着任何人都能够连接mongodb,这是很不安全的,因此为能够有效保证数据的安全,我们需要对mongodb进行设置账号,来控制对数据库的访问。这篇文章我们就一起来了解一下MongoDB访问控制的操作方法。
mongoDB中两个表之间的关联查询:首先两个表中要有关联信息,例如两个表中都有邮箱这一信息。关键步骤:{ $unwind: "$Users" },表示把从User表中查询的数据字段,作为订单表(PrepurchaseOrder)中的字段。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008