zoukankan      html  css  js  c++  java
  • mongodb存取图片文件功能

    MongoDB是一种非关系型数据库(NoSql),很好的实现了面向对象的思想(OO思想),在Mongo DB中 每一条记录都是一个Document对象。Mongo DB最大的优势在于所有的数据持久操作都无需开发人员手动编写SQL语句,直接调用方法就可以轻松的实现CRUD操作。

    这篇博客主要介绍如何mongodb存储以及读取文件。 
    mongodb操作文件,主要是通过GridFS类。存储文件主要存放在fs中,其中的fs是数据库默认的。并且GridFS是直接与数据库打交道,与collection集合无关。

    由于MongoDB的文档结构为BJSON格式(BJSON全称:Binary JSON),而BJSON格式本身就支持保存二进制格式的数据,因此可以把文件的二进制格式的数据直接保存到MongoDB的文档结构中。但是由于一个BJSON的最大长度不能超过4M,所以限制了单个文档中能存入的最大文件不能超过4M。为了提供对大容量文件存取的支持,samus驱动提供了“GridFS”方式来支持。 
    方法代码:

    /**
         * 存储文件 
         * @param collectionName 集合名 
         * @param file 文件 
         * @param fileid 文件id 
         * @param companyid 文件的公司id 
         * @param filename 文件名称
         */
        public void SaveFile(String collectionName, File file, String fileid, String companyid, String filename) {
            try {
                DB db = mongoTemplate.getDb();
                // 存储fs的根节点
                GridFS gridFS = new GridFS(db, collectionName);
                GridFSInputFile gfs = gridFS.createFile(file);
                gfs.put("aliases", companyid);
                gfs.put("filename", fileid);
                gfs.put("contentType", filename.substring(filename.lastIndexOf(".")));
                gfs.save();
            } catch (Exception e) {
                e.printStackTrace();
                System.out.println("存储文件时发生错误!!!");
            }
        }
    
        // 取出文件
        public GridFSDBFile retrieveFileOne(String collectionName, String filename) {
            try {
                DB db = mongoTemplate.getDb();
                // 获取fs的根节点
                GridFS gridFS = new GridFS(db, collectionName);
                GridFSDBFile dbfile = gridFS.findOne(filename);
                if (dbfile != null) {
                    return dbfile;
                }
            } catch (Exception e) {
                // TODO: handle exception
            }
            return null;
        }
  • 相关阅读:
    EasyHook库系列使用教程之四钩子的启动与停止
    inputclean插件的使用方法
    机器学习(十三)——机器学习中的矩阵方法(3)病态矩阵、协同过滤的ALS算法(1)
    <LeetCode OJ> 204. Count Primes
    leetcode 235: Lowest Common Ancestor of a Binary Search Tree
    数据结构经常使用算法
    调侃物联网开源框架,我们什么时候也来开源一个?
    字符编码简单介绍
    PriorityQueue ,ArrayList , 数组排序
    从struts2.1开始Convention零配置
  • 原文地址:https://www.cnblogs.com/lyy0622/p/13933145.html
Copyright © 2011-2022 走看看