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

标签 php jquery base64

我将 Canvas 图像编码为 base64,这给了我这个:



这看起来像是一个有效的 base64 图像(使用在线解码器对其进行解码)。

我使用 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 中的输出错误

<?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 => php 脚本部分出现问题。现在,我们尝试比较从 ajax 收到的内容和原始字符串,只需将您的函数更改为此并查看 test.txt:

function saveImage($base64img){
    define('UPLOAD_DIR', '../uploads/');

    $file = UPLOAD_DIR . 'test.txt';
    file_put_contents($file, 'ORIG:'.''."\n".'AJAX:'.$base64img);
}

关于php - 在 PHP 中使用 AJAX 请求保存 base64 编码的图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15709515/

相关文章:

php - 在 PHP 中使用 enom API 检查域可用性

javascript - 在 Javascript 中解析来自 PHP 的编码数据

javascript - 如何使用 jQuery Mobile 或 Javascript 在 Web 应用程序上进行下拉页面刷新

javascript - 问答游戏: The answers from an array are not properly coming up as correct or incorrect.

javascript - Jquery fileupload - 包括表单内的插件

c - 如何处理解码 Base64 字符串时出现的错误

android - 在 Android 应用程序中使用 Base64 编码字符作为文件名

php - dailymotion API PHP 问题

PHP 亚马逊 SQS 大数据

javascript - 从 mongoDB 读取 PDF 并以 HTML 显示