使用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),它就可以正常工作! 🙂