В Nodejs / Loopback загружаемый файл не работает с мультером - PullRequest
0 голосов
/ 06 мая 2019

Используя Loopback, у меня есть удаленный метод, который выполняет 3 SQL-запроса. Я хотел добавить загрузку файла, но у меня возникла проблема: файл не загружается, я использую multer для загрузки. На самом деле, когда я хочу проверить с помощью POSTMAN, он выполняется правильно без ошибок, за исключением того, что загрузка файла не работает, поэтому изображение не копируется в указанную папку, а пересечение пути в третьем запросе показывает неопределенный в базе данных (очевидно, потому что нет пути, чтобы найти, когда нет загрузки файла). Я не нашел свою ошибку, любая помощь будет оценена. Спасибо

Это мой дистанционный метод:

 module.exports = function(cm_comediens) {

   cm_comediens.upload = function (comedien_perso_nom,comedien_perso_prenom,nationalite,options,req,res,cb) {
      const token = options && options.accessToken;
      const userId = token && token.userId;
      var ds = app.datasources.mydb;

      var uploadedFileName = '';
      var storage = multer.diskStorage({
        destination: function (req, file, cb) {
          // checking and creating uploads folder where files will be uploaded
          var dirPath = 'server/storage/common'
          if (!fs.existsSync(dirPath)) {
              var dir = fs.mkdirSync(dirPath);
          }
          cb(null, dirPath + '/');
      },
      filename: function (req, file, cb) {
          // file will be accessible in `file` variable
          var ext = file.originalname.substring(file.originalname.lastIndexOf("."));
          var fileName = Date.now() + ext;
          uploadedFileName = fileName;
          cb(null, fileName);
                }
      });
      var upload = multer({storage: storage}).single('photoscomedien');
      upload(req, res, function (err) {
      if (err) {res.json(err);}

      var sql = "UPDATE cm_comediens SET comedien_perso_nom=?,comedien_perso_prenom=?,nationalite=? WHERE id_comedien IN ( SELECT id_comedien FROM (SELECT id_comedien FROM cm_comediens WHERE id_utilisateur= '" + userId + "') as MakeitWork) ";
      var sql2 = "UPDATE photoscomedien SET photo_profile=0 WHERE id_comedien IN ( SELECT id_comedien FROM (SELECT id_comedien FROM cm_comediens WHERE id_utilisateur= '" + userId + "') as MakeitWork2)";
      var sql3 = "INSERT INTO photoscomedien (id_comedien,photo_profile,path,name) VALUES ((SELECT id_comedien FROM cm_comediens WHERE id_utilisateur= '" + userId + "'),1,'" + req.file.path + "','" + req.file.originalname + "')";

      ds.connector.execute(sql, [comedien_perso_nom,comedien_perso_prenom,nationalite], function (err, cm_comedienss) {
      ds.connector.execute(sql2, [], function (err, cm_comedienss) {
      ds.connector.execute(sql3, [], function (err, cm_comedienss) {
          if (err) console.error(err);
          cb(err,[cm_comedienss,uploadedFileName]); 
      });
      });
      });      
      });     

  };
  cm_comediens.remoteMethod(
      'upload',
      {
          http: { verb: 'PUT' },
          description: 'Update Comediens Infos Mon Profil Bloc 1 et Update photos',
           accepts:[
           { arg: 'comedien_perso_nom', type: 'string' },
           { arg: 'comedien_perso_prenom', type: 'string' }, 
           { arg: 'nationalite', type: 'string' } ,
           { arg: "options", "type": "object", "http": "optionsFromRequest"},
           { arg: 'req',type: 'object',http: {source: 'req'}},
           { arg: 'res',type: 'object',http: {source: 'res'}},
          ],
          returns: {arg: 'result',type: 'string',root: true}
      }
  );    }
...