【发布时间】:2021-05-12 16:05:02
【问题描述】:
我正在制作一个获取音频的 chrome 扩展,并将其发送到 python 服务器(带有 HttpServer),服务器保存音频。
问题是服务器没有正确保存音频,音频无法播放
JS:
let gapBlob = new Blob(gapRecord.recording, { type: "video/webm" });
let currGapAudio = document.getElementById("recording" + gapId)
currGapAudio.src = URL.createObjectURL(gapBlob);
var myHeaders = new Headers();
myHeaders.append("Content-Type", "multipart/form-data");
var formdata = new FormData();
formdata.append("AudioFile",gapBlob, "my_audio.wav");
var requestOptions = {
method: 'POST',
headers: myHeaders,
body: formdata,
redirect: 'follow'
};
fetch("http://localhost:8080/", requestOptions)
.then(response => response.text())
.then(result => console.log(result))
.catch(error => console.log('error', error));
- 在前两行中,我使用
<audio />元素向客户端显示音频,效果很好。
python 服务器:
def do_POST(self):
self.send_header('Access-Control-Allow-Origin', '*')
file_length = int(self.headers['Content-Length'])
newname = 'server/uploaded' + str(random.randint(100,999)) + '.wav'
with open(newname, 'wb') as output_file:
content = self.rfile.read(file_length)
content = content.split(b'Content-Type: video/webm')[1]
content = content[4:]
content = content.split(b'------')[0]
output_file.write(content)
- 分裂是因为身体看起来像这样:
b'------WebKitFormBoundary3joaVYqdXgqiCh0X\r\nContent-Disposition: form-data; name="AudioFile"; filename="my_corrupted.wav"\r\nContent-Type: video/webm\r\n\r\n\x1aE\xdf\xa3\....2\xef\x06}\xa8\xc2\xd7\x9b\xee\xd9\xed2\x16\x0f\xdd\x07U\xef\x9f\xdf\xcb\x16Hk\xfd\x81n2=\xc3\r\n------WebKitFormBoundary3joaVYqdXgqiCh0X--'
我试图通过拆分删除附加到正文的额外文本,但没有帮助。
有人知道吗?
谢谢
【问题讨论】:
标签: javascript python audio fetch fetch-api