无法找到base64图像代码无效的原因

时间:2018-03-07 21:51:30

标签: javascript image encoding base64

有谁可以告诉我为什么here中链接的base64图片代码无效?我相信语法存在某种问题?

我的文件如下:

/9j/4AAQSkZJR..........39b/lRk5HGVz8

我已经截断了它(“...”),因为整个文件都不适合这个问题。

这是我的Javascript Fetch API POST代码:

function submitPhoto(){ 


    console.log("name: "+name);
    console.log("email: "+email);
    console.log("market: "+market);
    //console.log("base64: "+b64data);


    fetch('http://fanbeauties.com/app/submit-photo.php?pass=MY_PASS', { 
    method: "POST", 
    headers: {
      "Content-type": "application/x-www-form-urlencoded; charset=UTF-8"
    },
    body: '&name='+name+'&email='+email+'&market='+market+'&picture='+b64data
     });


};

2 个答案:

答案 0 :(得分:1)

是的我认为语法不正确,可能不是有效的图像或某些部分被删除。

点击此链接https://jsfiddle.net/casiano/xadvz/



<img src="">
&#13;
&#13;
&#13;

格式应该从以下开始:data:image/gif;base64,或仅此image/gif;base64,,因此第一部分显示图像类型。在你的情况下它应该是image/jpeg;base64,就像定义它的base64内联图像。

在代码的末尾或任何base64编码内容的结尾处应该有==或=但你不应该删除它的部分编码内容。

答案 1 :(得分:0)

所以这是另一个答案。我单独发布,导致您的问题发生变化。

实现这一目标有两种方法。首先是使用URL编码和URL解码。因此,在发送包含图像数据的base64字符串之前,请对其进行编码,然后在服务器端对第一个回显进行编码,以查看它的外观。然后使用PHP urldecode来恢复你的字符串。

使用javascript进行网址解码/编码:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/encodeURIComponent

PHP中的URL解码/编码:

http://php.net/manual/en/function.urlencode.php

https://stackoverflow.com/a/4744917/9453736

但是在这种情况下应该更好地适应的另一种方式是当你想发布某些内容时使用帖子。但是,由于您已经在使用库来执行此操作,我猜它只是库的限制。因此,请尝试检查是否有其他方法为该库设置POST参数。就像你将参数添加到正文,但你这样做(图书馆)只是限制你。例如,当你这样做时,你不能使用一些字符:

{
     body: '&name='+name+'&email='+email+'&market='+market+'&picture='+b64data
{

因此,如果您未能找到其他方式来执行请求。就像你可以使用纯javascript和其他方式的表单对象。所以,如果你失败了,那就去第一个尝试url编码数据。

javascript中的url编码示例:

// encodes characters such as ?,=,/,&,:
console.log(encodeURIComponent('?x=шеллы'));
// expected output: "%3Fx%3D%D1%88%D0%B5%D0%BB%D0%BB%D1%8B"

console.log(encodeURIComponent('?x=test'));
// expected output: "%3Fx%3Dtest"

PHP中的urldecode示例:

$query = "my=apples&are=green+and+red";

foreach (explode('&', $query) as $chunk) {
    $param = explode("=", $chunk);

    if ($param) {
        printf("La valeur du paramètre \"%s\" est \"%s\"<br/>\n", urldecode($param[0]), urldecode($param[1]));
    }
}