SpringBoot 利用MongoDB存储图片文件

文件存储 -- 替代文件服务器

MongoDB 分片, 当你一台文件服务器硬盘不够的时候, 分片轻而易举解决这个问题

 大批量文件, 图片, 视频, 音频 考虑采用 MongoDB gridfs

 

package cn.tom.demo.controllerr;


import com.mongodb.client.MongoDatabase;
import com.mongodb.client.gridfs.GridFSBucket;
import com.mongodb.client.gridfs.GridFSBuckets;
import com.mongodb.client.gridfs.GridFSDownloadStream;
import com.mongodb.client.gridfs.model.GridFSFile;
import org.apache.tomcat.util.http.fileupload.IOUtils;
import org.bson.types.ObjectId;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.MongoDbFactory;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.gridfs.GridFsResource;
import org.springframework.data.mongodb.gridfs.GridFsTemplate;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;
import java.io.InputStream;


/**
 * 文件上传下载
 * MongoTemplate
 **/
@Controller
@RequestMapping("/file")
public class FileController {
    // 获得SpringBoot提供的mongodb的GridFS对象
    @Autowired
    private GridFsTemplate gridFsTemplate;
    @Resource
    private MongoDbFactory mongoDbFactory;
    /**
     * 文件上传
     */
    @RequestMapping(value = "/upload", method = RequestMethod.POST)
    @ResponseBody
    public String uploadFile(@RequestParam("file")MultipartFile multiportFile) throws Exception {

        String fileName = multiportFile.getOriginalFilename();
        // 获得文件输入流
        InputStream ins = multiportFile.getInputStream();
        // 获得文件类型
        String contentType = multiportFile.getContentType();
        // 将文件存储到mongodb中,mongodb 将会返回这个文件的具体信息
        ObjectId objectId = gridFsTemplate.store(ins, fileName, contentType);
        //将文件信息保存到关系型数据库中进行维护

        return "id===>" + objectId.toHexString(); //id 16进制字符串, 一定拿到
    }

    /**
     * 下载
     *
     * @param fileId   文件id
     */
    @RequestMapping(value = "/down")
    public void downloadFile(@RequestParam(name = "file_id") String fileId, HttpServletRequest request, HttpServletResponse response) throws Exception {
        System.out.println("Finding by ID: " + fileId);
        // fileId 16 进制字符串
        GridFSFile fsFile = gridFsTemplate.findOne(new Query(Criteria
                .where("_id").is(new ObjectId(fileId))));
        //打开下载流对象

        //获取数据库 demodb
        MongoDatabase db = mongoDbFactory.getDb();
        System.out.println("db===> " + db.getName());
        GridFSBucket gridFSBucket = GridFSBuckets.create(db);
        GridFSDownloadStream gridFSDownloadStream = gridFSBucket.openDownloadStream(fsFile.getObjectId());
        //创建GridFsResource用于获取流对象
        GridFsResource resource = new GridFsResource(fsFile, gridFSDownloadStream);
        
        String fileName = fsFile.getFilename().replace(",", "");
        //处理中文文件名乱码
        if (request.getHeader("User-Agent").toUpperCase().contains("MSIE") ||
                request.getHeader("User-Agent").toUpperCase().contains("TRIDENT")
                || request.getHeader("User-Agent").toUpperCase().contains("EDGE")) {
            fileName = java.net.URLEncoder.encode(fileName, "UTF-8");
        } else {
            //非IE浏览器的处理:
            fileName = new String(fileName.getBytes("UTF-8"), "ISO-8859-1");
        }
        // 通知浏览器进行文件下载
        response.setContentType("multipart/form-data");
        response.setHeader("Content-Disposition", "attachment;filename=\"" + fileName + "\"");
        IOUtils.copy(resource.getInputStream(), response.getOutputStream());
    }

    /**
     * 删除文件
     *
     */
    @RequestMapping(value = "/remove")
    @ResponseBody
    public String  deleteFile(@RequestParam(name = "file_id") String fileId) {
        Query query = Query.query(Criteria.where("_id").is(fileId));
        // 查询单个文件
        GridFSFile gfsfile = gridFsTemplate.findOne(query);

        gridFsTemplate.delete(query);
        return "删除==>" + gfsfile.getFilename();
    }

}

拿到 id 返回值非常关键

   ObjectId objectId = gridFsTemplate.store(ins, fileName, contentType);
   //将文件信息保存到关系型数据库中进行维护
   
  这个值需要保存在 产品表中对应的文件的图片的 id
   String  fileId= objectId.toHexString();    //转成 16 进制的字符串
   
   如果用的 mysql 数据库也是如此, 也是如此
   这样你的 mysql 就保存交易数据, 描述性的数据就在 MongoDB
   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风雨河岸柳

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值