javascript - AJax post BASE64编码到后台
程序员文章站
2022-05-16 17:15:04
...
php convert & output BASE64
$img = str_replace(FILE_DOMAIN , FILE_PATH, 'http://img.demo.com/2016/08/21/12121.jpg');
if(! file_exists($img)) {
$ret = array('err_no'=>-1,'err_msg' => '商品图片不存在');
break;
}
$img_info = getimagesize($img);
$img_base64 = "data:{$img_info['mime']};base64,".chunk_split(base64_encode(file_get_contents($img)));
$result['base64'] = $img_base64;
$ret = array('err_no' => 0, 'err_msg'=> 'succes', 'results'=> $result);
echo json_encode($ret, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE ); exit;
json格式返回 没处理直接 data.results
获取的 无法显示
data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEAYABgAAD//gA8Q1JFQVRPUjogZ2QtanBlZyB2MS4wICh1c2luZyBJSkcgSlBFRyB2ODApLCBxdWFsaXR5ID0gMTAwCv/bAEMABgQFBgUEBgYFBgcHBggKEAoKCQkKFA4PDBAXFBgYFxQWFhodJR8aGyMcFhYgLCAjJicpKikZHy0wLSgwJSgpKP/bAEMBBwcHCggKEwoKEygaFhooKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKP/A....
上面是同步的 说以 放到
html
标签的li
的data-base64
你面下面是异步提交,先生成参数
js
var idArr = [];
var imgArr =[];
$(".list-group").children('li').each(function(index){
var imgBase64 = $(this).data('base64');
var pId = $(this).data('item');
idArr.push(pId); imgArr.push( encodeURIComponent(imgBase64));
});
//生成参数
var _params = $.param({
pid: idArr.join(','),
image: imgArr.join(','),
});
后台接收处理
php
$img_arr = explode(',', $params['image']);
foreach($result as $key => $val) {
$ans_data[] = array(
'image' => addslashes( rawurldecode( $img_arr[$key]) ),
);
}
然后就直接插入数据库 字段类型是longtext
,
这里每一步json输出 的图片都无法显示正确
回复内容:
php convert & output BASE64
$img = str_replace(FILE_DOMAIN , FILE_PATH, 'http://img.demo.com/2016/08/21/12121.jpg');
if(! file_exists($img)) {
$ret = array('err_no'=>-1,'err_msg' => '商品图片不存在');
break;
}
$img_info = getimagesize($img);
$img_base64 = "data:{$img_info['mime']};base64,".chunk_split(base64_encode(file_get_contents($img)));
$result['base64'] = $img_base64;
$ret = array('err_no' => 0, 'err_msg'=> 'succes', 'results'=> $result);
echo json_encode($ret, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE ); exit;
json格式返回 没处理直接 data.results
获取的 无法显示
data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEAYABgAAD//gA8Q1JFQVRPUjogZ2QtanBlZyB2MS4wICh1c2luZyBJSkcgSlBFRyB2ODApLCBxdWFsaXR5ID0gMTAwCv/bAEMABgQFBgUEBgYFBgcHBggKEAoKCQkKFA4PDBAXFBgYFxQWFhodJR8aGyMcFhYgLCAjJicpKikZHy0wLSgwJSgpKP/bAEMBBwcHCggKEwoKEygaFhooKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKP/A....
上面是同步的 说以 放到
html
标签的li
的data-base64
你面下面是异步提交,先生成参数
js
var idArr = [];
var imgArr =[];
$(".list-group").children('li').each(function(index){
var imgBase64 = $(this).data('base64');
var pId = $(this).data('item');
idArr.push(pId); imgArr.push( encodeURIComponent(imgBase64));
});
//生成参数
var _params = $.param({
pid: idArr.join(','),
image: imgArr.join(','),
});
后台接收处理
php
$img_arr = explode(',', $params['image']);
foreach($result as $key => $val) {
$ans_data[] = array(
'image' => addslashes( rawurldecode( $img_arr[$key]) ),
);
}
然后就直接插入数据库 字段类型是longtext
,
这里每一步json输出 的图片都无法显示正确
推荐阅读
-
javascript - 用js自写ajax提交表单数据到php,但是php的$_POST为空?
-
javascript - AJax post BASE64编码到后台
-
javascript - laravel , ajax 使用post方式传输,后台获取登陆用户id时报错500,使用get方式正常.
-
javascript - AJax post BASE64编码到后台
-
javascript - 如何用ajax post一个url到php服务器?
-
javascript - laravel , ajax 使用post方式传输,后台获取登陆用户id时报错500,使用get方式正常.
-
借助FileReader实现将文件编码为Base64后通过AJAX上传_javascript技巧
-
javascript - JS 用AJAX用POST 传到PHP后台的JSON字符串为什么会成为一个对象?
-
借助FileReader实现将文件编码为Base64后通过AJAX上传_javascript技巧
-
javascript - JS 用AJAX用POST 传到PHP后台的JSON字符串为什么会成为一个对象?