使用PHP中的AJAX请求保存base64编码的图像

我将canvas图像编码为base64,它给了我:

 

这似乎是一个有效的base64图像(用在线解码器解码)。

我用其他(form-)变量用jquery ajax发送它,如下所示:

 $.ajax({ type: "POST", url: "index.php?action=saveNewPost", data: {text: text, img: encodeURIComponent(base64img)}, contentType: "application/x-www-form-urlencoded;charset=UTF-8", success: function(){ //... } }); 

在服务器上,这是这一行:

 saveImage(utf8_decode($_POST['img'])); 

哪个叫:

 function saveImage($base64img){ define('UPLOAD_DIR', '../uploads/'); $base64img = str_replace('data:image/jpeg;base64,', '', $base64img); $data = base64_decode($base64img); $file = UPLOAD_DIR . uniqid() . '.jpg'; file_put_contents($file, $data); } 

但是,文件未保存。 可能有什么不对?

让我们尝试在单个函数和调用的相同文件夹中创建文件test.php,检查浏览器中的输出错误或/var/log/httpd/error_log

  

这意味着部分AJAX => php脚本的麻烦。 现在,我们尝试比较我们从ajax和原始字符串中收到的内容,只需将函数更改为this并查看test.txt:

 function saveImage($base64img){ define('UPLOAD_DIR', '../uploads/'); $file = UPLOAD_DIR . 'test.txt'; file_put_contents($file, 'ORIG:'.''."\n".'AJAX:'.$base64img); } 

它工作 – 似乎当一个文件包含在PHP使用

 include('file.php'); 

相对路径来自父级而不是来自包含的文件:(

这就是整个问题……感谢大家

你编写encodeURIComponent (JS)然后utf8_decode (PHP)。 只需使用urldecode (PHP),它就可以正常工作! 🙂