使用PHP将datauri保存到png文件-创建空png文件

使用PHP将datauri保存到png文件-创建空png文件,php,image,base64,png,Php,Image,Base64,Png,我已经尝试了十几种方法将svg生成的dataurl保存到我的服务器。这段代码似乎应该基于我在这里读到的其他线程工作,但出于某种原因,它只是创建了一个0 KB的.png文件。我继续,只是将dataurl复制/粘贴到我的脚本中,以避免现在任何数据被发送到php的问题,我只想看到php正确地创建图像。这是我的密码: $img="

我已经尝试了十几种方法将svg生成的dataurl保存到我的服务器。这段代码似乎应该基于我在这里读到的其他线程工作,但出于某种原因,它只是创建了一个0 KB的.png文件。我继续,只是将dataurl复制/粘贴到我的脚本中,以避免现在任何数据被发送到php的问题,我只想看到php正确地创建图像。这是我的密码:

$img="...j/bZbdmX23g8nv8GSJ7ZsQ3ZHlk6Ep0rW9snCcckDs0DcHSQjueyQrtUSk3vxZJoBMTOLckTx2Yghs3P3CWEc+N3/zspUOm3ASgz3URJWTtzMKXs29tifqCgWQhhcxMVEnFFonqgOcZO8Ds7M0Z047hjsOZMR3vQyzWXyfMTFRt994pBQR2LhrcIvriGdwCehohj4maWScTRECI6ZGNfe3jx/21soaLiNE5i2SEpOsfixVSgvxxGehnn9VbTHBWrMOal3w2bG5MTGxWboZu7dqNeStcNteMre7Fy4Wn7t+CZsKNNoHnMNEI2EEWAoN8WZiEgC4kF2pHxYOITWLMlU+RvvcDoneMDkltqVAVJoVFpTm07gOA2iq+gVkysWf6LhbS5zQwffwpVFP+/NpqC3UqggiE5OQG4cv0xcBCCfeDN7wSFBW4AP8+4uWOly+XA950crPd0NJedRscdMfAdsrC+soAUpOHgGTDtbl8aqmV808tWtu5K9VWzcsjO/KP10455EO2iQBQQ0OJkSTfmNIlh4n2ZzpMy+vb5XskomJjjuS1xQZAQwfzrUXt8BT/BgYaxfgw/KHEJqaRXttZDAVDsA5TBSCmeBQVG5cbyoZ4KmTuJwRE3m1wWHrOiggWFs9vVHo/fPvH/VMcdjw+g64fnlHl4OhyfhexFxPzUxD1Cem9s7xOsiy7VVcbopKDZnCAyOQLVhDfZMUE5Nk9hjPkhICXn6TtuKz8ERuwiUgMcFTuu022pTgbjntjlPHvagEbGwSaAmXNh1M+1BoA1yEhSDx2DPykdh3ccSdKpe9D/9NULn9f1p2y7T/HPb5LkS5YYI3jG7DRJKYMkH619X6dEmtRu2ykKBgdWR6rexDn9l6tyMLHOKctWRJ9scaQ/+6Z5FXjVk+/zjn5yBkul52XNP2G2d+jbDRs3wpZosF886zgIHnf4IP4T2Ll7P/ScKbgqqnMbSbCWLCAgg5nWm1S0LepraXoTmk8t6am4yQykbeAPpwYEp8TNwmtSWo6fo5/B2JQSOCgtfjM/kZeD+iqebYtcvi9bMfeBoRJBD43sSGBOTnF897Vdtv7pon/vvrl3uHPlwL1imjrTbzdq0mqDbhHF77/2+0YTJok+Kow2gRAg7L5gQw/v8PaqCA15/YCYqB15+MnqVBi9DGNBN6SNcPoAzH6FZh+oQ5NWwZare9UsPPQ8kM0OLkg8DRlQffv2J1NrbTekENlrvfPhNsqMAMpFZHArRWBTQKA2rUIAPItBIveGHsU+CZL7vfvgBLD4VyYnTEZCjllkHsVtD2YuAiskbY+hNcQ4qD2AtDzmmgAgl0ERwQ/AEO+7KAenCjYGiEAKxhQqtdHUMjFAa/K0EjGaDRhktfP/7/BV33AYqzBGklvMcnwE6rBY3MYBtNocXFjaDGFOh6Cvj0D45FvaMNk8Gf7kZdOBoCoyEwGgKjITAaAqMhMIhCAAC+P4HZvnVG3QAAAABJRU5ErkJggg==";

$filedata = substr($img, strpos($img,",")+1);

file_put_contents("testfile2.png", base64_decode($filedata));

echo "file created";
下面是生成数据的jquery代码。我只是将其从警报复制到脚本中的测试:

$("#testclick").click(function() {

var svg = document.getElementById("map").innerHTML; // or whatever you call it
//alert(svg);
 $('#load-target').html(svg);

var canvas = $('#load-target svg')[0];
try {
  svgAsDataUri(canvas, null, function(uri) {
  var image = new Image();
        image.src = uri;
        image.onload = function() {
        var canvas = document.createElement('canvas');
        canvas.width = image.width;
        canvas.height = image.height;
        var context = canvas.getContext('2d');
        context.drawImage(image, 0, 0);

        var a = document.createElement('a');
        a.download = name;
        alert(canvas.toDataURL('image/png'));
        a.href = canvas.toDataURL('image/png');
        document.body.appendChild(a);
        a.click();
        }

    //alert(uri);
    $.post("http://www.srqnews.com/maps/create.php",
    {
        type:"PNG",
        datauri:uri
    },
    function(data,status){
        alert("Data: " + data + "\nStatus: " + status);
    });
  });
} catch(err) {
  alert(err.message);
}

});

b64_decode在失败时返回布尔值FALSE,该值将作为零长度字符串输出。尝试$data=base64_解码。。。;如果$data==false{dieb64数据已损坏;},则我的jquery必须创建错误数据。在jquery代码中编辑可能会像substr操作走得太远和对b64数据的第一个字符进行切片一样简单。我尝试只插入逗号后的文本,而不使用相同的结果执行substr操作。我猜我的jquery不知何故导致了坏数据。呃,这是新的东西,所以我要花很长时间才能把它做好。