HTML5移动端实现选择裁剪图片并且ajax上传服务器

直接看demo 下载地址如下

demo下载地址

然后直接把css和js引用下  把html直接复制过来 改下css就可以了
如果要改比例

       aspectRatio: 750 / 1206,//裁剪框比例 750:1206改这个就好了 在myCrop.js文件里


他最后截取生成的图片是base64的  把他ajax上传PHP

后台处理程序PHP:
function error($msg=''){
    $return = array('msg'=>$msg);
    echo json_encode($return);
    exit();
}

function main(){
    if(!$_POST['img']){
        error('请上传图片!');
    }
    
    $img = $_POST['img'];
    
    $path = './upload/';
    
    $type_limit = array('jpg','jpeg','png');

    if(preg_match('/data:\s*image\/(\w+);base64,/iu',$img,$tmp)){
        if(!in_array($tmp[1],$type_limit)){
            error('图片格式不正确,只支持jpg,jpeg,png!');
        }
    }else{
        error('抱歉!上传失败,请重新再试!');
    }
    
    $img = str_replace(' ','+',$img);
    
    $img = str_replace($tmp[0], '', $img);

    $img = base64_decode($img);
   
    $file = $path.time().'.'.$tmp[1];
    if(!file_put_contents($file,$img)){
        error('上传图片失败!');
    }else{
        error('恭喜您!上传成功!');
    }
}
main();
步上传压缩图片并立即显示图片 javascript异步上传压缩图片并立即显示图片 <script type="text/javascript" src="./js/lrz.mobile.min.js"></script> <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
选择图片
<script type="text/javascript"> var img; $("input:file").change(function (){ //console.log(this.files[0]); //找个地方加个height就代表强制拉伸 不设置 就是按照640 等比例缩放 lrz(this.files[0],{width:640,quality:0.9},function(rst){ img = rst.base64; var html = []; var show_img = new Image(); show_img.src = rst.base64; $("#img_show").html("
"); $(".upimg").html(show_img); }); }); $("#form").submit(function (){ var phone = $("input[name='phone']").val(); var month = $("input[name='month']").val(); $.post("upload.php",{img:img,phone:phone,month:month},function(data){ img = null; alert(data.msg); },'json'); return false; }); </script> 1.首先你要载入JS类库: <script type="text/javascript" src="./js/lrz.mobile.min.js"></script> 2.然后就是写好form 3.准备处理图片以及图片异步提交的JS。 <script type="text/javascript"> var img; $("input:file").change(function (){ //console.log(this.files[0]); lrz(this.files[0],{width:640,quality:0.9},function(rst){ img = rst.base64; var html = []; var show_img = new Image(); show_img.src = rst.base64; $("#img_show").html("
"); $(".upimg").html(show_img); }); }); $("#form").submit(function (){ var phone = $("input[name='phone']").val(); var month = $("input[name='month']").val(); $.post("upload.php",{img:img},function(data){ img = null; alert(data.msg); },'json'); return false; }); </script> 从代码中可以看出,这个JS库是把图片转成码,然后用变量存起来,然后在用异步POST到服务器中在处理。 看起来貌似没有什么特别的地方,的确实在也没有什么特别的地方……. 后台处理程序PHP: function error($msg=''){ $return = array('msg'=>$msg); echo json_encode($return); exit(); } function main(){ if(!$_POST['img']){ error('请上传图片!'); } $img = $_POST['img']; $path = './upload/'; $type_limit = array('jpg','jpeg','png'); if(preg_match('/data:\s*image\/(\w+);base64,/iu',$img,$tmp)){ if(!in_array($tmp[1],$type_limit)){ error('图片格式不正确,只支持jpg,jpeg,png!'); } }else{ error('抱歉!上传失败,请重新再试!'); } $img = str_replace(' ','+',$img); $img = str_replace($tmp[0], '', $img); $img = base64_decode($img); $file = $path.time().'.'.$tmp[1]; if(!file_put_contents($file,$img)){ error('上传图片失败!'); }else{ error('恭喜您!上传成功!'); } } main(); 上述代码如果有错误欢迎指出。 如上诉代码,正如你看到的那样,经过BASE64加密过的图片码经过JS异步的POST过来后端后,我们要把代码还原。但是JS库加密的时候会带有一些标签,所以还原前需要处理掉这些本来不属于图片的东西。
   $img = str_replace(' ','+',$img);
    
    $img = str_replace($tmp[0], '', $img);

    $img = base64_decode($img);
最后把代码塞进文件,设置好相应的文件名和扩展名,图片就成功上传到了服务器了。 注意: 前后端包括JS编码要要一致,建议UTF-8 如果图片还原不会来的话,那肯定是数据问题,打印POST过来的图片码出来看看。

查看原文:http://newmiracle.cn/?p=1376
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值