您好,欢迎访问一九零五行业门户网

jQuery Ajax文件上传(php)

如何实现jquery的ajax文件上传,php如实文件上传.
ajax上传文件,php上传文件。
【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{ ); 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" onclick="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:/"; ); if($ok === false){ echo json_encode('file_infor'=>'上传失败'); }else{ echo json_encode('file_infor'=>'上传成功'); } ?>
另注:实际上,你可以在一个页面里嵌入一个iframe,然后在iframe使用原生的post表单提交.jquery的这个插件也是采用了这种方式。只不过它是动态生成的iframe 与表单
更多jquery ajax文件上传(php)。
其它类似信息

推荐信息