Image created with blob only contains numbers and commas

吃可爱长大的小学妹 提交于 2019-12-24 19:40:54

问题


I have a file on my device that is stored in a folder like:

/opt/share/folder/image.jpg

I'd like to upload this file on my server using some ajax request just as I'd do with a standard HTML form.

After few searches, I've come to create a Blob file and upload it on the server; this works. But the problem is that my jpeg at the arrival is corrupted and contains a suit of numbers and commas (technically, Bytes of the source file):

255,216,255,224,0,16,74,70,73,70,0,1,1,0,0,1,0,1,0,0,255,219,0,67,0,8,6,6,7,6,5,8,7,7

The Filesystem API of Tizen allows me to open this file and read its bytes - which is what I do. So I use the following code to read bytes, create a blob and upload it on my server:

var raw = fs.readBytes(1024);                    
var blob = new Blob([raw], {type:"image/jpeg"});
var formData = new FormData();
formData.append('screenCapture', blob);

$.ajax({
   type: 'post',
   url: myurl,
   processData: false,
   contentType: false,
   data: formData,
   success: function(data){
             ...

   },
   error: function(jqxhr, status, msg){
          console.log("ERROR! " + msg);
          }
});

回答1:


I finally found what was wrong with my code.

In fact, readBytes return an array of number corresponding to bytes, but the array isn't formatted as a byte array.

Creating a new Uint8Array from this array did the trick:

var raw = fs.readBytes(1024);
var byteArray = new Uint8Array(raw);
var blob = new Blob([byteArray], {type:"image/jpeg"});


来源:https://stackoverflow.com/questions/47793606/image-created-with-blob-only-contains-numbers-and-commas

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!