我将画布图像编码为base64,这给了我:

这似乎是一个有效的base64图像(用在线解码器解码)。
我使用jquery ajax将其与其他(form-)变量一起发送,如下所示:
$.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);
}
但是,文件未保存。可能有什么不对?
答案 0 :(得分:8)
让我们尝试在单个函数和调用的相同文件夹中创建文件test.php,检查浏览器中的输出错误或/var/log/httpd/error_log
<?php
function saveImage($base64img){
define('UPLOAD_DIR', '../uploads/');
$base64img = str_replace('data:image/jpeg;base64,', '', $base64img);
$data = base64_decode($base64img);
$file = UPLOAD_DIR . '123123123.jpg';
file_put_contents($file, $data);
}
saveImage('');
这意味着部分AJAX中的麻烦=&gt; 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);
}
答案 1 :(得分:1)
它有效 - 似乎使用
将文件包含在php中include('file.php');
相对路径来自父级而不是来自包含的文件:(
这就是整个问题......感谢所有人
答案 2 :(得分:1)
您编写encodeURIComponent
(JS),然后编写utf8_decode
(PHP)。只需使用urldecode
(PHP),它就可以正常工作! :)