二进制流 ajax 实现图片上传

jax图片上传
 
//获取整个form表单的id;
var upload = document.getElementById('uploadForm');
//jquery发送FormData
var fb = new FormData(upload); 
//如果追加一个
fb.append('demo','this is a demo');
$.ajax({
      url: "?r=weather/img",
      type: "POST",
      data: image,
      dataType: 'json', //以jsonp类型返回
      processData: false, //告诉jquery不要发送数据
      contentType: false, //不要射中content-type
});
//如果采用二进制流的形式上传图片
//需要在相应的控制器中获取
$tmp_name = $_FILES['img']['tmp_name'];
//然后采用
$path = file_get_contents($tmp_name); //获取临时文件的路径,并解析称为字符串的形式
//为了安全起见,对路径进行加密
$image = base64_encode($path);
//在  file_get_contens  和   base64_encode 之间 可能会丢失一些数据 ,
所以在base64_decode之前 要进行匹配 ,要不然会导致数据不正确
 
主要解决为
 $path = str_replace (' ','+',$image);
//如果在另一个方法中使用,应
$image = base64_decode($path); //解密
//另外,需要
file_put_contents('./123.png',$image); //放入到文件中,现在则是图片啦
 
//然后 根据自己的需要可以入库。。。。

转载于:https://www.cnblogs.com/zhanzy/p/6606017.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值