52

我有一个从 javascript 获取并尝试通过 php 保存的数据 URI。我使用以下代码给出了一个明显损坏的图像文件:

  $data = $_POST['logoImage'];

  $uri = substr($data,strpos($data,",")+1);

  file_put_contents($_POST['logoFilename'], base64_decode($uri));



data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAKCAYAAACNMs 9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAAxklEQVQYlYWQMW7CUBBE33yITYUUmwbOkBtEcgUlTa7COXIVV5RUkXKC5AxU EdyZVD4kyKxkwIrr9vd0c7Oih aopinLNsF6Qkg2XW4XJ7LGFsAAcTV6lF5/jLdbALA9XDAXYfthFQVx OrmqKYK88/7rbbMFksALieTnzu9wDYTj6f70PKsp2kwAiSvjXNcvkWpAfNZkzWa/5a9yT7fdoX7rrB7hYh2fXo9HdjPYQZu3MIU8bYIlW20y0RUlXG2Kpv/vfwLxhTaSQwWqwhAAAAAElFTkSuQmCC

代码下方是作为 Data-URI 的实际图像。'logoImage' 是上面的字符串,$uri 是字符串减去'image/jpeg;base64,'。

4

4 回答 4

77

快速浏览一下PHP 手册会得出以下结论:

如果要保存从 Javascript canvas.toDataURL()函数派生的数据,则必须将空白转换为加号。如果你不这样做,解码的数据就会损坏:

$encodedData = str_replace(' ','+',$encodedData);
$decodedData = base64_decode($encodedData);
于 2011-07-18T15:39:22.470 回答
52

您在示例中拥有的数据 URI 不是有效的 PNG 图像。这永远不会起作用,并且与代码无关,它与数据有关。


不适用但可能感兴趣:

file_put_contents($_POST['logoFilename'], file_get_contents($data));

背后的理念:PHP 本身可以读取数据 URI ( data://)的内容,因此您无需自行解码。

请注意,官方数据 URI 方案(参考:“数据”URL 方案 RFC 2397// )在冒号(“”)后不包含双斜杠(“ :”)。PHP 支持带或不带两个斜杠。

 # RFC 2397 conform
 $binary = file_get_contents($uri);

 # with two slashes
 $uriPhp = 'data://' . substr($uri, 5);
 $binary = file_get_contents($uriPhp);
于 2011-07-18T15:38:12.140 回答
33

有效的所有代码:

$imgData = str_replace(' ','+',$_POST['image']);
$imgData =  substr($imgData,strpos($imgData,",")+1);
$imgData = base64_decode($imgData);
// Path where the image is going to be saved
$filePath = $_SERVER['DOCUMENT_ROOT']. '/ima/temp2.png';
// Write $imgData into the image file
$file = fopen($filePath, 'w');
fwrite($file, $imgData);
fclose($file);
于 2015-05-21T07:22:25.177 回答
0

我有另一种方法可以用 PHP 做到这一点。

$img = str_replace(' ','+',$img);
$i = explode(',', $img);
$imgData = array_pop($i);
$newName = 'digital_file/'. rand(10, 16) . '.' . str_replace('/', '.', mime_content_type($img) );
// data:image/png;base64
$imgData = base64_decode($imgData);

现在您可以使用file_put_contents($newName)创建图像文件了。生成具有随机数字名称的文件(例如“123123.image.png”)。当然,它有正确的 mime 类型。

于 2021-08-29T19:42:40.850 回答