当前位置: 首页 > 编程日记 > 正文

转: 如何实现jQuery的Ajax文件上传

【PHP文件上传】

在开始之前,我觉得是有必要把通WEB上传文件的原理简单说一下的。
实际上,在这里不管是PHP,JSP,还是ASP处理上传的文件,其实都是WEB早已把文件上传到服务器了,我们只是运用上传处理函数来处理上传的文件
而处理函数一般都是用PHP,JSP,ASP等服务端语言来实现的。那么如何通过WEB(HTTP协议来上传文件呢?)你需要类似于以下的HTML代码:
test.html
<form action="do_file_upload.php" method="post" enctype="multipart/form-data">
<p>Pictures:
<input type="file" name="picture" />
<input type="submit" value="Send" />
</p>
</form>
注意:enctype="multipart/form-data",是必需的,它告诉FORM表这个是一文件上传类型,一旦这次请求成功后,文件就被上传到了服务器的临时文件夹中,
至于到达目的地后,文件将会被怎么样处理那就是PHP,JSP,ASP的事了。
(不过,你不要高兴的太早,如果该文件没有被移动到其它地方也没有被改名,则该文件将在表单请求结束时被删除。所以我们要写一个处理上传文件的脚本)
这里我们用PHP来处理
do_file_upload.php
<?php
$error = ""; //上传文件出错信息
$msg = "";
$fileElementName = 'picture';
    $allowType = array(".jpg",".gif",".png"); //允许上传的文件类型
    $num      = strrpos($_FILES['picture']['name'] ,'.');  
$fileSuffixName    = substr($_FILES['picture']['name'],$num,8);//此数可变  
$fileSuffixName    = strtolower($fileSuffixName); //确定上传文件的类型
    
$upFilePath             = 'd:/'; //最终存放路径

if(!empty($_FILES[$fileElementName]['error']))
{
   switch($_FILES[$fileElementName]['error'])
   {

case '1':
     $error = '传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值';
     break;
    case '2':
     $error = '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值';
     break;
    case '3':
     $error = '文件只有部分被上传';
     break;
    case '4':
     $error = '没有文件被上传';
     break;

case '6':
     $error = '找不到临时文件夹';
     break;
    case '7':
     $error = '文件写入失败';
     break;
    default:
     $error = '未知错误';
   }
}elseif(empty($_FILES['fileToUpload']['tmp_name']) || $_FILES['fileToUpload']['tmp_name'] == 'none')
{
   $error = '没有上传文件.';
}else if(!in_array($fileSuffixName,$allowType))
{
   $error = '不允许上传的文件类型'; 
}else{
  $ok=@move_uploaded_file($_FILES['fileToUpload']['tmp_name'],$upFilePath);
   if($ok === FALSE){
    $error = '上传失败';
   }
}
?>


另注:关于$_FILES数组
此数组包含有所有上传的文件信息,即记录下了上传文件时的相关信息。 
以上范例中 $_FILES 数组的内容如下所示。我们假设文件上传字段的名称如上例所示,为 userfile。名称可随意命名。

$_FILES['userfile']['name'] 
客户端机器文件的原名称。

$_FILES['userfile']['type'] 
文件的 MIME 类型,如果浏览器提供此信息的话。一个例子是“image/gif”。不过此 MIME 类型在 PHP 端并不检查,因此不要想当然认为有这个值。

$_FILES['userfile']['size'] 
已上传文件的大小,单位为字节。

$_FILES['userfile']['tmp_name'] 
文件被上传后在服务端储存的临时文件名。

$_FILES['userfile']['error'] 
和该文件上传相关的错误代码。此项目是在 PHP 4.2.0 版本中增加的。


AJAX文件上传

其实就是实现无刷新式的文件上传。可采用IFRAME文件上传原理。
实际上在用PHP上传文件时。。。只能用$_FILES形式,但是若我们只是单一的用JS方式取其ID,如<input id='img' type='file'>..document.getElementById('img').value或者jquery形式的$("#img")都是不能正真实际上传的(但是还是有很多人这样做,刚开始时我也是)。
可是功能上又要要求实现所谓的“异步上传”,怎么办呢??只能借助于第三方的组件,或者自己写一个(在网页里嵌入一个IFRAME)。但如果是考虑开发时间,那以用第三方的,这里有一个不错的jQuery的Ajax文件上传的组件,是“ajaxfileupload.js",其组件下载地址为:http://www.phpletter.com/,下载完毕里面有一个php的应用demo,很容易看懂的。
过程:
(1 )前端上文件的代码: test.php

<script type="text/javascript" src="jquery.js"></script> 
    <script type="text/javascript" src="ajaxfileupload.js"></script>
    <script type="text/javascript">
       function ajaxFileUpload()
               {
                  $.ajaxFileUpload
                     (
                       {
                            url:'doajaxfileupload.php', //你处理上传文件的服务端
                            secureuri:false,
                            fileElementId:'img',
                            dataType: 'json',
                            success: function (data)
                                  {
                                    alert(data.file_infor);
                                  }
                               }
                         )

                       return false;
                 } 
     </script>
相应的HTML为:
        <input id="img" type="file" size="45" name="img" class="input">
        <button class="button" id="buttonUpload" οnclick="return ajaxFileUpload();">Upload</button>

这样客户端就完成了。
         
(2) 再服务器端时   doajaxfileupload.php

此处为了简便的检测是否真正的传值过来了,你可以将它存起来了。
             $file_infor = var_export($_FILES,true);
             file_put_contents("d:file_infor.php".$file_infor);
   这样你打来刚生成的file_infor.php文件时,你又看到了熟悉的信息了:
     array(
             'name'=>'lamp.jpg',
             'type'=>'image/pjpeg',
             'tmp_name'=>'c:/windows/temp/phpFA.tmp',
             'error'=>0,
             'size'=>3127
         )
当然,真正的处理类于这样的:
   <?php
     $upFilePath = "d:/";
     $ok=@move_uploaded_file($_FILES['img']['tmp_name'],$upFilePath);
   if($ok === FALSE){
    echo json_encode('file_infor'=>'上传失败');
   }else{
    echo json_encode('file_infor'=>'上传成功');
   }
   ?>    
另注:实际上,你可以在一个页面里嵌入一个IFRAME,然后在IFRAME使用原生的POST表单提交.JQUERY的这个插件也是采用了这种方式。只不过它是动态生成的IFRAME 与表单

~~~ phpleter.com 下载的ajaxfileupload.js 缺少方法 handleError 需要自己写一下,以输出错误信息,帮助调试

~~~ajaxfileupload.js的原理实际上是:1.创建form 2.创建iframe 3.复制file控件并append到新form 4.新的form.submit到iframe 5.提取iframe输出的结果显示回主页面

相关文章:

Mybatis遍历查询 ——foreach

第一步&#xff1a; 在xxxMapper接口中添加一个函数&#xff0c;返回一个list&#xff0c;这里的参数是一个integer类型的集合 public List<Emp> findEmpByList(Param("list") List<Integer> list); 第二步&#xff1a; 在xxxMapper.xml 中添加statement…

C#中如何获取注册表信息

实现方式&#xff1a;利用Microsoft.win32类提供的注册表类访问系统注册表获取ODBC数据服务列表。 具体实现&#xff1a; Microsoft.win32提供了RegistryKey类&#xff0c;用来访问系统的注册表。 ///定义注册表子Path string strRegPath "SOFTWARE/ODBC/ODBC.INI…

用 Python 实现隐身,我可以 | 文末福利

作者 | 李秋键头图 | 下载于视觉中国出品 | AI 科技大本营&#xff08;ID:rgznai100&#xff09;引言&#xff1a;视频和图像的隐身术是指在视频或者图像中中&#xff0c;在没有任何输入遮罩的情况下&#xff0c;通过框选目标体&#xff0c;使得程序实现自动去除视频中的文本叠…

改变myeclipse北京颜色

经常用 MyEclipse 写代码&#xff0c;时间久了会觉得白色的背景颜色很刺眼&#xff0c;于是乎便想要换一种柔和些的颜色来缓解视力疲劳&#xff0c;那么怎么样来修改 MyEclipse 代码编辑区域的背景颜色呢&#xff1f; 依次展开菜单 Window >> Preferences >> Gener…

redis 代理工具Predixy安装部署

PredixyPredixy 是一款高性能全特征redis代理&#xff0c;支持redis-sentinel和redis-cluster特性高性能并轻量级支持多线程多平台支持&#xff1a;Linux、OSX、BSD、Windows(Cygwin)支持Redis Sentinel&#xff0c;可配置一组或者多组redis支持Redis Cluster支持redis阻塞型命…

超级详细的 Python 数据分析指南

来源 | 算法进阶头图 | 下载于视觉中国前言&#xff1a;数据分析是通过明确分析目的&#xff0c;梳理并确定分析逻辑&#xff0c;针对性的收集、整理数据&#xff0c;并采用统计、挖掘技术分析&#xff0c;提取有用信息和展示结论的过程&#xff0c;是数据科学领域的核心技能。…

C#实现-移位加密

/* Filename: encrypt_string.cs Author : zhanghua Date : 2005-08-11 Fuction : input a strig and encrypt a string 加密后的字符串的第一个字符是原先字符串的最后一个字符&#xff0c; 其余的每一个字符是对应的原字符串中的前一个字符的值…

oracle相关操作

查看用户系统权限&#xff1a;select * from dba_sys_privs;select * from session_privs;select * from user_sys_privs;查看用户对象权限&#xff1a;select * from dba_tab_privs;select * from all_tab_privs;select * from user_tab_privs;修改数据库密码&#xff1a;alte…

Ansible批量安装mysql数据

1.构建安装目录mkdir -p /ansible/roles/mysql/{defaults,files,handlers,meta,tasks,templates,vars}defaults 默认寻找路径tasks 存放playbooks路径files 存放文件和脚本&#xff0c;copy模块文件搜索路径templates 模版存放路径handlers notify调用部分playbook存放路径vars…

C#在客户端和服务端操作Excel文件

一、在客户端把数据导入到Excel文件步骤1、创建Excel application对象&#xff0c;打开或生成Excel文件//服务端创建StringBuilder对象System.Text.StringBuilder sbnew System .Text .StringBuilder (); //指定客户端执行语言sb.Append ("<Script LanguageVBScript&g…

oracle数据库同步交换的方法

oracle数据同步方案与实现&#xff1a;如何在两个oracle服务器之间交换数据&#xff1f;来源:无忧模板 作者:网络编辑 更新时间:2010-08-09 18:10 点击:次 方案一&#xff1a;建立两个数据库之间的DATA_LINK&#xff0c;直接将新数据写入另一数据库方案二&#xff1a;使用SQL *…

让语音助手听懂方言,这个数据集能搞定

来源 | HyperAI超神经头图 | 来源于网络 侵删方言是语音识别技术发展中必须要迈过去的坎儿&#xff0c;那么如何让模型能够听懂和理解方言呢&#xff1f;使用优质的数据集是一种的方法&#xff0c;本文将介绍一个经典的方言录音数据集 TIMIT。随着科技的成熟&#xff0c;语音识…

Django内置Admin

Django内置的Admin是对于model中对应的数据表进行增删改查提供的组件&#xff0c;使用方式有&#xff1a;依赖APP&#xff1a;django.contrib.authdjango.contrib.contenttypesdjango.contrib.messagesdjango.contrib.sessions模板的context_processors&#xff1a;django.cont…

Puppet扩展篇1-自定义fact结合ENC(hirea)的应用实践

零基础学习Puppet自动化配置管理系列文档在大量节点加入Puppet之后&#xff0c;你至少会面临两个比较大的问题&#xff1a;1、由于节点数的增多&#xff0c;site.pp文件必然会编写更多的节点条目&#xff0c;以及节点包含的类。假设你用Puppet管理500个节点&#xff0c;存在三种…

C#WinForm制作异形窗体/控件

制作异形窗体或控件的思路一般都是想办法生成一个region&#xff0c;然后设置给指定的窗口或控件。生成region的方法有很多&#xff0c;最常用的就是从一幅图片生成&#xff0c;把该图片中的透明色部分“抠”掉&#xff0c;剩下的部分作为一个region。设置窗口或控件的region可…

谷歌提出纯 MLP 构成的视觉架构,无需卷积、注意力 !

来源 | 迈微AI研习社责编 | 寇雪芹头图 | 下载于视觉中国当前&#xff0c;卷积神经网络&#xff08;CNN&#xff09;和基于自注意力的网络&#xff08;如近来大火的 ViT&#xff09;是计算机视觉领域的主流选择&#xff0c;但研究人员没有停止探索视觉网络架构的脚步。近日&…

HttpApplication事件ASP.NET页面周期

学习吧少年........................... 修改中........... 当一次请求到达IIS 1、http.sys将请求发送到指定的应用程序池。 2、应用程序池再将请求交给池中的工作进程&#xff08;w3wp.exe&#xff09;&#xff0c; 3、w3wp.exe根据请求URL的后缀&#xff0c;决定加载那个ISAP…

C#实现对象的Xml格式序列化及反序列化

要序列化的对象的类&#xff1a; [Serializable]public class Person{private string name;public string Name{get{return name;}set{namevalue;}}public string Sex;public int Age31;public Course[] Courses;public Person(){}public Person(string Name){nameName;Sex&qu…

outlook2010 打开总是提示“正在加载配置文件”

公司员工的电脑一打开OUTLOOK2010的时候&#xff0c;总是提示“正在加载配置文件”&#xff0c;要重新启动&#xff0c;还是无法打开,尝试了卸载和重装的方法也没有用.其实,只需下载一个windows search 4.0即可解决.转载于:https://blog.51cto.com/shidilun/1400227

腾讯云存储产品矩阵全面升级,发布三维生态战略

5月10日&#xff0c;腾讯云在北京举行存储产品战略发布会&#xff0c;发布了业界首款十微秒级的极速型云硬盘、业界首款突破百GB 吞吐的文件存储、以及业界首创能够10倍提升数据湖存储分析性能的对象存储三级加速器等新一代云存储产品矩阵。 同时&#xff0c;腾讯云还宣布将围…

围绕云计算 虚拟化技术又呈现新面貌

本文讲的是围绕云计算 虚拟化技术又呈现新面貌&#xff0c;【IT168 资讯】虚拟化技术的三项基本使命-即作为客户端技术&#xff0c;作为服务器技术和作为网络技术&#xff0c;如今正在围绕云计算理念相结合在一起。 起源于X86服务器的虚拟化技术已经快速扩展到存储和网络领域。…

C#字符串处理类

首先介绍一下常用的几个功能&#xff1a; Compare(str1,str2)——比较两个字符串 str1,str2的大小&#xff0c;如果大于返回正数&#xff0c;等于返回0&#xff0c;小于返回负数&#xff01; IndexOf——定位字符串中第一次出现某个给定字符串的位置PadLeft和PadRight——在字…

linux严谨的telnet搭建并用防火墙开通与禁行

今天本打算练练防火墙iptables的东西&#xff0c;本想拿telnet的23号端口练手&#xff0c;没想到在敲实验的时候遇到了些曲折&#xff0c;经过一番努力&#xff0c;把本次实验过程生成文档。实验环境&#xff1a;rhel5.6及系统盘实验目的&#xff1a;通过iptables对telnet服务2…

孩子、老人与海豚,如何用 AI 伴他们走出孤独

“万里归来颜愈少。微笑。笑时犹带岭梅香。试问岭南应不好。却道。此心安处是吾乡。”苏轼的一首《定风波》道出老人心愿&#xff0c;道出人生百态&#xff0c;也道尽世间炎凉。当你走出万里&#xff0c;无论天涯或是海角&#xff0c;每个人的身上都带着自己独有的印记。这份印…

Linux之 手动释放内存

我们在进程中要怎样去描述一个文件呢&#xff1f;我们用目录项(dentry)和索引节点(inode)。它们的定义如下: 所谓"文件", 就是按一定的形式存储在介质上的信息&#xff0c;所以一个文件其实包含了两方面的信息&#xff0c;一是存储的数据本身&#xff0c;二是有关该文…

C#操作Excel导入导出

前些日子&#xff0c;有很多朋友说需要C#导出到Excel的代码&#xff0c;现共享给大家 /// <summary> /// 读取Excel文档 /// </summary> /// <param name"Path">文件名称</param> /// <returns>返回一个数据集</returns> …

中国安全态势越来越好,专访山石网科CSO蒋东毅 | 拟合

从无序中寻找踪迹&#xff0c;从眼前事探索未来。2021 年正值黄金十年新开端&#xff0c;CSDN 以中立技术社区专业、客观的角度&#xff0c;深度探讨中国前沿 IT 技术演进&#xff0c;推出年度重磅企划栏目——「拟合」&#xff0c;通过对话企业技术高管大咖&#xff0c;跟踪报…

《大数据、小数据、无数据:网络世界的数据学术》一 导读

前  言‖ 在“大数据”风靡的当代&#xff0c;学术研究中的“小数据”依旧不容小觑。随着绝对数据量的增加&#xff0c;学者们进行个体研究的能力却不断退化。因为他们从未距离研究对象如此遥远。新工具和新视角成为学术研究的必需品。但相对于“小数据”而言&#xff0c;“大…

UIView旋转角度

2019独角兽企业重金招聘Python工程师标准>>> 最近做一个视图的旋转、放大、拖动、拉伸&#xff0c;其他的都慢慢解决了&#xff0c;就是旋转之后各种问题不好处理&#xff0c;最终归结到旋转角度的不能获取&#xff0c;纠结了好几天&#xff0c;终于找到了获取旋转角…

生成静态文件的新闻系统核心代码

在网上看了许多能生成静态页的新闻系统&#xff0c;但基于asp.net的系统极少&#xff0c;闲下时间来自己写了一个&#xff0c;发出来&#xff0c;大家一起研究&#xff0c;代码没做什么优化&#xff0c;只是实现了功能 using System;using System.Collections;using System.Com…