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

时间:2013-03-29 18:47:15

标签: php jquery base64

我将画布图像编码为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);
}

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

3 个答案:

答案 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),它就可以正常工作! :)