如何使用PHP保存Google Chart PNG?

时间:2014-03-09 09:15:03

标签: javascript php base64 google-visualization

我有一个使用Google Charts API生成的图表,我想将其另存为图像文件。我使用PHP将其保存到文件中,但它无效。

我需要做什么。

的javascript

 var chart = new google.visualization.PieChart(document.getElementById('chart_div_source'));
 chart.draw(data, {width: 450, height: 300, title: 'Course Payment Breakdown'});

 jQuery.post("action_save64png.php", {pngImageData :chart.getImageURI(), CourseID: 23, charttype: 'incomesplit' });

这将生成图表并向action_save64png.php发出ajax请求以保存文件

PHP文件

$EncodedPNG = $_POST['pngImageData'];
$FileName = 'chart_'. $_POST['CourseID'] . '.png';

$decoded=base64_decode($EncodedPNG);

file_put_contents('../charts/' . $FileName,$decoded);

这会保存文件,但是当我尝试打开它时它是无效的png。

我需要做些什么?

1 个答案:

答案 0 :(得分:3)

事实证明,在PNG 64位字符串的开头有一个字符串

data:image/png;base64,

必须先删除。

$EncodedPNG = $_POST['pngImageData'];
//Replace spaces with +
$EncodedPNG = str_replace(' ','+',$EncodedPNG);
//Remove identifier string from begining of data.
$EncodedPNG =  str_replace('data:image/png;base64,', '', $EncodedPNG);

$FileName = 'chart_'.  $_POST['CourseID'] .  '.png';


$decoded=base64_decode($EncodedPNG);
file_put_contents('../charts/' . $FileName,$decoded);

现在png文件有效。