php中上传文件的方法有多少种
一、传统的php写的上传类。
写一个php的上传类,这个方法用到的知识全部是php的,而且技术的难点也不多。
form method="post" action="upload.php" enctype="multipart/form-data"
table border=0 cellspacing=0 cellpadding=0 align=center width="100%"
input type="hidden" name="MAX_FILE_SIZE" value="2000000"//隐藏域。这里name必须设置成MAX_FILE_SIZE,其值就是上传文件的最大长度,单位是B,这里我限制成2M
input name="file" type="file" value="浏览"
input type="submit" value="上传" name="B1"
/table
/form
服务端利用php的$_FILES['file']['name']来获取文件后缀名,具体的代码自己查找资料看看,这里就不多说了。
总结;这个方法可以用来上传小于2M的文件或者是图片,基本的功能可以实现。
二、利用uploadify插件
这个是利用jQuery的上传插件,上传可以带进度条,容易配置。
总结:可以上传一些大文件,和图片,而且带进度条,可以多文件上传,在WEB中会经常用。
三、利用百度的webupload
WebUploader 是由 Baidu FEX 团队开发的一款以 HTML5 为主,FLASH 为辅的现代文件上传组件。在现代的浏览器里面能充分发挥 HTML5 的优势,同时又不摒弃主流IE浏览器,沿用原来的 FLASH 运行时,兼容 IE6+,iOS 6+, Android 4+。采用大文件分片并发上传,极大的提高了文件上传效率。
四、swfupload的插件
这是一个jquery的上传插件,功能也非常强大,开发也比较容易,网上有很多的资料,可以自行查找。
PHP文件上传代码用法
php文件上传代码编写过程
先判断是否上传文件
如果有再来判断上传中是否出错
如果出错 则提示出错信息
如查没出错 再判断文件类型
如果类型符合条件 再判断指定目录中有没有存在该文件
如果没有就把该文件移至指定目录
在php中上传文件必须知道的几个东西
$_FILES[ myfile ][ name ] 是指被上传文件的名称
$_FILES[ myfile ][ type ] 是指被上传文件的类型
$_FILES[ myfile ][ size ] 是指被上传文件的大小 单位为字节(B)
$_FILES[ myfile ][ tmp_name ] 是指被上传文件存在服务器中的临时副本文件名称 文件被移动到指定目录后临文件将被自动消毁
$_FILES[ myfile ]["error"] 是指由文件上传中有可能出现的错误的状态码 关于各状态含义后在会说明
先来看一下HTML部分
代码如下 复制代码
?form action="upload php" method="post" enctype="multipart/form data" 上传 input type=file name=myfile / input type=submit name=submit value="上传" / /form
说明
form标答的action="upload php"是指点击这个form中的submit的时候 这个上传命令会被发送到这个叫 upload php的页面去处理 method="post"是指以post方式去送 enctype="multipart/form data"属性规定了在提交这个表单时要使用哪种内容类型 在表单需要二进制数据时 比如文件内容 请使用"multipart/form data" 如果要上传文件 这个属性是必要的 input中的type="file"时 规定了应该把输入作为文件来处理 并且在input后面会有一个浏览的按钮
我们再来看一个PHP处理页面 upload php
代码如下 复制代码
?php if($_FILES[ myfile ][ name ] != ) { if($_FILES[ myfile ][ error ] ) { echo "错误状态 " $_FILES[ myfile ][ error ]; } else { move_uploaded_file($_FILES[ myfile ][ tmp_name ] "uploads/" $FILES[ myfile ][ name ]); echo "scriptalert(上传成功!);/script"; } } else{ echo "scriptalert(请上传文件!);/script"; } ?
上面超级简单 我们现在来升级一下
upload php
代码如下 复制代码
!DOCTYPE HTML PUBLIC " //W C//DTD HTML Transitional//EN" head titleddd/title meta equiv="content type" content="text/; charset=UTF " /head body ! 文件上传要注意: 要有enctyp method="post" form enctype="multipart/form data" action="uploadProcess php" method="post" table trtd请填写用户名/tdtdinput type=text name=username/td/tr trtd请简单介绍文件/tdtdtextarea rows=" " cols=" " name=fileintro class="page_speeder_734321457"/textarea/td/tr trtd请上传你的文件/tdtdinput type=file name=myfile/td/tr trtd colspan=" "input type=submit value="上传"td/tr /table /form /body /
uploadProcess php
代码如下 复制代码
?php
//接收 $username=$_POST@[ username ]; $fileintro=$_POST@[ fileintro ]; //echo $username $fileintro; //获取文件信息 /* echo "pre"; print_r($_FILES); echo "/pre"; */ //获取文件的大小 $file_size=$_FILES[ myfile ][ size ]; if($file_size * * ){ echo "script type= text/javascript window alert( 文件不能大于 M )/script"; exit(); }
//获取文件类型 $file_type=$_FILES[ myfile ][ type ]; if($file_type!="image/jpeg" $file_type!="image/pjpeg"){ echo "文件类型只能是 jpg 格式"; exit(); }
//判断上传是否OK if(is_uploaded_file($_FILES[ myfile ][ tmp_name ])){ //得到上传的文件 转存到你希望的目录 $upload_file=$_FILES[ myfile ][ tmp_name ]; //防止图片覆盖问题 为每个用户建立一个文件夹 $user_path=$_SERVER[ DOCUMENT_ROOT ] "/file/up/" $username; if(!file_exists($user_path)){ mkdir ($user_path); }
//$move_to_file=$user_path "/" $_FILES[ myfile ][ name ]; //防止用户上传用户名相同的问题 $file_true_name=$_FILES[ myfile ][ name ]; $move_to_file=$user_path "/" time() rand( ) substr($file_true_name strripos($file_true_name " "));
//echo $upload_file $move_to_file; //中文要转码 if(move_uploaded_file($upload_file iconv("utf " "gb " "$move_to_file"))){ echo $_FILES[ myfile ][ name ] "上传成功"; }else{ echo "上传失败"; } }else{ echo "上传失败"; }
?
注意:
我举个例子大家就知道 比如一个图片文件 pic jpg 我们用 strrchr处理 strrchr(pic jpg ) 它将返回 jpg 明白了吗?该函数返回指定字符在该字符串最后出现的位置后的字符 配合 substr() 我们就可以取到jpg 这样我们就得到了文件的后缀名 来判断上传文件是否符合指定格式 本程序把指定的格式放在一个数组中 实际使用时可根据需要添加
lishixinzhi/Article/program/PHP/201311/20924
php如何实现文件上传
所谓上传就是把文件从你电脑本地复制到你的项目指定文件夹下。
但这有个中间过程,就是复制到系统指定的临时文件夹生成临时文件。
然后将临时文件复制到你指定的文件夹下。
剩下的就是各种验证了。
给你个图片上传方法
//上传一张图片
$pic = $_FILES['pic'];
function upload($pic){
$tmp_name = $pic['tmp_name'];
$name = $pic['name'];
$type = $pic['type'];
$size = $pic['size'];
if(!is_uploaded_file($tmp_name)) exit('不是上传文件');
//判断是否是图片
$mine = array('image/png','image/jpg','image/gif','image/jpeg');
if(!in_array($type,$mine)) exit('图片格式不正确');
//判断是否有错误码
$error = $pic['error'];
switch ($error) {
case 1:
exit("超出上传文件的最大限制");
case 2:
exit("超出了指定的文件大小");
case 3:
exit("只有部分文件被上传");
case 4:
exit("文件没有被上传");
case 6:
exit("找不到临时文件夹");
case 7:
exit("文件写入失败");
}
echo "================br/";
echo "上传文件名称是:".$name."br/";
echo "上传文件类型是:".$type."br/";
echo "上传文件大小是:".$size."br/";
echo "上传后系统返回的值是:".$error."br/";
echo "上传文件的临时存放路径是:".$tmp_name."br/";
echo"开始移动临时文件".'br';
$des_name = 'up/'.mt_rand().time().'.'.basename($type);
$res = move_uploaded_file($tmp_name, $des_name);
if($res){
echo "================br/";
echo "上传图片成功".'br';
}
}