1 客户端图片上传,先通过js将要上传的图片转换为base64格式的图片,再提交到后台
<div>
<input type="file" id="myimg"
onchange="imgChange(this)"
accept="image/png,image/gif,image/jpeg"/>
<img width="300px" src="" alt="">
</div>
function imgChange(img) {
// 生成一个文件读取的对象
const reader = new FileReader();
reader.onload = function (ev) {
// base64码
var imgFile =ev.target.result;//或e.target都是一样的
document.querySelector("img").src= ev.target.result;
}
//发起异步读取文件请求,读取结果为data:url的字符串形式,
reader.readAsDataURL(img.files[0]);
}
2 后台php需要对客户端提交的base64格式做一下处理,防止提交的base64图片头部包含 data:image/xxxx;base64, 字符串。
// 只替换jpeg,png,gif格式
$basb64_img = preg_replace('#data\:image\/(jpeg|png|gif){1};base64,#','',$_REQUEST['base64']);
// 或者不管什么格式
$basb64_img = preg_replace('#data\:image\/[a-z]+;base64,#','',$_REQUEST['base64']);