基于手机端的base64异步多图上传+php后台程序处理【代码】

前端html代码

[html]  view plain  copy
  1. <!DOCTYPE html>  
  2. <html lang="en">  
  3. <head>  
  4.   <meta charset="UTF-8" />  
  5.   <meta id="viewport" name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">  
  6.   <title>WeUI-Uploader</title>  
  7.   <link rel="stylesheet" href="https://res.wx.qq.com/open/libs/weui/0.3.0/weui.css" />  
  8. </head>  
  9. <body>  
  10.   <div class="container">  
  11.     <div class="weui_cells_title">上传</div>  
  12.     <div class="weui_cells weui_cells_form">  
  13.       <div class="weui_cell">  
  14.         <div class="weui_cell_bd weui_cell_primary">  
  15.           <div class="weui_uploader">  
  16.             <div class="weui_uploader_hd weui_cell">  
  17.               <div class="weui_cell_bd weui_cell_primary">图片上传</div>  
  18.               <div class="weui_cell_ft js_counter">0/6</div>  
  19.             </div>  
  20.             <div class="weui_uploader_bd">  
  21.               <ul class="weui_uploader_files">  
  22.                 <!-- 预览图插入到这 --> </ul>  
  23.               <div class="weui_uploader_input_wrp">  
  24.                 <input class="weui_uploader_input js_file" type="file" accept="image/jpg,image/jpeg,image/png,image/gif" multiple=""></div>  
  25.             </div>  
  26.           </div>  
  27.         </div>  
  28.       </div>  
  29.     </div>  
  30.   </div>  
  31.   <div class="weui_dialog_alert" style="display: none;">  
  32.     <div class="weui_mask"></div>  
  33.     <div class="weui_dialog">  
  34.       <div class="weui_dialog_hd"> <strong class="weui_dialog_title">警告</strong>  
  35.       </div>  
  36.       <div class="weui_dialog_bd">弹窗内容,告知当前页面信息等</div>  
  37.       <div class="weui_dialog_ft">  
  38.         <a href="javascript:;" class="weui_btn_dialog primary">确定</a>  
  39.       </div>  
  40.     </div>  
  41.   </div>  
  42.   <script src="https://cdn.bootcss.com/zepto/1.1.6/zepto.min.js"></script>  
  43. </body>  
  44. </html>  
  45. <script>    
  46.   $.weui = {};    
  47.   $.weui.alert = function(options){    
  48.     options = $.extend({title: '警告', text: '警告内容'}, options);    
  49.     var $alert = $('.weui_dialog_alert');    
  50.     $alert.find('.weui_dialog_title').text(options.title);    
  51.     $alert.find('.weui_dialog_bd').text(options.text);    
  52.     $alert.on('touchend click', '.weui_btn_dialog', function(){    
  53.       $alert.hide();    
  54.     });    
  55.     $alert.show();    
  56.   };    
  57.     
  58.   $(function () {    
  59.     // 允许上传的图片类型    
  60.     var allowTypes = ['image/jpg', 'image/jpeg', 'image/png', 'image/gif'];    
  61.     // 1024KB,也就是 1MB    
  62.     var maxSize = 1024 * 1024;    
  63.     // 图片最大宽度    
  64.     var maxWidth = 300;    
  65.     // 最大上传图片数量    
  66.     var maxCount = 6;    
  67.     $('.js_file').on('change', function (event) {    
  68.       var files = event.target.files;    
  69.         
  70.         // 如果没有选中文件,直接返回    
  71.         if (files.length === 0) {    
  72.           return;    
  73.         }    
  74.           
  75.         for (var i = 0len = files.length; i < len; i++) {    
  76.           var file = files[i];    
  77.           var reader = new FileReader();    
  78.             
  79.             // 如果类型不在允许的类型范围内    
  80.             if (allowTypes.indexOf(file.type) === -1) {    
  81.               $.weui.alert({text: '该类型不允许上传'});    
  82.               continue;    
  83.             }    
  84.               
  85.             if (file.size > maxSize) {    
  86.               $.weui.alert({text: '图片太大,不允许上传'});    
  87.               continue;    
  88.             }    
  89.               
  90.             if ($('.weui_uploader_file').length >= maxCount) {    
  91.               $.weui.alert({text: '最多只能上传' + maxCount + '张图片'});    
  92.               return;    
  93.             }    
  94.               
  95.             reader.onload = function (e) {    
  96.               var img = new Image();    
  97.               img.onload = function () {    
  98.                     // 不要超出最大宽度    
  99.                     var w = Math.min(maxWidth, img.width);    
  100.                     // 高度按比例计算    
  101.                     var h = img.height * (w / img.width);    
  102.                     var canvas = document.createElement('canvas');    
  103.                     var ctx = canvas.getContext('2d');    
  104.                     // 设置 canvas 的宽度和高度    
  105.                     canvas.width = w;    
  106.                     canvas.height = h;    
  107.                     ctx.drawImage(img, 0, 0, w, h);    
  108.                     var base64 = canvas.toDataURL('image/png');    
  109.                       
  110.                     // 插入到预览区    
  111.                     var $preview = $('<li class="weui_uploader_file weui_uploader_status" style="background-image:url(' + base64 + ')"><div class="weui_uploader_status_content">0%</div></li>');    
  112.                     $('.weui_uploader_files').append($preview);    
  113.                     var num = $('.weui_uploader_file').length;    
  114.                     $('.js_counter').text(num + '/' + maxCount);    
  115.                       
  116.                     $.ajax({  
  117.                           type: 'POST',  
  118.                           url: 'http://127.0.0.4/index.php/Index/posts',  
  119.                           // data to be added to query string:  
  120.                           data: { name: base64 },  
  121.                           // type of data we are expecting in return:  
  122.                           dataType: 'json',  
  123.                           timeout: 300,  
  124.                           context: $('body'),  
  125.                           success: function(data){  
  126.                             // Supposing this JSON payload was received:  
  127.                             //   {"project": {"id": 42, "html": "<div>..." }}  
  128.                             // append the HTML to context object.  
  129.                             this.append(data.project.html)  
  130.                           },  
  131.                           error: function(xhr, type){  
  132.                             // alert('Ajax error!')  
  133.                           }  
  134.                         })  
  135.                     // alert(1);  
  136.                       
  137.                     // 然后假装在上传,可以post base64格式,也可以构造blob对象上传,也可以用微信JSSDK上传    
  138.                       
  139.                     var progress = 0;    
  140.                     function uploading() {    
  141.                       $preview.find('.weui_uploader_status_content').text(++progress + '%');    
  142.                       if (progress < 100) {    
  143.                         setTimeout(uploading, 30);    
  144.                       }    
  145.                       else {    
  146.                             // 如果是失败,塞一个失败图标    
  147.                             //$preview.find('.weui_uploader_status_content').html('<i class="weui_icon_warn"></i>');    
  148.                             $preview.removeClass('weui_uploader_status').find('.weui_uploader_status_content').remove();    
  149.                           }    
  150.                         }    
  151.                         setTimeout(uploading, 30);    
  152.                       };    
  153.                         
  154.                       img.src = e.target.result;    
  155.                     };    
  156.                     reader.readAsDataURL(file);    
  157.                   }    
  158.                 });    
  159.   });    
  160. //# sourceURL=pen.js    
  161. </script>  
  162. </body>  
  163. </html>  


后台php处理代码

[php]  view plain  copy
  1. function posts(){  
  2.         $name=isset($_POST['name'])?$_POST['name']:'0';  
  3.         if(!$name){echo 1;exit;}  
  4.         // $img = base64_decode($name);  
  5.         $img = base64_decode(explode(';base64,',$name)[1]);  
  6.         $datase=file_get_contents($img);  
  7.         $type=explode(';base64,',$name)[0];//图片类型  
  8.         $type=explode('data:',$type)[1];  
  9.         // echo $type;exit;  
  10.         if ($type == "image/gif") {  
  11.             $type='gif';  
  12.         }else if($type  == "image/jpeg"){  
  13.             $type='jpg';  
  14.         }else if($type == "image/pjpeg"){  
  15.             $type='jpg';  
  16.         }else if($type == "image/png"){  
  17.             $type='png';  
  18.         }  
  19.           
  20.         $imgsrc=date("y").date("m").date("d").'\\';//图片路径  
  21.         $imgname=generate_password(12).str_replace(',','',str_replace(' ','',microtime())).'.'.$type;//图片名称  
  22.         $src=dirname(dirname(dirname(dirname(__FILE__)))).'\Public\imgsecs\\';  
  23.         $this->mkdirs($src);//函数判断文件夹是否存在 如果存在则存入不存在则创建  
  24.         $this->mkdirs($src.$imgsrc);  
  25.         file_put_contents($src.$imgsrc.$imgname,$img);//保存图片,返回的是字节数  
  26.         echo $src.$imgsrc.$imgname;//图片储存地址  
  27.          
  28.         exit;  
  29.     }  

猜你喜欢

转载自blog.csdn.net/wuxiaoxue22/article/details/79738353