亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

php + WebUploader實現圖片批量上傳功能

2024-05-05 00:08:48
字體:
來源:轉載
供稿:網友

一.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上傳圖片,也只需要幾步:

  • 前臺HTML頁面配置webuploader
  • 后臺服務器PHP頁面接受webuploader的上傳圖片,然后進行處理。
  • 后臺處理完圖片返回json數據的結果給前臺
  • 前臺接收后作出反饋。

這里說一點,后臺PHP接收和處理圖片其實和PHP+HTML表單上傳基本是一樣的。

三. webuploader的配置和使用

所有的配置參數和使用方法都可以查看官方文件。webuploader官方網站,在webuploader github倉庫中有一些example案例可以參考。example

我的運行環境:php5.6+nginx+macOS

我的文件夾的目錄

  • index.php
  • upload_img.php
  • mywebupload.js
  • webuploader/
  • uploads/

1. 前臺HTML頁面配置webupload

主要做以下幾個步驟:

  • 引入webuploader的相關js和css包
  • 創建HTML標簽
  • 創建一個js文件,初始化webuploader  以下是整個頁面代碼,webuploader文件夾是在github上整個搬運下來的,然后我還用到了jquery來增強頁面的體驗。

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        $('.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的官方網址。希望大家多多留言交流指正。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国内精品小视频| 色综合视频一区中文字幕| 精品国产欧美成人夜夜嗨| 国产亚洲一区精品| 欧美日韩在线一区| 亚洲高清一二三区| 伊人久久久久久久久久久| 亚洲美女福利视频网站| 国产日产亚洲精品| 国产精品第2页| 国产美女久久精品香蕉69| 亚洲欧美日韩精品久久亚洲区| 欧美激情亚洲国产| 亚洲小视频在线| 亚洲激情视频在线观看| 国产日韩精品综合网站| 国产日本欧美一区二区三区在线| 成人午夜一级二级三级| 欧美成人精品一区二区三区| 丰满岳妇乱一区二区三区| www.xxxx精品| 欧美视频二区36p| 国产精品美腿一区在线看| 国产精品你懂得| 成人激情春色网| 欧美午夜xxx| 国产成人涩涩涩视频在线观看| 亚洲国产精品人久久电影| 久久精品欧美视频| 国模极品一区二区三区| 国产69精品久久久久99| 国产小视频国产精品| 国产精品第一区| 91极品视频在线| 国产精品福利久久久| 精品亚洲一区二区三区在线观看| 国产日本欧美一区二区三区在线| 亚洲少妇激情视频| 岛国视频午夜一区免费在线观看| 欧美日韩一二三四五区| 亚洲欧洲免费视频| 国产精品高潮呻吟久久av野狼| 亚洲欧洲一区二区三区在线观看| 久久久综合免费视频| 国产精品久久99久久| 国产精品成人aaaaa网站| 欧美富婆性猛交| 亚洲国产黄色片| 国产精品视频公开费视频| 在线精品播放av| 国产成人一区二区在线| 久久久久久97| 亚洲视频国产视频| 亚洲国产精品嫩草影院久久| 国产一区二区三区欧美| 三级精品视频久久久久| 国产精品自拍网| 一区二区国产精品视频| 日韩av色在线| 日韩电影视频免费| 亚洲欧美日韩久久久久久| 国产一区二区三区在线播放免费观看| 日韩精品视频观看| 亚洲美女视频网| www.久久久久久.com| 国产成人精彩在线视频九色| 久久理论片午夜琪琪电影网| 亚洲国产精品福利| 国产一区二区三区久久精品| 国产精品第七影院| 欧洲成人在线视频| 亚洲欧美日韩成人| 国产精品美女无圣光视频| 亚洲黄色av网站| 国产做受高潮69| 国自产精品手机在线观看视频| 国产精品99久久99久久久二8| 亚洲丝袜一区在线| 国产日韩欧美在线| 98精品国产自产在线观看| 91久久嫩草影院一区二区| 国产成人精品免高潮在线观看| 91色琪琪电影亚洲精品久久| 亚洲福利在线播放| 亚洲视频一区二区三区| 精品视频在线观看日韩| 久久久久久久久久久免费| 久久久国产一区二区| 国产精品入口尤物| 中文国产成人精品| 精品人伦一区二区三区蜜桃免费| 国产成人综合精品| 亚洲免费一在线| 久久精品国产亚洲7777| 国产精品视频资源| 中文在线不卡视频| 精品国产1区2区| 国产精品大片wwwwww| 中文字幕欧美国内| 色一情一乱一区二区| 黄色精品一区二区| 久久国产精品久久国产精品| 久久久精品国产| 欧美猛交ⅹxxx乱大交视频| 高跟丝袜欧美一区| 欧美资源在线观看| 欧美午夜丰满在线18影院| zzjj国产精品一区二区| 欧美日韩精品在线观看| 日韩av在线播放资源| 国产欧美精品在线| 亚洲欧美日本伦理| 亚洲福利在线看| 777777777亚洲妇女| 成人激情视频在线播放| 欧美性在线视频| 国产精品视频内| 欧美视频国产精品| 久久99国产精品久久久久久久久| 久久久www成人免费精品张筱雨| 亚洲综合在线播放| 日韩免费观看视频| 国产精品白丝jk喷水视频一区| 亚洲色图日韩av| 色哟哟网站入口亚洲精品| 成人有码在线视频| 亚洲精品久久久久久久久久久久久| 亚洲激情第一页| 国产精品一久久香蕉国产线看观看| 国内精品久久久久| 黑人与娇小精品av专区| 日韩精品在线观| 91精品国产高清久久久久久| 欧美成人精品在线播放| 日韩有码在线播放| 久久91精品国产91久久跳| 久久夜色精品亚洲噜噜国产mv| 91av在线国产| 久久免费福利视频| 国产精品欧美激情| 欧美亚洲在线播放| 久久av在线看| 91午夜理伦私人影院| 国产性色av一区二区| 国产精品久久久久久久av电影| 91免费精品国偷自产在线| 亚洲欧美另类在线观看| 欧美日韩国产成人在线观看| 亚洲jizzjizz日本少妇| 2020欧美日韩在线视频| 国产97色在线| 日韩欧美aaa| 欧美—级高清免费播放| 丝袜情趣国产精品| 日本三级久久久| 国产精品美女免费看| 久久91精品国产| 国产精品成人国产乱一区| 国产精品国语对白| 性欧美办公室18xxxxhd| 久久露脸国产精品| 久久视频在线看| 欧美在线视频观看免费网站| 精品日韩美女的视频高清|