php无法解码js发过来的base64图片编码,有诡异空格

发布于 2022-09-04 18:35:50 字数 1582 浏览 10 评论 0

我通过vue的axois通过post方法向php转图片编码,在php base64_decode解码的时候总是失败

发现

  1. 在php里,base64编码里的'+'号变成了空格

  2. 尝试用str_replace(' ', '+', $str)失败,无法替换

  3. 尝试用str_replace(' ', '%2B', $str)成功替换,还是无法解码

  4. 对比初始的base64编码和替换后的编码发现中间少了几行(我认为原因就出在这里)

  5. 后面尝试
    (1)在js里先将'+'号替换到'-',再在php里替换回来,同样上面3和4

(2)在js里使用encodeURIComponent,再在php里解码回来,同样上面3和4

啊啊啊,我主要是做前端的,php这方面不是很熟悉,查了很久资料都没找到解决方法,相当难受

代码:
JavaScript:

...
    this.$http.post('../info/publish.php', {
              name: this.name,
              description: this.description,
              cid: this.fenlei,
              price: this.price,
              image: this.base64,
              address: this.location
            }).then((res) => {
    //          console.log(this.base64);
              console.log(res.data);
            });
...

PHP:

...
$data = file_get_contents('php://input');
    $pName=json_decode($data)->name;
    $pDe=json_decode($data)->description;
    $cid=json_decode($data)->cid;
    $price=json_decode($data)->price;
    $image=json_decode($data)->image;
    $image1=str_replace(' ', '+', $image);
    // $image=urldecode($image);
    $address=json_decode($data)->address;
    $image=substr(strstr($image1,','), 1);
    $img=base64_decode($image);
...

clipboard.png

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

爺獨霸怡葒院 2022-09-11 18:35:51

我觉得这是php的锅,base64转码之后的图片,php解码应该是解码 'data:image/png;base64,' 后面的一串代码

$img = substr('img数据', 22);
file_put_contents('path', base64_decode($img));
伴我老 2022-09-11 18:35:51

post数据是没必要encode的

你的呼吸 2022-09-11 18:35:51

你在前端先把 base64 字符串中 + 号替换为 %2B ,然后 php 接收的时候再对 base64 串做 urldecode(base64) 解码试试

撞了怀 2022-09-11 18:35:51

前端url编码后,在php那层没必要url解码,中间件如apache会自动解码的,包括post。
因此解决办法是js直接url编码image数据,后端php正常base64解码即可。

智商已欠费 2022-09-11 18:35:51

在百度,google上找了三个多小时,终于找到和我一样的问题了,我试过了。楼主你的第二个解决方案,直接在php中用str_replace(' ', '+', $str),+号替换掉空格是可行的。我不知道为什么你哪里不行?

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文