微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

将二进制字符串保存到POST发送的php文件中

我有一个用于(.jpg,.ai,.pdf,.flv,.psd …. etc.)的拖放上传

我正在读取文件为二进制文件,并在jquery帖子中发送字符串:

function importZoneDrop(evt) {
    evt.stopPropagation();
    evt.preventDefault();

    var files = evt.dataTransfer.files; // FileList object.

    // files is a FileList of File objects. List some properties.
    for (var i = 0, f; f = files[i]; i++) {
        var start = 0;
        var stop = files[0].size - 1;
        var reader1 = new FileReader();
        var reader2 = new FileReader();
        var ext = f.name.substring(f.name.indexOf(".")+1);
        if(ext == "JPEG" || ext == "jpeg" || ext == "JPG"){
            ext ="jpg";
        }

        reader1.onload = (function(theFile) {
            return function(e) {
              // Render thumbnail.
              $("#import-drop-zone").append('<img src="'+e.target.result+'" />');
            };
         })(f);

        reader2.onloadend = function(evt) {
          if (evt.target.readyState == FileReader.DONE) { // DONE == 2
            $.post("/process/upload.PHP",{"blob":evt.target.result,"extension":ext},function(data){
                console.log(data);
            });
          }
        };

        reader1.readAsDataURL(f);
        var blob = f.slice(start, stop + 1);
        reader2.readAsBinaryString(f);
    }
  }

这可以正常工作并发送文件.接下来获取字符串并使用file_put_contents编写它:

$extension = $_POST['extension'];
$file = $_POST['blob'];//sent from jquery post
$filePath = "../_temp/monkey.".$extension;

file_put_contents($filePath,$file);
if(file_put_contents($filePath,$file)){
    echo json_encode("it worked");
}else{
    echo json_encode("it Failed");
}

这将成功写入文件.但是该文件不起作用,它已损坏.

我究竟做错了什么?

解决方法:

您需要使用base64_decode.

file_put_contents($filePath, base64_decode($file));

请注意,您当前正在两次写入数据.别.

if (file_put_contents($filePath, base64_decode($file))) {

很好

编辑

另外,直接上传二进制文件效率更高也没有任何价值,然后可以跳过base64_decode.像这样:

var xhr  = new XMLHttpRequest(),
    data = new FormData();

data.append("file", f); // You don't need to use a FileReader
// append your post fields

// attach your events
xhr.addEventListener('load', function(e) {});
xhr.upload.addEventListener('progress', function(e) {});

xhr.open('POST', '/process/upload.PHP', true);
xhr.send(data);

您可以查看一些示例here的其余事件here.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐