PHP文件上传、客户端和服务器端加限制、抓取错误信息、完整步骤解析


Posted in PHP onJanuary 12, 2017

文件上传分为两个部分,HTML显示部分和PHP处理部分,HTML部分主要是让用户来选择所要上传的文件,然后通过PHP中的$_FILES,我们可以把文件上传到服务器的指定目录。

1.客户端页面

   客户端的配置

    1.表单页面

    2.表单发送方式为post

    3.表单form中添加enctype="multipart/form-data"

<body>
 <form action="doaction.php" method="post" enctype="multipart/form-data">
 <input type="file" name="myfile">
 <input type="submit" value="上传">
 </form>
</body>

2.处理页面doaction

$_FILES:文件上传变量

print_r($_FILES);

$_FILES:保存着上传文件的信息

1.name:上传文件的名称

2.type:上传文件的MIME类型

3.tmp_name:上传到服务器上的临时文件名

4.size:上传文件的大小

5.error:上传文件的错误号

$filename=$_FILES['myfile']['name'];
$type=$_FILES['myfile']['type'];
$tmp_name=$_FILES['myfile']['tmp_name'];
$size=$_FILES['myfile']['size'];
$error=$_FILES['myfile']['error'];

将服务器上的临时文件移动到指定文件夹

1.move_uploaded_file(临时文件名,‘文件夹名'.$filename);   将服务器上的临时文件移动到指定文件夹,叫什么名字($filename),移动成功返回true,移动失败返回false。

move_uploaded_file($tmp_name,"wenjian/".$filename);

2.copy("临时文件名","文件名".$filename)  将服务器上的临时文件拷贝到指定文件夹

文件上传配置

file_uploads = on,支持HTTP上传
upload_tmp_dir= ,临时文件保存的目录
upload_max_filesize=2M,允许上传文件的最大值
max_file_uploads=20,允许一次上传的最大文件数
post_max_size=8M,post方式发送数据的最大值

3.错误信息处理

上传文件失败时,判断一下错误号,只有为0或者UPLOAD_ERR_OK,才没有错误发生,上传成功

下面是抓取错误

if($error==UPLOAD_ERR_OK)
{
  if(move_uploaded_file($tmp_name,"wenjian/".$filename))
  {
    echo "文件".$filename."上传成功";
    }else
    {
      echo "文件".$filename."上传失败";
      }
  }
  else
  {
    //匹配错误信息
    switch($error)
    {
      case 1:
      echo "上传文件超过了PHP配置文件中upload_max_filesize选项的值";
      break;
      case 2:
      echo "超过了表单MAX_FILE_SIZE的限制大小";
      break;
      case 3:
      echo "文件部分被上传";
      break;
      case 4:
      echo "没有选择上传文件";
      break;
      case 6:
      echo "没有找到临时目录";
      break;
      case 7:
      case 8:
      echo "系统错误";
      break;
      }
    }
?>

4.上传文件限制

《客户端限制:》

通过表单隐藏域限制上传文件的最大值

<input type="hidden" name="MAX_FILE_SIZE" value="字节数">

通过accept属性限制上传文件的类型

<input type="file" name="myfile" accept="文件的MIME类型">

《服务器端限制》

1.限制上传文件大小

2.限制上传文件类型

3.检测是否为真实图片类型

4.检测是否为HTTP POST方式上传

5.判断服务器上存储的文件夹在不在

6.防止重名产生覆盖

<?php
$fileinfo=$_FILES["myfile"];
$maxsize=2097152;     //写最大的字节数,自己算
$allowext=array('jpeg','jpg','pnd','gif','wbmp');  //定义一下允许的上传文件类型
//1.判断错误号
if($fileinfo['error']==0)
{
  //1.判断上传文件大小
if($fileinfo['size']>$maxsize)
  {
    exit('上传文件过大');
    }
 //2.判断上传文件类型是不是在规定类型中
$ext=strtolower(end(explode(',',$fileinfo['name'])));//截取上传文件扩展名
  if(!in_array($ext,$allowext))  // 判断上传文件的扩展名是不是在定义类型中
  {
     exit('非法文件类型');  
    }
 //3.判断文件是否是通过HTTP POST方式上传上来的
if(!is_uploaded_file($fileinfo['tmp_name']))
  {
    exit('文件不是通过HTTP POST方式上传上来的');
    }
 //4.检测是否为真实的图片类型,而不是认为改动的
$flag=true;
  if($flag)
  {
    if(!getimagesize($fileinfo['tmp_name']))
    {
      echo "不是真实的图片类型";
      }
    }
  $path='uploads'; //服务器上存储文件的文件名
//5.判断服务器上存储的文件夹在不在
if(!file_exists($path))
  {
    mkdir($path,0777,true);//不存在就创建一个目录
    chmod($path,0777);//加一个权限
    }
 //6.确保文件名唯一,防止重名产生覆盖
$uniname=md5(uniqid(microtime(true),true)).'.'.$ext;  //通过MD5加密等措施给文件名取名
  $destination=$path.'/'.$uniname;
  if(move_uploaded_file($fileinfo['tmp_name'],$destination)) //上传文件
  {
    echo "文件上传成功";
    }else
    {
      echo "文件上传失败";
      }
  }else
  {
//匹配错误信息
  switch($error)
    {
      case 1:
      echo "上传文件超过了PHP配置文件中upload_max_filesize选项的值";
      break;
      case 2:
      echo "超过了表单MAX_FILE_SIZE的限制大小";
      break;
      case 3:
      echo "文件部分被上传";
      break;
      case 4:
      echo "没有选择上传文件";
      break;
      case 6:
      echo "没有找到临时目录";
      break;
      case 7:
      case 8:
      echo "系统错误";
      break;
      }
    }
?>

5.完整的上传文件步骤

第一步:表单页内容

<body>
 <form action="doaction.php" method="post" enctype="multipart/form-data">
//通过表单隐藏域限制上传文件的最大值
<input type="hidden" name="MAX_FILE_SIZE" value="字节数">
//通过accept属性限制上传文件的类型
<input type="file" name="myfile" accept="文件的MIME类型">
</form>
 </body>

第二步:处理界面。定义变量

<?php
//$_FILES:文件上传变量
print_r($_FILES);
//$_FILES:保存着上传文件的信息
/*1.name:上传文件的名称
2.type:上传文件的MIME类型
3.tmp_name:上传到服务器上的临时文件名
4.size:上传文件的大小
5.error:上传文件的错误号*/
$filename=$_FILES['myfile']['name'];
$type=$_FILES['myfile']['type'];
$tmp_name=$_FILES['myfile']['tmp_name'];
$size=$_FILES['myfile']['size'];
$error=$_FILES['myfile']['error'];

 第三步:处理页面上服务器加限制和输出错误信息

1.限制上传文件大小

2.限制上传文件类型

3.检测是否为真实图片类型

4.检测是否为HTTP POST方式上传

5.判断服务器上存储的文件夹在不在

6.防止重名产生覆盖 

//服务器端限制
<?php
$fileinfo=$_FILES["myfile"];
$maxsize=2097152;     //写最大的字节数,自己算
$allowext=array('jpeg','jpg','pnd','gif','wbmp');  //定义一下允许的上传文件类型
//1.判断错误号
if($fileinfo['error']==0)
{
  //1.判断上传文件大小
if($fileinfo['size']>$maxsize)
  {
    exit('上传文件过大');
    }
 //2.判断上传文件类型是不是在规定类型中
$ext=strtolower(end(explode(',',$fileinfo['name'])));//截取上传文件扩展名
  if(!in_array($ext,$allowext))  // 判断上传文件的扩展名是不是在定义类型中
  {
     exit('非法文件类型');  
    }
 //3.判断文件是否是通过HTTP POST方式上传上来的
if(!is_uploaded_file($fileinfo['tmp_name']))
  {
    exit('文件不是通过HTTP POST方式上传上来的');
    }
 //4.检测是否为真实的图片类型,而不是认为改动的
$flag=true;
  if($flag)
  {
    if(!getimagesize($fileinfo['tmp_name']))
    {
      echo "不是真实的图片类型";
      }
    }
  $path='uploads'; //服务器上存储文件的文件名
//5.判断服务器上存储的文件夹在不在
if(!file_exists($path))
  {
    mkdir($path,0777,true);//不存在就创建一个目录
    chmod($path,0777);//加一个权限
    }
 //6.确保文件名唯一,防止重名产生覆盖
$uniname=md5(uniqid(microtime(true),true)).'.'.$ext;  //通过MD5加密等措施给文件名取名
  $destination=$path.'/'.$uniname;
  $destination=inocv("UTF-8","gb2312",$destination); //如果上传的文件名中有汉字,需要转码一下,用inocv函数,把utf-8转为gb2312.
  if(move_uploaded_file($fileinfo['tmp_name'],$destination)) //上传文件
  {
    echo "文件上传成功";
    }else
    {
      echo "文件上传失败";
      }
  }else
  {

第四步:匹配错误信息

switch($error)
    {
      case 1:
      echo "上传文件超过了PHP配置文件中upload_max_filesize选项的值";
      break;
      case 2:
      echo "超过了表单MAX_FILE_SIZE的限制大小";
      break;
      case 3:
      echo "文件部分被上传";
      break;
      case 4:
      echo "没有选择上传文件";
      break;
      case 6:
      echo "没有找到临时目录";
      break;
      case 7:
      case 8:
      echo "系统错误";
      break;
      }
    }
?>

以上所述是小编给大家介绍的PHP文件上传、客户端和服务器端加限制、抓取错误信息、完整步骤,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

PHP 相关文章推荐
php完全过滤HTML,JS,CSS等标签
Jan 16 PHP
洪恩在线成语词典小偷程序php版
Apr 20 PHP
PHP中数字检测is_numeric与ctype_digit的区别介绍
Oct 04 PHP
PHP实例分享判断客户端是否使用代理服务器及其匿名级别
Jun 04 PHP
php采用file_get_contents代替使用curl实例
Nov 07 PHP
php中动态调用函数的方法
Mar 16 PHP
学习php设计模式 php实现工厂模式(factory)
Dec 07 PHP
thinkphp3.2点击刷新生成验证码
Feb 16 PHP
thinkphp中的url跳转用法分析
Jul 12 PHP
解析PHP之提取多维数组指定列的方法
Jan 03 PHP
Thinkphp3.2实用篇之计算型验证码示例
Feb 09 PHP
Laravel框架Eloquent ORM删除数据操作示例
Dec 03 PHP
php中分页及SqlHelper类用法实例
Jan 12 #PHP
PHP生成图片验证码功能示例
Jan 12 #PHP
PHP中字符串长度的截取用法示例
Jan 12 #PHP
PHP实现二维数组去重功能示例
Jan 12 #PHP
PHP生成图片缩略图类示例
Jan 12 #PHP
php+redis实现多台服务器内网存储session并读取示例
Jan 12 #PHP
[原创]PHPCMS遭遇会员投稿审核无效的解决方法
Jan 11 #PHP
You might like
php 深入理解strtotime函数的使用详解
2013/05/23 PHP
php生成数组的使用示例 php全组合算法
2014/01/16 PHP
javascript语句中的CDATA标签的意义
2007/05/09 Javascript
Prototype ObjectRange对象学习
2009/07/19 Javascript
在多个页面使用同一个HTML片段《续》
2011/03/04 Javascript
javascript(js)的小数点乘法除法问题详解
2014/03/07 Javascript
Egret引擎开发指南之发布项目
2014/09/03 Javascript
js交换排序 冒泡排序算法(Javascript版)
2014/10/04 Javascript
编写简单的jQuery提示插件
2014/12/21 Javascript
兼容各大浏览器的JavaScript阻止事件冒泡代码
2015/07/09 Javascript
JavaScript实现定时隐藏与显示图片的方法
2015/08/06 Javascript
Jquery实现弹性滑块滑动选择数值插件
2015/08/08 Javascript
基于javascript实现文字无缝滚动效果
2016/03/22 Javascript
jQuery dataTables与jQuery UI 对话框dialog的使用教程
2016/09/02 Javascript
jQuery图片拖动组件Dropzone用法示例
2017/01/17 Javascript
js cookie实现记住密码功能
2017/01/17 Javascript
轻松搞定jQuery+JSONP跨域请求的解决方案
2018/03/06 jQuery
Vue实现push数组并删除的例子
2019/11/01 Javascript
用python实现的去除win下文本文件头部BOM的代码
2013/02/10 Python
分析python服务器拒绝服务攻击代码
2014/01/16 Python
python实现斐波那契递归函数的方法
2014/09/08 Python
Python实现建立SSH连接的方法
2015/06/03 Python
Django+Ajax+jQuery实现网页动态更新的实例
2018/05/28 Python
Python读取excel中的图片完美解决方法
2018/07/27 Python
python进程池实现的多进程文件夹copy器完整示例
2019/11/27 Python
详解python方法之绑定方法与非绑定方法
2020/08/17 Python
Python实现给PDF添加水印的方法
2021/01/25 Python
HTML5新控件之日期和时间选择输入的实现代码
2018/09/13 HTML / CSS
Alexandre Birman美国官网:亚历山大·伯曼
2019/10/30 全球购物
美术毕业生求职信
2014/02/25 职场文书
公司担保书格式范文
2014/05/12 职场文书
奥巴马英文演讲稿
2014/05/15 职场文书
教师专业自荐信
2014/05/31 职场文书
2015年安全生产月活动总结
2015/03/26 职场文书
单位综合评价意见
2015/06/05 职场文书
python APScheduler执行定时任务介绍
2022/04/19 Python