分片上传文件,后端接收怎么生成了一个文件名为blob的文件?

最近在做一个视频上传的功能,所以用到了分片上传,因为之前没做过,所以结合网上的一些例子也大概知道了思路,自己也尝试了,然后发现后端生成了一个文件名为blob的文件。实在是搞不懂所以请教下大佬们,顺便贴下代码。
前端代码:

UploadChunk(event: any) {

let file = event.target.files[0];

var bytesPerPiece = 1024 * 1024 * 2; // 每个文件切片大小定为2MB

var totalPieces; //切片总数

var fileHash = "" //文件加密后的hash

var filesize = file.size; //文件大小

var start = 0; //开始切割的位置

var end; //切割的结束位置

JsUtilsApi.md5File(file).then(

(md5:string)=>{

console.log("md5", md5)

fileHash = md5

totalPieces = Math.ceil(filesize / bytesPerPiece); //计算切片总数

while(start < filesize) {

console.log("asdasd")

end = start + bytesPerPiece;

if(end > filesize) {

end = filesize;

}

var chunk = file.slice(start, end); //切割文件

var formData = new FormData();

formData.append('file', chunk);

formData.append("hash", fileHash);

this.http.post('http://localhost:8090/api/uploadChunk', formData).subscribe(

(response) => {

console.log("res", response)

},

(error) => {

console.log("err", error)

}

)

start = end;

}

},

(error)=>{

console.log(error);

}

);

}

后端代码:

func UploadChunk(w http.ResponseWriter, r *http.Request) {

w.Header().Set("Access-Control-Allow-Origin", "*")

fileHash := r.FormValue("hash")

file, fileHeader, err := r.FormFile("file")

if err != nil {

log.Println("read file err", err)

return

}

defer file.Close()

var fileBuff []byte

_, err = file.Read(fileBuff)

if err != nil {

fmt.Println("read file err", err)

return

}

nowDate := time.Now().Format("20060102")

hashPath := fmt.Sprintf("%svideo/%s/%s", conf.Conf.UploadPath, nowDate, fileHash)

err = utils.IsFolder(hashPath)

if err != nil {

log.Println("create folder fail", err)

return

}

//err = ioutil.WriteFile(fmt.Sprintf("%s/%s", hashPath, fileHeader.Filename), fileBuff, 0666)

//if err != nil {

// log.Println("write file err", err)

// return

//}

out, err := os.Create(fmt.Sprintf("%s/%s", hashPath, fileHeader.Filename))

if err != nil {

log.Println("create file err", err)

return

}

defer out.Close()

_, err = io.Copy(out, file)

if err != nil {

log.Println("write file err", err)

return

}

}

回答

formData.append('file', chunk);

问题就在这里 append 是可以添加第三个参数的,就是文件名
image.png

以上是 分片上传文件,后端接收怎么生成了一个文件名为blob的文件? 的全部内容, 来源链接: utcz.com/a/40890.html

回到顶部