2011-08-02 221 views
4

用一張空白的畫布開始:HTML5畫布toDataURL返回空白圖像

<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中均失敗。

所產生的PNG圖像轉儲到火狐「圖像/ PNG」頭產生這個錯誤控制檯:

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

但是...圖像不損壞或截斷,我可以看出,除非toDataURL ()隨處可見,因爲php的東西只是base64_decode()toDataURL()的結果。

任何想法?

謝謝!

+0

你可能想看看這個例子的來源。 http://motyarblog.000space.com/imagetouri.php使用jquery。你的問題我的謊言實際上'canvas.toDataURL'是圖像的base64字符串,如果它超過了255個字符而不能作爲$ _GET傳遞 –

+0

已經想到了這一點,並確認我正在執行POST操作XHR。在後端,我將base64編碼的圖像轉儲爲文本文件,長度沒問題,它是一個真正的b64字符串,沒有編碼,只是一個空白圖像。 – Erick

+2

你見過[this comment](http://www.php.net/manual/en/function.base64-decode.php#104193)在'base64_decode'的PHP文檔中嗎? – robertc

回答

7

檢查你見過在PHP文檔的base64_decodethis comment

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

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

在JavaScript從canvas.toDataURL()這些瀏覽器比支持此方法與「圖像/ 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 = ""