基于手机端的base64异步多图上传+php后台程序处理【代码】
来源:互联网 发布:淘宝卖家怎么评价买家 编辑:程序博客网 时间:2024/06/07 17:44
前端效果
前端html代码
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" /> <meta id="viewport" name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0"> <title>WeUI-Uploader</title> <link rel="stylesheet" href="https://res.wx.qq.com/open/libs/weui/0.3.0/weui.css" /></head><body> <div class="container"> <div class="weui_cells_title">上传</div> <div class="weui_cells weui_cells_form"> <div class="weui_cell"> <div class="weui_cell_bd weui_cell_primary"> <div class="weui_uploader"> <div class="weui_uploader_hd weui_cell"> <div class="weui_cell_bd weui_cell_primary">图片上传</div> <div class="weui_cell_ft js_counter">0/6</div> </div> <div class="weui_uploader_bd"> <ul class="weui_uploader_files"> <!-- 预览图插入到这 --> </ul> <div class="weui_uploader_input_wrp"> <input class="weui_uploader_input js_file" type="file" accept="image/jpg,image/jpeg,image/png,image/gif" multiple=""></div> </div> </div> </div> </div> </div> </div> <div class="weui_dialog_alert" style="display: none;"> <div class="weui_mask"></div> <div class="weui_dialog"> <div class="weui_dialog_hd"> <strong class="weui_dialog_title">警告</strong> </div> <div class="weui_dialog_bd">弹窗内容,告知当前页面信息等</div> <div class="weui_dialog_ft"> <a href="javascript:;" class="weui_btn_dialog primary">确定</a> </div> </div> </div> <script src="https://cdn.bootcss.com/zepto/1.1.6/zepto.min.js"></script></body></html><script> $.weui = {}; $.weui.alert = function(options){ options = $.extend({title: '警告', text: '警告内容'}, options); var $alert = $('.weui_dialog_alert'); $alert.find('.weui_dialog_title').text(options.title); $alert.find('.weui_dialog_bd').text(options.text); $alert.on('touchend click', '.weui_btn_dialog', function(){ $alert.hide(); }); $alert.show(); }; $(function () { // 允许上传的图片类型 var allowTypes = ['image/jpg', 'image/jpeg', 'image/png', 'image/gif']; // 1024KB,也就是 1MB var maxSize = 1024 * 1024; // 图片最大宽度 var maxWidth = 300; // 最大上传图片数量 var maxCount = 6; $('.js_file').on('change', function (event) { var files = event.target.files; // 如果没有选中文件,直接返回 if (files.length === 0) { return; } for (var i = 0, len = files.length; i < len; i++) { var file = files[i]; var reader = new FileReader(); // 如果类型不在允许的类型范围内 if (allowTypes.indexOf(file.type) === -1) { $.weui.alert({text: '该类型不允许上传'}); continue; } if (file.size > maxSize) { $.weui.alert({text: '图片太大,不允许上传'}); continue; } if ($('.weui_uploader_file').length >= maxCount) { $.weui.alert({text: '最多只能上传' + maxCount + '张图片'}); return; } reader.onload = function (e) { var img = new Image(); img.onload = function () { // 不要超出最大宽度 var w = Math.min(maxWidth, img.width); // 高度按比例计算 var h = img.height * (w / img.width); var canvas = document.createElement('canvas'); var ctx = canvas.getContext('2d'); // 设置 canvas 的宽度和高度 canvas.width = w; canvas.height = h; ctx.drawImage(img, 0, 0, w, h); var base64 = canvas.toDataURL('image/png'); // 插入到预览区 var $preview = $('<li class="weui_uploader_file weui_uploader_status" style="background-image:url(' + base64 + ')"><div class="weui_uploader_status_content">0%</div></li>'); $('.weui_uploader_files').append($preview); var num = $('.weui_uploader_file').length; $('.js_counter').text(num + '/' + maxCount); $.ajax({ type: 'POST', url: 'http://127.0.0.4/index.php/Index/posts', // data to be added to query string: data: { name: base64 }, // type of data we are expecting in return: dataType: 'json', timeout: 300, context: $('body'), success: function(data){ // Supposing this JSON payload was received: // {"project": {"id": 42, "html": "<div>..." }} // append the HTML to context object. this.append(data.project.html) }, error: function(xhr, type){ // alert('Ajax error!') }}) // alert(1); // 然后假装在上传,可以post base64格式,也可以构造blob对象上传,也可以用微信JSSDK上传 var progress = 0; function uploading() { $preview.find('.weui_uploader_status_content').text(++progress + '%'); if (progress < 100) { setTimeout(uploading, 30); } else { // 如果是失败,塞一个失败图标 //$preview.find('.weui_uploader_status_content').html('<i class="weui_icon_warn"></i>'); $preview.removeClass('weui_uploader_status').find('.weui_uploader_status_content').remove(); } } setTimeout(uploading, 30); }; img.src = e.target.result; }; reader.readAsDataURL(file); } }); }); //# sourceURL=pen.js </script></body></html>
后台php处理代码
function posts(){ $name=isset($_POST['name'])?$_POST['name']:'0'; if(!$name){echo 1;exit;} // $img = base64_decode($name); $img = base64_decode(explode(';base64,',$name)[1]); $datase=file_get_contents($img); $type=explode(';base64,',$name)[0];//图片类型 $type=explode('data:',$type)[1]; // echo $type;exit; if ($type == "image/gif") { $type='gif'; }else if($type == "image/jpeg"){ $type='jpg'; }else if($type == "image/pjpeg"){ $type='jpg'; }else if($type == "image/png"){ $type='png'; } $imgsrc=date("y").date("m").date("d").'\\';//图片路径 $imgname=generate_password(12).str_replace(',','',str_replace(' ','',microtime())).'.'.$type;//图片名称 $src=dirname(dirname(dirname(dirname(__FILE__)))).'\Public\imgsecs\\'; $this->mkdirs($src);//函数判断文件夹是否存在 如果存在则存入不存在则创建 $this->mkdirs($src.$imgsrc); file_put_contents($src.$imgsrc.$imgname,$img);//保存图片,返回的是字节数 echo $src.$imgsrc.$imgname;//图片储存地址 exit; }
阅读全文
0 0
- 基于手机端的base64异步多图上传+php后台程序处理【代码】
- PHP后台程序对LINUX信号的处理
- 基于PHP的AJAX技术实现文件异步上传
- 基于PHP的AJAX技术 实现文件异步上传
- 基于PHP的AJAX技术实现文件异步上传
- 基于PHP的AJAX技术实现文件异步上传方法
- 基于PHP的AJAX技术实现文件异步上传
- php+ajax+jquery后台程序处理
- 异步上传文件以及php对文件的处理
- 基于jquery的异步上传,异步提交
- php base64图片上传
- 支持多文件上传,预览,拖拽,基于bootstrap的上传插件fileinput的ajax异步上传
- php单图上传,多图上传,图片批量上传,图片异步上传Thinkphp整合kindeditor
- flash8上传功能的后台程序收集
- 异步的多文件上传和文件存储代码
- 处理文件上传使用base64
- php下base64图片上传
- PHP做后台程序的一些问题
- RCFile和ORCFile
- 1034. Head of a Gang (30) <广搜>
- cURL实现发送Get和Post请求(PHP)
- ios-运用第三方字体
- Android App 瘦身总结 第一章 图片资源的优化处理
- 基于手机端的base64异步多图上传+php后台程序处理【代码】
- 107. Binary Tree Level Order Traversal II
- zynq bit文件固化在flash里,上电不启动
- Hadoop系列--Hadoop介绍(Hadoop是什么)
- scipy安装
- 盘点四个最好用的JavaScript语言IDE
- RESTful API详解
- 项目之思(日常更新)
- [解决问题]apache2安装以后无法解析php代码