簡體   English   中英

html5 canvas toDataURL返回空白圖像

[英]html5 canvas toDataURL returns blank image

從空白畫布開始:

<canvas id='myCanvas' width='800' height='600'></canvas>

然后初始化該畫布:

  function init_canvas(){
    var canvas = document.getElementById('myCanvas');
    context = canvas.getContext('2d');
    context.lineCap = 'round';
    // fill it with white background
    context.save();
    context.fillStyle = '#fff';
    context.fillRect(0, 0, context.canvas.width, context.canvas.height);
    context.restore();
    return;
  }

然后在畫布上做一堆繪圖。

然后嘗試使用后端的ajax和PHP將其保存到服務器。

在客戶端:

var img = canvas.toDataURL('image/png');
// strip the leading garbage.
img.substr(img.indexOf(',')+1).toString();

將生成的字符串(base64編碼的png)直接輸入到PHP和base64_decode()字符串...圖像總是正確的大小,但它沒有任何繪圖 - 只是一個透明的圖像。 這似乎不是PHP中的base64_decode()的問題,它似乎是一個安全的事情。 Firefox 4和最新的Chrome都失敗了。

使用“image / png”標頭將生成的png圖像轉儲到firefox會在錯誤控制台中生成:

Error: Image corrupt or truncated: http://somewhere.com/showimage.php
Source file: http://somewhere.com/showimage.php

但是......除非toDataURL()在任何地方都被破壞,否則圖像不會被破壞或被截斷,因為php的東西只是base64_decode()toDataURL()的結果。

有任何想法嗎?

謝謝!

你有沒有在base64_decode的PHP文檔中看到這個評論

如果要保存從Javascript canvas.toDataURL()函數派生的數據,則必須將空格轉換為加號。 如果不這樣做,解碼數據將被破壞:

 <?php $encodedData = str_replace(' ','+',$encodedData); $decocedData = base64_decode($encodedData); ?> 

這工作正常,沒有返回空白圖像。

saveImage.php

 <?php 
        $result = array();  
        $encodedData = explode("," , $_POST['imgData'])[1];
        $encodedData = str_replace(' ','+',$encodedData);
        $decocedData = base64_decode($encodedData); 
        //Location to where you want to save image
        $NewFileName = './photos/'.$_POST['imgName'].'.jpg';
        file_put_contents($NewFileName,$decocedData);
        $result['status'] = 1;
        $result['saveImage'] = $NewFileName;
        echo json_encode($result);
    ?>

的script.js

<script>
//This post the data to server on fly

function saveImage(canvasData,FileName) {
  var xmlHttpReq = false;

  if (window.XMLHttpRequest) {
    ajax = new XMLHttpRequest();
  }
  else if (window.ActiveXObject) {
    ajax = new ActiveXObject("Microsoft.XMLHTTP");
  }

  ajax.open("POST", "saveImage.php", false);
  ajax.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
  ajax.onreadystatechange = function() {

    if (this.readyState == 4 && this.status == 200) {
        var rawArr = JSON.parse(this.responseText);
        var ImagePreviewer= document.getElementById("ImagePreviewer");
    ImagePreviewer.src=rawArr.saveImage;
    //console.log(rawArr.saveImage);
    }

  }
  ajax.send("imgData=" + canvasData+"&imgName=" + FileName);
}
// Call this with button click or whatever you want 
function saveJPG(filename) {
//do other logic here
var dataURL = TheCanvas.toDataURL("image/jpg");
    saveImage(dataURL,filename);
}
<script>

在JavaScript中,在支持此方法的瀏覽器上發送canvas.toDataURL()的結果,默認類型為“image / png”。

var imageInfo = canvas.toDataURL();

直接創建png文件的方法:

<?php
$imageInfo = imageInfoFromBrowser(); // Your method to get the data
$image = fopen($imageInfo, 'r');
file_put_contents("fileName.png", $image);
fclose($image);
?>

我有這個在PHP 5.3中工作,對於其他版本,請檢查。

用於在PHP上測試的圖像數據樣本。

$imageDataInfoSample = ""

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM