文档章节

JS异步上传压缩图片,并立即显示图片。

zerodeng
 zerodeng
发布于 2015/11/05 11:13
字数 730
阅读 13812
收藏 17

感谢 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过来的图片码出来看看。

© 著作权归作者所有

zerodeng

zerodeng

粉丝 7
博文 13
码字总数 4923
作品 0
湛江
程序员
私信 提问
原生JS上传图片(FormData,可预览,一次多图)

前言: 适合人群:刚起步的前端新人。(前后端未分离的项目)全栈后端老大哥的前端需求(点名批评下jsp)。 解决问题: 知识点: 1.普通js上传一张图片 HTML代码: 需要一个input:file图片上传控件 ...

TJ在掘金
06/13
0
0
原创jquery图片上传预览插件uploadView

勾国印原创jquery图片上传前预览插件uploadView,支持自定义允许上传图片的最大尺寸、允许上传图片的格式、预览图片的宽度和高度以及上传成功后回调函数,兼容手机端和PC端。 大家在开发网站...

够过瘾
2015/10/24
5.5K
0
Javascript 异步加载详解

一、同步加载与异步加载的形式 1. 同步加载 我们平时最常使用的就是这种同步加载形式: <script src="http://yourdomain.com/script.js"></script> 同步模式,又称阻塞模式,会阻止浏览器的后...

Carl_
2014/09/15
48
0
Javascript 异步加载详解

一、同步加载与异步加载的形式 1. 同步加载 我们平时最常使用的就是这种同步加载形式: <script src="http://yourdomain.com/script.js"></script> 同步模式,又称阻塞模式,会阻止浏览器的后...

张悟空
2014/08/18
91
0
重构之路:webpack打包体积优化

开始 这一章讲打包体积优化,这个也算是最重要的一章了,我之前可是花了很多时间去查资料怎么优化打包体积的,不同版本的webpack之间还有一些区别,所以也算踩了很多的坑,所以这一章会比较长...

大灰狼的小绵羊哥哥
02/23
0
0

没有更多内容

加载失败,请刷新页面

加载更多

OSChina 周三乱弹 —— 调查人员问狗 那你在做什么啊?

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 小小编辑推荐:《Let It Be》- John Denver 《Let It Be》- John Denver 手机党少年们想听歌,请使劲儿戳(这里) @FalconChen :每天看一遍,...

小小编辑
今天
6
0
高效程序员的45个习惯总结版-文末脑图

1 做事 一个重大的错误应该被当做一次学习而不是指责他人的机会,团队成员一起工作,应该互相帮助,而不是互相指责 2 欲速则不达 不要为了修复问题而去修复,要投入时间和精力保持代码整洁 ...

阿提说说
今天
18
0
带南海九段线分位数地图可视化(R语言版)

今天带来一篇承诺虾神的可视化博客。内容是使用R语言进行带南海九段线分位数地图可视化。虾神的原博文地址如下(Python版)。 Python实现带南海九段线分位数地图完整可视化版本(附代码及数据...

胖胖雕
今天
12
0
Nginx 的进程结构,你明白吗?

Nginx 进程结构 这篇文章我们来看下 Nginx 的进程结构,Nginx 其实有两种进程结构: 单进程结构 多进程结构 单进程结构实际上不适用于生产环境,只适合我们做开发调试使用。因为在生产环境中...

武培轩
今天
20
0
蓝鲸平台部署

环境 系统:Centos7 依赖包:java8 主机: 10.0.1.150 域名:paas.ops.net;cmdb.ops.net;job.ops.net 生成SSH key ssh-keygen -t rsa -P '' 生成证书 https://bk.tencent.com/download_ssl/......

以谁为师
今天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部