将Blob文件保存到服务器

5

我正在尝试将录制的文件保存到服务器上。为了录制目的,我正在使用演示录音机

在录制结束时,它会给我一个指向录制文件的blob链接。因此,在进行了一些搜索之后,我发现可以使用该bob url进行保存。
这里是讨论保存blobs的链接。 之后,我正在尝试获取它并下载到服务器。

1- 我得到了指向blob文件的链接。

var data = document.getElementById("save").href

接下来,我在我的index.html文件中使用js代码发送blob url到php代码。
JS代码

<script>
function saveAudio(){
var req = null;
var url = "savefile.php";
var data = document.getElementById("save").href.toString();// document.getElementById("save").innerHTML;// = xhttp.responseText;;   // you have to check how to get the data from your saveAudio() method
window.alert(data);

(window.XMLHttpRequest) ? req = new XMLHttpRequest() : (window.ActiveXObject) ? req = new ActiveXObject("Microsoft.XMLHTTP") : req = false; 
req.open("POST", url, true);
req.setRequestHeader("Content-Type", "multipart/form-data");

if(data != null) //&& data != "")
{
  req.setRequestHeader("Content-length", data.length);
  req.send(data);
}}


</script>

PHP 代码

<?php

$save_folder = dirname(__FILE__) ."/js";
if(! file_exists($save_folder)) {
    if(! mkdir($save_folder)) {
        die("failed to create save folder $save_folder");
    }
}

$key = 'filename';
$tmp_name = $_FILES["audiofile"]["tmp_name"];
$upload_name = $_FILES["audiofile"]["name"];
$type = $_FILES["audiofile"]["type"];
$filename = "$save_folder/$upload_name";
$saved = 0;
if(($type == 'audio/x-wav' || $type == 'application/octet-stream') && preg_match('/^[a-zA-Z0-9_\-]+\.wav$/', $upload_name) ) {

    $saved = move_uploaded_file($tmp_name, $filename) ? 1 : 0;
}

//name is needed to send in the php file

?>

在浏览器编译时,我遇到了两个错误:
1-拒绝设置不安全的头"Content-length"。
2-POST savefile.php 500

我猜测是php文件出了问题!
我该如何处理这些错误并完成上传任务?
有没有任何开源工具可以直接将Blob-URL上传到服务器而不使用php?
非常感谢您的帮助和建议!

1个回答

1

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接