2012-07-20 133 views
16

我正在尝试使用base64编码的字符串并将它作为图像在PHP中使用$_POST返回。如果我使用$_POST['imgdata'],那么在线上它会从preg_match返回错误,如果我使用base64字符串进行硬编码而不是使用$_POST,则它将工作并返回图像。我怎样才能使这项工作通过$_POST从base64中获取图像字符串

作品

$imgstr = ''; 

不起作用

$imgstr = $_POST['imgdata']; 

全码

$imgstr = $_POST['imgdata']; 
// Grab the MIME type and the data with a regex for convenience 
if (!preg_match('/data:([^;]*);base64,(.*)/', $imgstr, $matches)) { 
    die("error"); 
} 

// Decode the data 
$content = base64_decode($matches[2]); 

// Output the correct HTTP headers (may add more if you require them) 
header('Content-Type: '.$matches[1]); 
header('Content-Length: '.strlen($content)); 

// Output the actual image data 
echo $content; 
+0

POST的值看起来像......? – 2012-07-20 00:26:59

+0

@Ignacio Vazquez-Abrams我添加了完整的字符串 – 2012-07-20 00:32:55

+0

你有没有试图回显$ _POST ['imgdata']并比较? – haynar 2012-07-20 00:37:48

回答

1

不知道为什么正则表达式是不工作为你,我复制了base64的发布数据和你的代码,它工作得很好。你可以尝试这个,而不使用正则表达式,可能会更快一点,并使用更少的内存。

$imgstr = $_GET['imgdata']; 

list($type, $imgstr) = explode(';', $imgstr); 
list(, $type)  = explode(':', $type); 
list(, $imgstr)  = explode(',', $imgstr); 
$content = base64_decode($imgstr); 
+0

它不工作。如果我试图把这个在我的浏览器中''http://mywebsite.com/dataurl_decode.php?imgdata = data:image/png; base64,iVBORw0KGgoAAAANSUhEUgAAAMgAAAAoCAYAAAC7HLUcAAADr0lEQVR4Xu2brZIqMRCFsy8A'只是返回一个空白页面 – 2012-07-20 00:41:25

+0

空白页面可能表明一个解析错误,你将'display_errors'设置为off。顺便说一句,那是'$ _GET'数据,而不是'$ _POST',所以这可能是正则表达式不适合你的原因。 – drew010 2012-07-20 00:44:48

+0

我打开了错误,并得到“注意:未定义的索引:imgdata” – 2012-07-20 00:49:33

16

如前所述,不应该错过“+”,其余的都是直截了当的。如果您不确定是否发布或获取,请使用$ _REQUEST。

// requires php5 
define('UPLOAD_DIR', 'images/'); 
$img = $_REQUEST['img']; 
$img = str_replace('data:image/png;base64,', '', $img); 
$img = str_replace(' ', '+', $img); 
$data = base64_decode($img); 
$file = UPLOAD_DIR . uniqid() . '.png'; 
$success = file_put_contents($file, $data); 
print $success ? $file : 'Unable to save the file.'; 
+0

难道你不需要替换那个+符号吗?在iOS中,这将是encodedString = [encodedString stringByReplacingOccurrencesOfString:@“+”withString:@“%2B”]; – coolcool1994 2013-08-11 03:49:33

+1

伟大的人!我几乎杀了自己,但替换空间解决了我的问题 – Leaf 2014-12-26 17:56:22

3
<?php 
$data = 'iVBORw0KGgoAAAANSUhEUgAAABwAAAASCAMAAAB/2U7WAAAABl' 
     . 'BMVEUAAAD///+l2Z/dAAAASUlEQVR4XqWQUQoAIAxC2/0vXZDr' 
     . 'EX4IJTRkb7lobNUStXsB0jIXIAMSsQnWlsV+wULF4Avk9fLq2r' 
     . '8a5HSE35Q3eO2XP1A1wQkZSgETvDtKdQAAAABJRU5ErkJggg=='; 
$data = base64_decode($data); 

$im = imagecreatefromstring($data); 
if ($im !== false) { 
    header('Content-Type: image/png'); 
    imagepng($im); 
    imagedestroy($im); 
} 
else { 
    echo 'An error occurred.'; 
} 
?> 

源:文档。

检出imagecreatefromstring

7

这是一个,我想你会喜欢以下,

<?php 
$imgstr = 'image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMgAAAAoCAYAAAC7HLUcAAADtUlEQVR4Xu2aLZYqMRCFMxuAFaARg8WwAnaABQEWgwUBFoMFARaDRqAxWBBoVgAbmPcu7/Q7PX3SP0k16TTcnDNqOpXKrXykKsmXUurn7x+bvQJf9l3Z03cFEFwCIosSAZHp53VvAiIPDwGRa+itBQIiDw0BkWvorQUCIg8NAZFr6K0FAiIPDQGRa+itBQIiDw0BkWvorQUCIg8NAZFr6K0FAiIPDQGRa+itBTEg7XZb1Wo11Wg0VKVS+T/Rx+Ohzuezut1uar/feyVAp9NR8Dvaer2ejZ8ExEa1kvSxBgQLbDQaPeFIa4BkPp97AQr8XiwWWpfr9XraVHT/JyA2qpWkjxUg+AWeTqfGU5xMJmq73Rr3y6vD9/e32mw2v3a6sG0CkpfS72PHGBAsst1uZ60A0pjj8Wjd37Yj0j/AAf/jGgGxVfd9+xkDgp0DO0i0oeZYLpfqcrk8F+FgMND+UqMeGQ6HzhVdr9eq1WoljktAnIfF+wGNATmdTtqFH02fsBixKHUgNZtNp8LEQR11goA4DUspBjMCJC69wu6hW/TX6zXPYthKUF29BH/DJ26BYQJiJfFbdzICJFAinKoAGiy4aPGN063D4VDoDqIDGr7iRE13yEBA3nqtW03OCpAsI+EoVXfX4KoGAaA4TIjezXS7XVWtVrXpHwHJEtnP+uYlgCTl/C5OseJOrII6Ka4+IiCftfizzDZXQLAwcXmoO+WCM652D93uhbRqtVo9NSEgWZYGv4ECuQGClAYLM+6eAce/SG9QA7yy9fv9J6ThhvoIu0e4htKdsHEHeWVkymk7F0BQa8xms9gbalwM4u7j1XDoTqx0YHIHKediLcJrMSC6X+zwRJDWIL1x0XR3NBj/fr//Gh67nS4NDPzUncol+M+3WC6CW9AYIkCSinEssvF47PSBYty9i6m22PEMXvYSEFOBS/S9NSBJcLhKqaI6E5ASrbySuGoFSFJaFS2IXepAQFyq/RljGQOS9po3y0td5PoonvNuBCRvRWnPGJAsr2LTZH3VZWHaa93AL0AePQrG/4K6A0W9AcCsQdICXuL/GwES977KdP6vAiSrHzzmzaoUvzMCJO1IN6ucBCSrUvyuaAWMAIl7gGg6CQJiqhi/L0oBI0CKctLzcVmDeB4giXsERKLev74ERK6htxYIiDw0BESuobcWCIg8NARErqG3FgiIPDQERK6htxYIiDw0BESuobcWCIg8NARErqG3FgiIPDQERK6htxYIiDw0BESuobcW/gDZOWY4lzJl1QAAAABJRU5ErkJggg=='; 
$new_data=explode(";",$imgstr); 
$type=$new_data[0]; 
$data=explode(",",$new_data[1]); 
header("Content-type:".$type); 
echo base64_decode($data[1]); 
?> 

上面的代码将产生输出按你的愿望,尝试this..This可以帮助你。

对不起,延迟回复,现在只有我恢复我的StackOverFlow帐户很长一段时间后。

注意:忽略PHP文件上用于图像解码的开始''标记之前的空白空间。如果该文件上有空文件意味着它会抛出错误消息并且不会创建或显示解码后的原始图像。

+0

我试图使用$ _POST变量将字符串发送到一个PHP页面 – 2012-08-14 18:34:52

+0

只需添加隐藏的字段,并将值放在POST变量中,就像”>并在表单提交后获取值__POST ['imgstr' ]也将其分配给$ imgstr = $ _ POST ['imgstr']; – 2012-08-15 09:26:14

1

请检查下面的代码,它正在为我好,

$data = ''; 
$data = str_replace('data:image/png;base64,', '', $data); 
$data = str_replace(' ', '+', $data); 
$data = base64_decode($data); // Decode image using base64_decode 
$file = uniqid() . '.png'; //Now you can put this image data to your desired file using file_put_contents function like below: 
$success = file_put_contents($file, $data); 
1

您可以通过这个表达式捕捉部分:

^数据:([A-ZA-Z] +/[A- ZA-Z] +); BASE64 \,([A-ZA-Z0-9 + \ = /] +)$

0
$imgstr = ''; 
preg_match("/data\:image\/(.*)\;base64/",$imgstr, $match); 
echo $match[1]; 

^^^^返回文件扩展名。

$data = str_replace('data:image/png;base64,', '', $imgstr); 
data = str_replace(' ', '+', $data); 
$data = base64_decode($data); 
file_put_contents("/files/youfilemane.".$match[1],$data); 

^^^^从base64创建文件。