如何实现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 = ‘文件只有部分被上传’;










