Lo que estoy tratando de lograr aquí es convertir una foto de ImageCapture (construida por un VideoTrack de un MediaStream), que es básicamente un blob, enviarla usando FormData a través de una solicitud posterior de Ajax al servidor, y luego en el lado del servidor convertirlo nuevamente en imagen , que lamentablemente es la parte problemática: no sé cómo construir un archivo y guardarlo. Intenté FileSaver.js y usé File from file-class, pero no pude descubrir cómo convertirlo en un png.
Para más aclaraciones, aquí están mis lados de cliente y servidor:
lado del cliente
ImageCapture.takePhoto().then(photo => { console.log(photo) let photoAsFormData = new FormData() photoAsFormData.append("file", photo, '' + ID + '.png'); $.ajax({ type: 'POST', url: 'http://localhost:3030/test/' + ROOM_ID + '/' + ID + '/', data: photoAsFormData, processData: false, contentType: false, success: function(msg){ console.log('posted' + msg); } }); }).catch(e => { console.log(e) })
lado del servidor
app.post('/test/:room/:userId',(req,res) => { let blob = req.files.file // 'file' was appended to FormData console.log(blob) })
y aquí hay un ejemplo de lo que obtengo de console.log(blob)
:
{ name: '9a890613-3d78-40cb-9f38-8188daeae834.png', data: <Buffer 89 50 4e 47 0d 0a 1a 0a 00 00 00 0d 49 48 44 52 00 00 02 80 00 00 01 e0 08 02 00 00 00 ba b3 4b b3 00 00 20 00 49 44 41 54 78 9c ec bd dd 96 34 37 92 ... 183961 more bytes>, size: 184011, encoding: '7bit', tempFilePath: '', truncated: false, mimetype: 'image/png', md5: 'de593a55b911c7a9c82917babcc3df53', mv: [Function: mv] }
Está marcado en el lado del cliente como 'Blob', así que supuse que FileSaver.SaveAs([blob], *fileName*)
funcionaría, pero no se guardó en el directorio ~/Download como se esperaba, y no arrojó ningún error .
TL; DR: ¿cómo debo convertir el búfer de Blob en un archivo PNG y guardarlo?
En otra nota , estoy tratando de enviar la imagen al servidor, y después de saber que puedo ver la imagen en ese lado, la enviaré a un microservicio de python. Sólo necesito saber que se puede interpretar.