JS异步上传压缩过的图片!

感谢 think2011 这位兄台的JS库:https://github.com/think2011/LocalResizeIMG

先看调用页面:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0,user-scalable=no">
       <script type="text/javascript" src="./js/lrz.mobile.min.js"></script>
       <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
</head>
<body class="upload">
<form id="form">
        <div id="img_show"></div>
        <div id="upload">
           <div id="img_file"><input type="file" accept="image/*" ><div class="btn">选择图片</div></div>
        </div>
        <input type="submit" class="tijiao" value="提交">
    </form>
</body>

<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("<div class=‘upimg‘></div>");
            $(".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>
</html>

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("<div class=‘upimg‘></div>");
            $(".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);

最后把代码塞进文件,设置好相应的文件名和扩展名,图片就成功上传到了服务器了。

注意:

  1. 前后端包括JS编码要要一致,建议UTF-8
  2. 如果图片还原不会来的话,那肯定是数据问题,打印POST过来的图片码出来看看。
时间: 2024-10-17 12:43:13

JS异步上传压缩过的图片!的相关文章

利用ajaxfileupload.js异步上传文件

1.引入ajaxfileupload.js 2.html代码 <input type="file" id="enclosure" name="enclosure"> <button id="upClick" >上传</button> 注意这里的input控件的id和name必须一致:这样在后台利用springMVC接受文件的时候能对应起来: 3.JS代码 <script type=&q

PHP JS JQ 异步上传并立即显示图片

http://my.oschina.net/zerodeng/blog/313773 提交页面: <! DOCTYPE html> < html> < head> < meta charset ="GB2312" > < title> Insert title here </title > < script type ="text/javascript" src= "jquery

JS异步上传Excel 并使用NPOI进行读写操作

实现功能 导入--客户端使用 ajaxfileupload.js 插件实现Excel的异步上传,并在服务端解析成JSON字符串返回页面 导出--将页面中的grid表拼接成JSON串上传至服务器,在服务端新建Excel并将数据导入,随后返回url给用户下载 客户端(Test.aspx) 页面上需要实现的效果是显示一个"导入"按钮,hover时会显示标准格式图片,点击触发上传事件,选择Excel文件后上传到服务器,HTML代码如下 PS:使用了Bootstrap样式,也可以自己定义.&qu

PHP JQ 异步上传并立即显示图片

提交页面: <! DOCTYPE html> < html> < head> < meta charset ="GB2312" > < title> Insert title here </title > < script type ="text/javascript" src= "jquery.js"></ script > < script 

上传压缩后的图片并且保持100k不失真的方法

压缩100k图片不失真的方法:先获取图片的原始长度和宽度:然后计算图片的缩放值:最后等比例压缩: 下面代码是压缩的工具类: public class PictureUtil { /** * 主方法 * * @param filePath * @return */ public static InputStream bitmapToString(String filePath) { Bitmap bm = getSmallBitmap(filePath); ByteArrayOutputStrea

使用ajaxfileupload.js异步上传文件到Servlet

前段时间帮同学做的毕业设计..好吧又是帮人做...需要上传文件,在这里使用了ajaxfileupload.js进行异步的上传文件到Servlet  ,后台保存了文件以后通过JSON返回文件路径到前端,好了废话不多说,直接上代码了... 前端页面比较简单 <input maxlength=16 type=file name="pic" id="pic" size=16 />  <input type="button" id=&qu

关于js异步上传文件

好久没登录博客园了,今天来一发分享. 最近项目里有个需求,上传文件(好吧,这种需求很常见,这也不是第一次遇到了).当时第一想法就是直接用form表单提交(原谅我以前就是这么干的),不过表单里不仅有文件还有别的信息需要交互,跟后端商量后决定文件单独上传,获取到服务器端返回的文件地址在和表单一起提交.这里就需要异步上传文件. 在网上扒了扒相关的内容,发现还真不少,阮一峰老师的这篇文章(文件上传的渐进式增强)就介绍的很具体,下面就谈谈自己在实战中遇到的一些问题的感受吧. 先看看效果,实现了哪些功能 (

JS异步上传文件

直接调用Upload(option)方法,即可上传文件,不需要额外的插件辅助,采用原生js编写. /* *异步上传文件 *option参数 **url:上传路径 **data:上传的其他数据{id:"1"} **maxSize:文件最大值(单位M) * img:"#qrimg", **callback:回调函数(可空) **beforeSend:上传前函数(可空) */ function Upload(option) { var fd = new FormData(

ASP.NET MVC 使用jquery.form.js 异步上传 在IE下返回值被变为下载的解决办法

错误记录: <script type="text/javascript"> $(function () { $(document).off("ajaxSend"); //异步上传 $("#Submit").click(function () { if ($("#selectFileButton").val() == "") { return false; } $("#fileForm&