图片上传好用插件有,比如 uploadify  ueditor html5的各种ajax上传插件,大部分都是异步,返回只是true之类,有些时候需要上传图片需要一起上传,其实可以通过操作流程来避免这个问题,如果需要同步上传,改造的东西比较多

异步避免,比如有每个用户的图片相册,异步上传,然后你自己选需要上传图片,比如首先第一步吧需要的信息先提交给主表,第二步在上传多图,使用上面提到的插件,因为有了主表的ID,

还有自己比较大的改造,就是在同一页面,异步上传之后,返回图片的名字和相对路径input type hide一起抛到action页面,这种是比较好的,但是需要使用第三方插件改造的工作比较多,第一次之后就可以在多个项目中使用

ueditor 这个比较好用,如果需要使用请到笔者博客有专门介绍的博文

uploadify  目录结构

index.php 内容

  1. <!DOCTYPE HTML>
  2. <html>
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  5. <title>UploadiFive Test</title>
  6. <script src="http://resource.ehmall.com.cn/js/jquery.js" type="text/javascript"></script>
  7. <script src="jquery.uploadify.js" type="text/javascript"></script>
  8. <link rel="stylesheet" type="text/css" href="uploadify.css">
  9. </head>
  10.  
  11. <body>
  12. <link href="uploadify.css" rel="stylesheet" type="text/css">
  13. <script type="text/javascript" src="jquery.uploadify.js"></script>
  14.  
  15. <input id="file_upload" name="file_upload" type="file" multiple="true">
  16.  
  17. <a id="zx" href="javascript:">上传</a>
  18. <script type="text/javascript">
  19. $(function() {
  20. $('#file_upload').uploadify({
  21. auto : false, //是都自动上传
  22. buttonText : '选择图片', //按钮名称
  23. 'swf' : 'uploadify.swf', //使用到的swf
  24. 'uploader' : 'uploadify.php' //上传到那个文件
  25. });
  26. });
  27.  
  28. $("#zx").click(function(){
  29. $('#file_upload').uploadify('upload','*');
  30. });
  31.  
  32. </script>
  33. </body>
  34. </html>
  1. uploadify.php
  1. $targetFolder = '/uploads'; // Relative to the root
  2.  
  3. if (!empty($_FILES)) {
  4. $tempFile = $_FILES['Filedata']['tmp_name'];
  5. $targetPath = $_SERVER['DOCUMENT_ROOT'] . $targetFolder;
  6. $targetFile = rtrim($targetPath,'/') . '/' . $_FILES['Filedata']['name'];
  7.  
  8. // Validate the file type
  9. $fileTypes = array('jpg','jpeg','gif','png'); // File extensions
  10. $fileParts = pathinfo($_FILES['Filedata']['name']);
  11.  
  12. if (in_array($fileParts['extension'],$fileTypes)) {
  13. move_uploaded_file($tempFile,$targetFile);
  14. return $targetFile;
  15. } else {
  16. echo 'Invalid file type.';
  17. }
  18. }

Uploadify 3.2 参数属性、事件、方法函数详解

  1. 一、属性
  2. 属性名称 默认值 说明
  3. auto true 设置为true当选择文件后就直接上传了,为false需要点击上传按钮才上传
  4. buttonClass 按钮样式
  5. buttonCursor hand 鼠标指针悬停在按钮上的样子
  6. buttonImage null 浏览按钮的图片的路径
  7. buttonText SELECT FILES 浏览按钮的文本。
  8. checkExisting false 文件上传重复性检查程序,检查即将上传的文件在服务器端是否已存在,存在返回1,不存在返回0
  9. debug false 如果设置为true则表示启用SWFUpload的调试模式
  10. fileObjName Filedata 文件上传对象的名称,如果命名为’the_files’,PHP程序可以用$_FILES['the_files']来处理上传的文件对象。
  11. fileSizeLimit 0
  12. 上传文件的大小限制 ,如果为整数型则表示以KB为单位的大小,如果是字符串,则可以使用(B, KB, MB, or GB)为单位,比如’2MB’;
  13.  
  14. 如果设置为0则表示无限制
  15.  
  16. fileTypeDesc All Files 这个属性值必须设置fileTypeExts属性后才有效,用来设置选择文件对话框中的提示文本,如设置fileTypeDesc为“请选择rar doc pdf文件”
  17. fileTypeExts ‘*.*’ 设置可以选择的文件的类型,格式如:’*.doc;*.pdf;*.rar
  18. formData JSON格式上传每个文件的同时提交到服务器的额外数据,可在’onUploadStart’事件中使用’settings’方法动态设置。
  19. height 30 设置浏览按钮的高度 ,默认值
  20. itemTemplate false 用于设置上传队列的HTML模版,可以使用以下标签:
  21. instanceID Uploadify实例的ID
  22. fileID 列队中此文件的ID,或者理解为此任务的ID
  23. fileName 文件的名称
  24. fileSize 当前上传文件的大小
  25. 插入模版标签时使用格式如:${fileName}
  26. method Post 提交方式PostGet
  27. multi true 设置为true时可以上传多个文件。
  28. overrideEvents 设置哪些事件可以被重写,JSON格式,如:’overrideEvents : ['onUploadProgress']
  29. preventCaching true 如果为true,则每次上传文件时自动加上一串随机字符串参数,防止URL缓存影响上传结果
  30. progressData percentage 设置上传进度显示方式,percentage显示上传百分比,speed显示上传速度
  31. queueID false 设置上传队列容器DOM元素的ID,如果为false则自动生成一个队列容器。
  32. queueSizeLimit 999 队列最多显示的任务数量,如果选择的文件数量超出此限制,将会出发onSelectError事件。
  33. 注意此项并非最大文件上传数量,如果要限制最大上传文件数量,应设置uploadLimit
  34. removeCompleted true 是否自动将已完成任务从队列中删除,如果设置为false则会一直保留此任务显示。
  35. removeTimeout 3 如果设置了任务完成后自动从队列中移除,则可以规定从完成到被移除的时间间隔。
  36. requeueErrors false 如果设置为true,则单个任务上传失败后将返回错误,并重新加入任务队列上传。
  37. successTimeout 30 文件上传成功后服务端应返回成功标志,此项设置返回结果的超时时间
  38. swf uploadify.swf uploadify.swf 文件的相对路径。
  39. uploader uploadify.php 后台处理程序的相对路径。
  40. uploadLimit 999 最大上传文件数量,如果达到或超出此限制将会触发onUploadError事件。
  41. width 120 设置文件浏览按钮的宽度。
  42.  
  43. 二、事件
  44. 事件名称 说明
  45. onCancel(file)
  46. 当点击文件队列中文件的关闭按钮或点击取消上传时触发,file参数为被取消上传的文件对象
  47.  
  48. onClearQueue(queueItemCount) 当调用函数cancel方法时触发,queueItemCount参数为被取消上传的文件数量。
  49. onDestroy() destory方法被调用时触发
  50. onDialogClose(queueData)
  51. 当文件浏览框关闭时触发,如果将此事件被重写,则当向队列添加文件上传出错时不会弹出错误消息提示。
  52.  
  53. queueData对象包含如下属性:
  54.  
  55. filesSelected 文件选择对话框中共选择了多少个文件
  56. filesQueued 已经向队列中添加了多少个文件
  57. filesReplaced 已经向队列中替换了多少个文件
  58. filesCancelled 取消了多少个文件 filesErrored 出错了多少个文件
  59. onDialogOpen() 当文件选择对话框弹出时立即出发,但可能在文件选择对话框被关闭之前并不能全部执行。
  60. onDisable() disable方法禁用Uploadify上传按钮时被调用时触发。
  61. onEnable() disable方法启用Uploadify上传按钮时被调用时触发。
  62. onFallback() Uploadify初始化过程中检测到当前浏览器不支持flash时触发。
  63. onInit() 首次初始化Uploadify结束时触发。
  64. onQueueComplete(queueData)
  65. 文件上传队列处理完毕后触发。
  66.  
  67. queueData对象包含如下属性:
  68.  
  69. uploadsSuccessful 上传成功的文件数量
  70. uploadsErrored 上传失败的文件数量
  71. onSelect(file)
  72. 选择文件后向队列中添加每个上传任务时都会触发。
  73.  
  74. onSelectError(file, errorCode, errorMsg)
  75. 选择文件后向队列中添加每个上传任务时如果失败都会触发。
  76.  
  77. file 文件对象
  78.  
  79. errorCode 错误代码如下:
  80.  
  81. QUEUE_LIMIT_EXCEEDED 任务数量超出队列限制;
  82. FILE_EXCEEDS_SIZE_LIMIT 文件大小超出限制;
  83. ZERO_BYTE_FILE 文件大小为0
  84. INVALID_FILETYPE 文件类型不符合要求
  85. errorMsg 错误提示,可通过’this.queueData.errorMsg’定制
  86.  
  87. onSWFReady() Flash文件载入成功后触发。
  88. onUploadComplete(file) 每个文件上传完毕后无论成功与否都会触发。
  89. onUploadError(file, errorCode, errorMsg, errorString) 文件上传出错时触发,参数由服务端程序返回。
  90. onUploadProgress(file, bytesUploaded, bytesTotal, totalBytesUploaded, totalBytesTotal)
  91. 处理上传队列的过程中会多次触发此事件,每当任务状态有更新时都会触发。
  92.  
  93. file 文件对象
  94. bytesUploaded 已上传的字节数
  95. bytesTotal 文件总字节数
  96. totalBytesUploaded 当前任务队列中全部文件已上传的总字节数
  97. totalBytesTotal 当前任务队列中全部文件的总字节数
  98. onUploadStart(file) 当文件即将开始上传时立即触发
  99. onUploadSuccess(file, data, response)
  100. 当文件上传成功时触发
  101.  
  102. file 文件对象
  103. data 服务端输出返回的信息
  104. response 有输出时为true,如果无响应为false,如果返回的是false,当超过successTimeout设置的时间后假定为true
  105. 三、方法
  106. 方法名称 说明 应用举例
  107. cancel(fileID, suppressEvent)
  108. 取消队列中的任务,不管此任务是否已经开始上传
  109.  
  110. fileID 要取消的文件ID,如果为空则取消队列中第一个任务,如果为’*'则取消所有任务
  111. suppressEvent – 是否阻止触发onUploadCancel事件,当清空队列时非常实用。
  112. <a href="javascript:$(‘#file_upload’).uploadify(‘cancel’)">取消第一个</a>
  113.  
  114. <a href="javascript:$(‘#file_upload’).uploadify(‘cancel’, ‘*’)">清空队列</a>
  115.  
  116. <a href="javascript:$(‘#file_upload’).uploadify(‘upload’, ‘*’)">开始上传所有任务</a>
  117.  
  118. destroy() 销毁Uploadify实例并将文件上传按钮恢复到原始状态 <a href="javascript:$(‘#file_upload’).uploadify(‘destroy’)">销毁Uploadify实例</a>
  119. disable(setDisabled)
  120. 禁用或启用文件浏览按钮
  121.  
  122. setDisabled – 设置为true表示禁用,false为启用
  123.  
  124. <a href="javascript:$(‘#file_upload’).uploadify(‘disable’, true)">禁用按钮</a>
  125.  
  126. <a href="javascript:$(‘#file_upload’).uploadify(‘disable’, false)">启用按钮</a>
  127.  
  128. settings(name, value, resetObjects)
  129. 获取或设置Uploadify实例参数
  130.  
  131. name – 属性名称,如果只提供属性名称则表示获取其值
  132. value – 属性值
  133. resetObjects – 设置为true时,更新postData对象将清空现有的值。否则,新的值将被添加到其末尾。
  134. $(‘#file_upload’).uploadify(‘settings’,'buttonText’,'BROWSE’);
  135.  
  136. $(‘#file_upload’).uploadify(‘settings’,'buttonText’));
  137.  
  138. stop() 停止当前正在上传的任务
  139. <a href="javascript:$(‘#file_upload’).uploadify(‘upload’, ‘*’)">开始上传</a>
  140.  
  141. <a href="javascript:$(‘#file_upload’).uploadify(‘stop’)">停止上传</a>
  142.  
  143. upload(fileID) 立即上传指定的文件,如果fileID为’*'表示上传所有文件,要指定上传多个文件,则将每个文件的fileID作为一个参数 <a href="javascript:$(‘#file_upload’).uploadify(‘upload’,'*’)">开始上传所有文
  144.  
  145. 关于无法在formData获取到值得解决办法:在动态设置setting里设置就可以了,还是不知道是什么原因在直接配置文件里获取不到值。 另外如果将上传文件信息保存在session里要注意遍历的时候会有一点BUG,直接循环写入数据库会多出一组,原因暂时不明

接来下是html5的自带的多任务文件上传input控件

在IE8以上的都可以支持,其他浏览器都没问题,只有ie8,ie8以下不支持html5,蛋疼你懂的

  1. <form action="save.php" method="post" enctype="multipart/form-data">
  2.  
  3. <input type="file" name="fileToUpload[]" id="fileToUpload" multiple="multiple">
  4. <input type="submit" value="提交"/>
  5.  
  6. </form>
  1. // 处理$_FILES['pic_set']的数据格式
  2. foreach ($_FILES['pic_set'] as $key => $value) {
  3. $i = 0;
  4. foreach ($value as $v) {
  5. $de[$i][$key] = $v;
  6. $i++;
  7. }
  8. }
  9.  
  10. foreach ($de as $va) {
  11. $tempFile = $va['tmp_name'];
  12.  
  13. $tempath = '/data/upload/cms/pic_set/'.date("Ymd",time());
  14. $targetPath = $_SERVER['DOCUMENT_ROOT'].$tempath;
  15. if(!is_dir($targetPath)){
  16. mkdir($targetPath,'0777',true);
  17. }
  18. $targetFilename = time().rand(1,10000);
  19.  
  20. $fileTypes = array('jpg','jpeg','gif','png'); // File extensions
  21. $fileParts = pathinfo($va['name']);
  22.  
  23. $targetFile = $targetPath.'/'.$targetFilename.'.'.$fileParts['extension'];
  24.  
  25. if (in_array($fileParts['extension'],$fileTypes)) {
  26. move_uploaded_file($tempFile,$targetFile);
  27. }
  28. $url[] = 'cms/pic_set/'.date("Ymd",time()).'/'.$targetFilename.'.'.$fileParts['extension'];
  29. }
  30.  
  31. foreach ($url as $v1) {
  32. $data1['catalog_id'] = $catalog_id;
  33. $data1['pic_set_url'] = $v1;
  34. Model()->table('catalog_pic_set')->insert($data1);
  35.  
  36. }

值得注意的一点,就是name需要带[],而且post过来的数据需要整理

  1. array
  2. 'fileToUpload' =>
  3. array
  4. 'name' =>
  5. array
  6. 0 => string 'QQ Photo20150910172712.png' (length=26)
  7. 1 => string 'Unnamed QQ Screenshot20151119145202.jpg' (length=39)
  8. 'type' =>
  9. array
  10. 0 => string 'image/png' (length=9)
  11. 1 => string 'image/jpeg' (length=10)
  12. 'tmp_name' =>
  13. array
  14. 0 => string 'C:\wamp\tmp\php7BE.tmp' (length=22)
  15. 1 => string 'C:\wamp\tmp\php7BF.tmp' (length=22)
  16. 'error' =>
  17. array
  18. 0 => int 0
  19. 1 => int 0
  20. 'size' =>
  21. array
  22. 0 => int 21664
  23. 1 => int 14293

是这个样子的,但是需要整理成

  1. array
  2. 0 =>
  3. array
  4. 'name' => string 'QQ Photo20150910172712.png' (length=26)
  5. 'type' => string 'image/png' (length=9)
  6. 'tmp_name' => string 'C:\wamp\tmp\php63E4.tmp' (length=23)
  7. 'error' => int 0
  8. 'size' => int 21664
  9. 1 =>
  10. array
  11. 'name' => string 'Unnamed QQ Screenshot20151119145202.jpg' (length=39)
  12. 'type' => string 'image/jpeg' (length=10)
  13. 'tmp_name' => string 'C:\wamp\tmp\php63E5.tmp' (length=23)
  14. 'error' => int 0
  15. 'size' => int 14293

才能持续上传文件,但是这个是一个不好的方法,最好还是异步上传,这样才会吧php弄崩溃,特别是网络慢的时候,返回图片名称和路径,全部一起post,或者分步

uploadify中文开发文档,解决php多图上传的更多相关文章

  1. 在线API,桌面版,jquery,css,Android中文开发文档,JScript,SQL掌用实例

    学习帮助文档大全 jquery,css,Android中文开发文档,JScript,SQL掌用实例 http://api.jq-school.com/

  2. jssip中文开发文档(完整版)

    jsSip开发文档 (官网地址:http://www.jssip.net/) 完整案例demo下载地址: http://download.csdn.net/download/qq_39421580/1 ...

  3. sweetalert api中文开发文档和手册

    官网和下载地址: http://t4t5.github.io/sweetalert/  2016年10月30日14:10:21 废话,目前php开发越来越API话,所以php方法很多都是json返回数 ...

  4. phpredis中文开发文档

    刚好要用看了网上翻译版本都是2011,2012年的,随手翻译一下新版 2017年10月28日23:48:08 使用方法 : Ctrl+F 官方英文版 https://github.com/phpred ...

  5. (网页)sweetalert api 中文开发文档和手册,项目放弃alert

    弹框json的特别好使. sweetalert 示例 基本信息弹窗swal("这是一条信息!") 标题与文本的信息弹窗swal("这是一条信息!", " ...

  6. 若快打码平台python开发文档修改版

    一.打码的作用 在进行爬虫过程中,部分网站的登录验证码是比较简单的,例如四个英文数字随机组合而成的验证码,有的是全数字随机组成的验证码,有的是全中文随机组成的验证码.为了爬虫进行自动化,需要解决自动登 ...

  7. [翻译]开发文档:android Bitmap的高效使用

    内容概述 本文内容来自开发文档"Traning > Displaying Bitmaps Efficiently",包括大尺寸Bitmap的高效加载,图片的异步加载和数据缓存 ...

  8. AFC项目开发文档整理

    AFC项目开发文档整理 PHPCMS 的确是一个伟大的CMS,我对它爱不释手. 标签嵌套无法loop获取的解决办法.关键代码如下: /\*后台添加\*/ $str = preg_replace ( & ...

  9. QM项目开发文档整理

    QM项目开发文档整理 前言 在W公司工作4个多月,庆幸接触到的全是"硬"项目,真枪实干,技术.经验.能力都得到了很大提升. QM项目 此项目WEB前端学到的东西很多,对PHP项目的 ...

随机推荐

  1. (转)超过 130 个你需要了解的 vim 命令

    从 1970 年开始,vi 和 vim 就成为了程序员最喜爱的文本编辑器之一.5 年前,我写了一个问自己名为 “每个程序员都应该知道的 100 个 vim 命令” 这次算是之前那篇文章的改进版,希望你 ...

  2. 设置log rotation避免tomcat catalina.out文件增长过大

    创建logrotate配置文件 $ vi /etc/logrotate.d/tomcat 添加以下内容: /opt/tomcat/logs/catalina.out { copytruncate da ...

  3. DUAL PORT RAM应用实例

    作者:桂. 时间:2018-05-14  12:11:00 链接:http://www.cnblogs.com/xingshansi/p/9035522.html 前言 主要是Xilinx 常用模块汇 ...

  4. Sql2008中添加程序集(转)

    一.示例演示 1.用C# 建立数据库 CRL 项目 public partial class MyClr{    [Microsoft.SqlServer.Server.SqlFunction]    ...

  5. 菜鸟学Java(二十三)——Java内存分析

    我们常说的Java内存主要分为四大块(寄存器不在考虑之内,我们无法用代码来操控它):stack(栈).heap(堆).data segment(数据区).code segment(代码区).它们的主要 ...

  6. batch,iteration,epoch 什么意思

    深度学习中经常看到epoch. iteration和batchsize,下面按自己的理解说说这三个的区别: (1)batchsize:批大小.在深度学习中,一般采用SGD训练,即每次训练在训练集中取b ...

  7. Git应用实践(一)

    [时间:2017-03] [状态:Open] [关键词:Git,ssh,远程仓库,git remote] 0-背景 近期在使用Git@oschina上发现以下两个问题: 我的提交有两个名和email, ...

  8. Nginx配置WebService、MySQL、SQL Server、ORACLE等代理

    首先介绍一下Nginx的基本使用: 注意不要直接双击nginx.exe,这样会导致修改配置后重启.停止nginx无效,需要手动关闭任务管理器内的所有nginx进程 在nginx.exe目录,打开命令行 ...

  9. Git 藏匿操作

    假设您正在为您的产品实施的一项新功能.你的代码是在推进开发进度而客户不断升级需求突然来了.正因为如此,你必须保持放下你的新功能,工作几个小时.你不能提交你的部分代码,也不能扔掉你的变化.所以,你需要一 ...

  10. [echarts] 横纵数据散点图

    需求:课程平均分(X)与课程通过率散点图 http://echarts.baidu.com/echarts2/doc/example/scatter1.html https://www.cnblogs ...