Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/vba/16.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 通过ajax向multer发送图像_Javascript_Html_Node.js_Ajax_Multer - Fatal编程技术网

Javascript 通过ajax向multer发送图像

Javascript 通过ajax向multer发送图像,javascript,html,node.js,ajax,multer,Javascript,Html,Node.js,Ajax,Multer,我使用Multer将一个图像文件上传到我的节点服务器上,它总是返回给我未定义的使用ajax发送图像 阿贾克斯: image = $("#input-file-img").val() const data = new FormData(); data.append("image", image); $.ajax({ url: '/uploadfile/' +

我使用Multer将一个图像文件上传到我的节点服务器上,它总是返回给我未定义的使用ajax发送图像

阿贾克斯:

image = $("#input-file-img").val()
                const data = new FormData();
                 data.append("image", image);
                 $.ajax({
                    url: '/uploadfile/' + userName,
                    method: 'POST',
                    async: false,
                    processData: false ,
                    contentType: false,
                    data: data
                })
Upload.js

var storage = multer.diskStorage({
  destination: function (req, file, cb) {
    cb(null, 'uploads')
  },
  filename: function (req, file, cb) {
    cb(null, file.originalname)
  }
})
var upload = multer({ storage: storage })

router.post('/uploadfile/:userName', upload.single('image'), async (req, res, next) => {
  let user = await User.findOne({ userName: req.params.userName })
  let file = req.file
  let fileName = file.filename
  let path = variables.kepler + 'uploads/' + fileName
  user.image = path
  await user.save()
  if (!path) {
    const error = new Error('Please upload a file ...')
    error.httpStatusCode = 400
    return next(error)
  }

  if (path) {
    return res.status(200).send({
      status: '200',
      message: 'Operation completed successfully ...',
      data: user,
      path
    })
  }
})
我用控制台检查了图像值,它显示C:\fakepath\Capture d'e cran de 2019-09-19 11-33-59.png'


非常感谢您的帮助。

我认为您的服务器端代码很好,如果我按以下方式修改客户端代码,一切都很好,我们最终会在/uploads文件夹中显示图像:

function base64toBlob(base64, mimeType) {
    const bytes = atob(base64.split(',')[1]);
    const arrayBuffer = new ArrayBuffer(bytes.length);
    const uintArray = new Uint8Array(arrayBuffer);
    for (let i = 0; i < bytes.length; i++) {
        uintArray[i] = bytes.charCodeAt(i);
    }
    return new Blob([ arrayBuffer ], { type: mimeType });
}

function submitForm() {         
    const imgRegEx = /^data:(image\/(gif|png|jpg|jpeg))/;
    const imageData = $('#input-file-img').attr('src');
    const mimeType = imgRegEx.exec(imageData)[1];
    const blob = base64toBlob(imageData, mimeType);

    const fileExt = mimeType.replace("image/", "");
    const fileName = "test-image." + fileExt; // Change as appropriate..

    const data = new FormData();
    data.append("image", blob, fileName);

    $.ajax({
        url: '/uploadfile/' + userName,
        method: 'POST',
        async: false,
        processData: false ,
        contentType: false,
        data: data
    })
}
函数base64toBlob(base64,mimeType){
常量字节=atob(base64.split(',')[1]);
const arrayBuffer=新的arrayBuffer(bytes.length);
const uintArray=新的uint8阵列(arrayBuffer);
for(设i=0;i
已解决

从中获取价值

image = $("#input-file-img").val()
这意味着我正在发送一个类型字符串作为文件

所以我不得不把它改成

image = $('#input-file-img')[0].files[0]
一切都很顺利