如何在javascript中将文件转换为字节流

SSS*_*SSS 5 javascript

如何将文件转换为字节数组。

下面的另一种方式

let file = new File([myBlob], "name");
Run Code Online (Sandbox Code Playgroud)

文件需要转换成字节流

Art*_*pov 3

您可以尝试使用浏览器中提供的 FileReader API。

let file = new File(...) // this could be from file input or other source
let fileReader = new FileReader();

fileReader.readAsArrayBuffer(file);
fileReader.onload = function(ev) {
    const result = ev.target.result;
    console.log(result); // here it is
}
Run Code Online (Sandbox Code Playgroud)

根据这个答案,如果结果readAsArrayBuffer不适合您,您可能需要将其转换为真正的byte[]使用new Uint8Array。这是上述代码的扩展版本:

let file = new File(...) // this could be from file input or other source
let fileReader = new FileReader();

fileReader.readAsArrayBuffer(file);
fileReader.onload = function(ev) {
    const array = new Uint8Array(ev.target.result);
    const fileByteArray = [];
    for (let i = 0; i < array.length; i++) {
       fileByteArray.push(array[i]);
    }
    console.log(array); // here it is
}
Run Code Online (Sandbox Code Playgroud)

这是为了舒适使用而包装的实现:

function getByteArray(file) {
   return new Promise(function(resolve, reject) {
       fileReader.readAsArrayBuffer(file);
       fileReader.onload = function(ev) {
           const array = new Uint8Array(ev.target.result);
           const fileByteArray = [];
           for (let i = 0; i < array.length; i++) {
               fileByteArray.push(array[i]);
           }
           resolve(array);  // successful
       }
       fileReader.onerror = reject; // call reject if error
   })
}

//usage
let file = new File(...)
getByteArray(file).then((byteArray) => {
    // do whatever you need
    console.log(byteArray);
})
Run Code Online (Sandbox Code Playgroud)

PS 如果由于某种原因无法参考ev.target,请尝试使用fileReader.result