• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    php + WebUploader实现图片批量上传功能

    一.webuploader

    webuploader主要用来做文件的上传,支持批量上传和图片预览,图片预览是将图片生成base64数据直接在标签中使用,所以能够达到的效果是未真正上传图片可以先看到上传的效果。更多具体的介绍,可以上webuploader的官方网址看,我一直认为,看官网文档是学习最直接的途径。 webuploader官方网站,顺带一提,webuploader是由Baidu Fex Team团队进行维护的。

    二. webuploader上传原理

    1. PHP+HTML表单上传文件

    在讲这个之前,需要先了解一下php的文件上传方式,上传分两个部分

    先通过html创建表单,在表单中添加

    input type='file' name='xxx'>

    的文件上传标签,点击上传的submit 按钮之后,就可以将文件上传到服务器了。

    2. 到了服务器端,接收到的上传文件会被存储在php指定的临时文件夹中,利用PHP的内置函数move_uploaded_file(),就可以将临时文件移动到你想要的目标文件夹中,这个过程可以对文件进行改名、做大小判断是否符合条件等,这样上传就完成了。

    完整的php表单上传案例,可以看w3school的这篇文章,这里就不累赘了。PHP+HTML表单上传文件

    2. webuploader上传原理

    使用php+html表单上传可以完成文件的上传工作,但是有缺点,

    webuploader解决了这两个问题,webuploader使用ajax技术提交表单,上传的时候不需要提交页面,可以利用事件监听机制监听上传的结果,在页面中做出反馈,而且还能做图片预览。使用webuploader上传图片,也只需要几步:

    这里说一点,后台PHP接收和处理图片其实和PHP+HTML表单上传基本是一样的。

    三. webuploader的配置和使用

    所有的配置参数和使用方法都可以查看官方文件。webuploader官方网站,在webuploader github仓库中有一些example案例可以参考。example

    我的运行环境:php5.6+nginx+macOS

    我的文件夹的目录

    1. 前台HTML页面配置webupload

    主要做以下几个步骤:

    index.html

    !doctype html>
    html lang="cn">
    head>
      meta charset="UTF-8">
      meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
      title>WebUploader演示/title>
      link rel="stylesheet" type="text/css" href="webuploader/css/webuploader.css" />
      link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css" />
      link rel="shortcut icon" href="favicon.ico">
    /head>
    body>
    
      div id="imgPicker">选择文件/div>
      button class="btn btn-primary btn-upload">上传/button>
      div class="img-thumb">/div>
      div class="result">/div>
      
    !--jquery 1.12-->
    script src="https://cdn.jsdelivr.net/npm/jquery@1.12.4/dist/jquery.min.js">/script>
    !--bootstrap核心js文件-->
    script src="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/js/bootstrap.min.js">/script>
    !--webuploader js-->
    !--script type="text/javascript" src="static/jquery.js">/script>-->
    script type="text/javascript" src="webuploader/dist/webuploader.min.js">/script>
    script type="text/javascript" src="mywebupload.js">/script>
    /body>
    /html>

    mywebupload.js

    $(function(){
    
      /*
       *  配置webuploader
       */
    
      var imgUploader = WebUploader.create({
        fileVal: 'img', // 相当于input标签的name属性,用于后台PHP识别接收上传文件的field
        swf: './webuploader/dist/Uploader.swf', // swf文件路径
        server: './upload_img.php', // 文件接收服务端。
        fileNumLimit: 10,  // 上传文件的限制
        pick: {
          id : '#imgPicker',  // 
          multiple : true      // 是否支持多文件上传
        },
        // 只允许上传图片
        accept: {
          title: 'Only Images',
          extensions: 'gif,jpg,jpeg,bmp,png',
          mimeTypes: 'image/jpg,image/jpeg,image/png,image/gif,image/bmp'
        },
        auto: false,  // 添加文件后是否自动上传上去,我设置了false,后面我会利用自己的上传按钮上传
        resize: false  // 不压缩image, 默认如果是jpeg,文件上传前会压缩一把再上传!
      });
      
      /*
       *  设置上传按钮的单击事件
       */
      $('.btn-upload').click(function(){
        imgUploader.upload();  // webuploader内置的upload函数,启动webuploader的上传  
      });
      
      /*
       *  配置webuploader的事件监听 
       */
      
      // 当图片文件被添加到上传队列中
      imgUploader.on('fileQueued', function (file) {
        addImgThumb(file);
      });
      
      // 生产图片预览
      function addImgThumb(file){
        imgUploader.makeThumb(file, function(error, ret){
          if(!error){
            img = 'img alt="" src="' + ret + '" />';
            $('.img-thumb').append(img);
          }else{
            console.log('making img error');
          }
        },1,1);
      }
      
      imgUploader.on('uploadSuccess'), function(file, response){
        // response 是后台upload_img.php返回的数据
        if(response.success){
          $('.result').append('p>' + file.name + '上传成功/p>')
        }else{
          $('.result').append('p>' + response.message + '/p>')
        }
      });
    })

    2. 后台PHP页面处理上传文件

    这里要注意几点:

    1 后台处理的php文件文件名必须跟webuploader配置的时候一样。

    2 上传的文件夹记得设置好权限,linux可以利用chmod来修改文件夹权限,否则会导致上传失败。

    我这里的处理方式比较简单,有什么问题可以给我留言。

    upload_img.php

    ?php
      $field = 'img';  // 对应webupload里设置的fileVal
      
      $savePath = './uploads/';    // 这里注意设置uploads文件夹的权限
      $saveName = time() . uniqid() . '_' . $_FILES[$field]['name']; // 为文件重命名
      $fullName = $savePath . $saveName; 
      
      if (file_exists($fullName)) {
        $result = [
          'success'=>false, 
          'message'=>'相同文件名的文件已经存在'
        ];
      }else{
        move_uploaded_file($_FILES[$field]["tmp_name"], $fullName);
        $result = ['success'=>true, 'fullName'=>$fullName];
      }
      
      return json_encode($result); // 将结果打包成json格式返回
    ?>

    以上就是webuploader的全部内容,更多webuploader的参数配置和事件可以参考webuploader的官方网址。希望大家多多留言交流指正。

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

    您可能感兴趣的文章:
    • 关于webuploader插件使用过程遇到的小问题
    • 推荐三款不错的图片压缩上传插件(webuploader、localResizeIMG4、LUploader)
    • 百度多文件异步上传控件webuploader基本用法解析
    • 使用WebUploader实现上传文件功能(一)
    • 快速掌握jQuery插件WebUploader文件上传
    • webuploader 实现图片批量上传功能附实例代码
    • webuploader实现上传图片到服务器功能
    • webuploader模态框ueditor显示问题解决方法
    • 使用WebUploader实现分片断点上传文件功能(二)
    • webuploader分片上传的实现代码(前后端分离)
    上一篇:thinkPHP5.1框架路由::get、post请求简单用法示例
    下一篇:PHP连接SQL Server的方法分析【基于thinkPHP5.1框架】
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    php + WebUploader实现图片批量上传功能 php,WebUploader,实现,图片,