怎么把图片路径64位编码的转化成正常的路径,不编码的

妮妮
  • 47

再给后台上传图片路径,可是获取的图片路径一直是64位编码的,后台只要正常的图片路径图片描述

图片描述

这是控制台输出的图片路径,怎么把它转化成正常的呢
这个是我的代码:图片描述

有哪位大神知道的可否告知一下,谢谢

回复
阅读 6.3k
7 个回答
水不凉
  • 4.8k

这不是64位编码的路径,这叫base64编码的Data URI

这里有两个概念,一个是 Data URI,这种 uri 本身就包含资源的数据而不是表示某个资源的地址或路径,所以说,你拿到一个 Data URI 就表示你已经拿到这个资源的数据了。

Data URI的格式是:data:mimeType;encodeType,content 其中编码方式可以省略。

第二个概念是 base64 编码,如果 Data URI 包含的是二进制内容,为了方便展示,Data URI 支持使用 base64 对资源内容进行编码。

所以,你得到图片的 base64 编码的 Data URI,为什么需要转化为图片的真实的路径呢? Data URI 没法转化为资源路径,也不需要转化为资源的真实路径。

后端需要做的是将base64的图片数据保存为图片,并返回图片位置就好.

可以参考一下PHP:

<?php
header('Content-type:text/html;charset=utf-8');
$base64_image_content = $_POST['imgBase64'];
//匹配出图片的格式
if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_image_content, $result)){
$type = $result[2];
$new_file = "upload/active/img/".date('Ymd',time())."/";
if(!file_exists($new_file))
{
//检查是否有该文件夹,如果没有就创建,并给予最高权限
mkdir($new_file, 0700);
}
$new_file = $new_file.time().".{$type}";
if (file_put_contents($new_file, base64_decode(str_replace($result[1], '', $base64_image_content)))){
echo '新文件保存成功:', $new_file;
}else{
echo '新文件保存失败';
}
}
?>

base64编码Data URI和资源路径不是一个东西吧

这个编码就是一张图,上面有个回答解释的很清楚了,他很占大小,一般用在请求的次数很多的地方,减少请求的往返次数从而优化网站性能。
你可以尝试找东西把它转成图片,糙一点截图啥的,再引用路径

风兮清扬
  • 5.2k

在你的图里的红框那, 需要把那个base64编辑的图片先上传到服务器, 让服务器保存, 给你返回保存的url, 然后你把这个url再上传到服务器就好了.

或者直接上传base64图片, 服务器在保存的时候, 先把base64保存成图片文件, 然后替换掉headImage的值.

把这个base64的图片先上传到你们的服务器上,服务器返会远端地址,在把这个地址传给后端

司马缸砸光
  • 54

再给后台上传图片路径,可是获取的图片路径一直是64位编码的,后台只要正常的图片路径

首先,这不是 base64编码的路径,这就是base64编码之后的图片实体,准确的说是 base64编码的DATA URI你通过H5的 File API拿到这一大坨DATA URI是没问题的;

然后,"后台只要正常的图片路径" 这是扯犊子,前端上传个本地的 URL 路径(比如c://assets/pic1.jpg)给后台是没有意义的,后台需要的是你上面的那一大坨base64 URI,他需要自己decode


const fs = require('fs');
const path = require('path');

const baseStr = "";

function fileSaver(base64Str, filename = 'your_file_name', outputPath) {
    return new Promise((resolve, reject) => {
        const data = base64Str.split(',')[1];
        const buff = new Buffer(data, 'base64');
        const type = base64Str.match(/(?:image\/)(\w+)(?=;)/)[1];
        const savePath = path.resolve(outputPath, `${filename}.${type}`);

        fs.writeFile(savePath, buff, (err) => {
            if (err) {
                return reject(err);
            }
            return resolve(savePath);
        })
    })
}

fileSaver(baseStr, '2', './').then(
    (filepath) => console.log('File saved successfully,当前远程地址是:%s', filepath ),
    (err) => console.log('File saved failed, resean : ' + err)
);
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
宣传栏