修改从loopback-component-storage

时间:2015-06-25 11:06:45

标签: node.js express loopbackjs strongloop

我正在使用loopback将图片存储到server

我想在保存到服务器之前修改文件的文件名

此外,我想在保存之前将其转换为另一种缩略图形式。

以下是我的工作方式。

  

在客户端

Upload.upload(
{
    url: '/api/containers/container_name/upload',
    file: file,
    fileName: "demoImage.jpg",
    //Additional data with file
    params:{
     orderId: 1, 
     customerId: 1
    }
});
  

在服务器端,我收到了查询" params"但没有得到"文件名"

我的存储模型名称为container

Container.beforeRemote('upload', function(ctx,  modelInstance, next) {

    //OUPTUTS: {orderId:1, customerId:1]}
    console.log(ctx.req.query);

    //Now I want to change the File Name of the file.
    //But not getting how to do that

    next();
})

如何更改在服务器上保存的文件的文件名?

2 个答案:

答案 0 :(得分:23)

我明白了。

我们必须在boot/configure-storage.js中定义自定义函数 getFileName

假设loopback-component-storage数据源 presImage

  

服务器/引导/配置-storage.js

module.exports = function(app) {
    //Function for checking the file type..
    app.dataSources.presImage.connector.getFilename = function(file, req, res) {

        //First checking the file type..
        var pattern = /^image\/.+$/;
        var value = pattern.test(file.type);
        if(value ){
            var fileExtension = file.name.split('.').pop();
            var container = file.container;
            var time = new Date().getTime();
            var query = req.query;
            var customerId = query.customerId;
            var orderId    = query.orderId;

            //Now preparing the file name..
            //customerId_time_orderId.extension
            var NewFileName = '' + customerId + '_' + time + '_' + orderId + '.' + fileExtension; 

            //And the file name will be saved as defined..
            return NewFileName;
        }
        else{
            throw "FileTypeError: Only File of Image type is accepted.";
        }
    };
}
  

公共/模型/ container.js

现在假设我的容器模型是container

module.exports = function(Container) {
    Container.afterRemote('upload', function(ctx,  modelInstance, next) {
      var files = ctx.result.result.files.file;

      for(var i=0; i<files.length; i++){
        var ModifiedfileName = files[i].name;
        console.log(ModifiedfileName) //outputs the modified file name.
      } //for loop
      next();
    }); //afterRemote..
};

现在将图片转换为缩略图尺寸

下载quickthumb

以下是如何将其与环回一起使用。

此代码直接从Loopback thumbnail view

复制
  

公共/模型/ container.js

module.exports = function(Container) {

    var qt = require('quickthumb');

    Container.afterRemote('upload', function(ctx, res, next) {

        var file = res.result.files.file[0];
        var file_path = "./server/storage/" + file.container + "/" + file.name;
        var file_thumb_path = "./server/storage/" + file.container + "/thumb/" + file.name;

        qt.convert({
            src: file_path,
            dst: file_thumb_path,
            width: 100
        }, function (err, path) {

        });

        next();
    });

};

答案 1 :(得分:0)

根据上面的答案,这个配置存储可以通过req.params.filename显式设置文件名,如果没有提供,则默认为现有名称。

  

配置-storage.js

module.exports = function(app) {

//Function for checking the file type..
    app.dataSources.storage.connector.getFilename = function(file, req, ignoreRes) {

        if (!req.params.filename) {
            return file.name
        }

        var fileExtension = file.name.split('.').pop()
        return req.params.filename + '.' + fileExtension

    };
}