• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >JavaScript > PHP实现本地图片上传和验证功能

PHP实现本地图片上传和验证功能

作者:rain_web 字体:[增加 减小] 来源:互联网 时间:2017-05-11

rain_web通过本文主要向大家介绍了php分享功能实现,php实现购物车功能,php实现搜索功能,php实现下载功能,php实现点赞功能等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

今天研究了一下PHP的FILES函数,使用PHP实现本地图片的上传,验证文件是否为图片,并将图片保存在指定目录下,实现游览图片的功能,感觉还是很好玩的,一共有两个PHP页面,一个作为前台的上传和图片展示,另一个用来处理保存图片,代码里做了很详细的注释,并将FILES函数的语法,error报错类型写了出来,还有一些注意事项。

FILES函数

1、$_FILES[‘myFile'][‘name'] 客户端文件的原名称
2、$_FILES[‘myFile'][‘type'] 文件的 MIME类型,需要浏览器提供该信息的支持,例如”image/gif”
3、$_FILES[‘myFile'][‘size'] 已上传文件的大小,单位为字节
4、$_FILES[‘myFile'][‘tmp_name'] 文件被上传后在服务端储存的临时文件名,一般是系统默认,可以在php.ini的upload_tmp_dir指定

关于FILES中error报错类型及其注意:

过滤错误号

0: 没有错误发生,文件上传成功
1: 上传的文件超过了 php.ini 中 upload_max_filesize选项限制的值
2: 上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值
3: 文件只有部分被上传
4: 没有文件被上传
5: 上传文件大小为0

注意:

1、文件被上传结束后,默认地被存储在了临时目录中,这时必须将它从临时目录中删除或移动到其它地方,如果没有,则会被删除。也就是不管是否上传成功,脚本执行完后临时目录里的文件肯定会被删除。所以在删除之前要用PHP的copy() 函数将它复制到其它位置,此时,才算完成了上传文件过程。
2、在 PHP 4.1.0 版本以前该数组的名称为$HTTP_POST_FILES,它并不像_FILES 一样是自动全局变量。PHP 3 不支持HTTP_POST_FILES数组。
3、用form上传文件时,一定要加上属性内容enctype=”multipart/form-data”,否则用$_FILES[filename]获取文件信息时会报异常。

以下是代码

index.php

  <?php
  header("Content-Type:text/html;charset=utf-8");
  ?>
  <title>PHP实现图片的上传和验证</title>
  <style>
  table{text-align:center;}
  </style>
  <div align="center">
  <h1>上传功能</h1>
  <form action="index_ok.php" method="post" enctype="multipart/form-data">
    上传图片:<input type="file" name="pic">
    <input type="submit" name="sub" value="上传">
  </form>
  <table width="500">
    <tr bgcolor="#cccccc">
    <th>序号</th>
    <th>图片</th>
    <th>添加时间</th>
    <th>操作</th>
    </tr>
    <?php
    //1 打开目录
    $dir=opendir("./uploads");
    //2 遍历目录,输出里面的图片
    $i=0;
    while($f=readdir($dir)){
      $i++;
      //读取目录中的文件,模拟数据库操作
      if($f!="." && $f!=".."){
        $filename="./uploads/$f";
        echo "<tr>";
        echo "<td>{$i}</td>";
        echo "<td><img src='./uploads/{$f}' width='80' height='60'></td>";
        echo "<td>".date("Y-m-d",filectime($filename))."</td>";
        echo "<td><a href='./uploads/{$f}'>查看</a></td>";
        echo "</tr>";
      }
    }
    //3 关闭目录
    closedir($dir);
    ?>
  <tr bgcolor="#cccccc"><td colspan="4"> </td></tr>
  </table>
  </div>
</div>

upload.php

  <?php
  header("Content-Type:text/html;charset=utf-8");
    if($_FILES['pic']['error']>0){
      echo $_FILES['pic']['error'];
      echo "上传文件错误!";
      echo '<meta http-equiv="refresh" content="3;url=index.php">'; //自动跳转回index文件
    }else{
      //开始获取上传文件的信息
      $file=$_FILES['pic'];
      //var_dump($file);打印文件里的全部信息
      //name:上传文件名
      //type:上传文件的类型
      //tmp_name:上传成功后的临时文件
      //size:上传文件的大小
      //error:上传文件的错误信息
      $uploaddir="./uploads/"; //选择要上传的文件存放目录
      //$uploadfile=$uploaddir.basename($file['name']);//获得上传文件的名称
      //解析文件的名字
      $fileinfo=pathinfo($file['name']);
  //   echo $fileinfo['extension']; 获取文件的类型
      do{
        $newfile=date("YmdHis").rand(1000,9999).".".$fileinfo['extension'];//更改文件的名字,获取一个新的名字
      }while(file_exists($uploaddir.$newfile));

      //上传文件的类型限制
      if (!(($file['type'] == "image/gif")||($file['type'] == "image/jpeg")||($file['type'] == "image/pjpeg"))){
        die("文件类型错误!");
        echo '<meta http-equiv="refresh" content="3;url=index.php">';
      }
      //上传文件的大小限制
      if($file['size'] > 2*1024*1024){
        die("上传文件超过2MB!");
        echo '<meta http-equiv="refresh" content="3;url=index.php">';
      }
      //开始上传文件
      if (is_uploaded_file($file['tmp_name'])) {
        if (move_uploaded_file($file['tmp_name'], $uploaddir.$newfile)) {
          echo "上传成功!";
          echo '<meta http-equiv="refresh" content="3;url=index.php">';//自动跳转回index文件
        } else {
          echo "上传失败,请稍等!";
          echo '<meta http-equiv="refresh" content="3;url=index.php">'; //自动跳转回index文件
        }
      }

    }
  ?>
</div>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • PHP实现本地图片上传和验证功能

相关文章

  • 2017-05-11解析jquery easyui tree异步加载子节点问题
  • 2017-05-11详解微信开发中snsapi_base和snsapi_userinfo及静默授权的实现
  • 2017-05-11js图片延迟加载(Lazyload)三种实现方式
  • 2017-05-11canvas知识总结
  • 2017-05-11手机端js和html5刮刮卡效果
  • 2017-05-11微信小程序 仿美团分类菜单 swiper分类菜单
  • 2017-08-31div 跟着鼠标移动
  • 2017-05-11jQuery插件echarts去掉垂直网格线用法示例
  • 2017-05-11Bootstrap的popover(弹出框)2秒后定时消失的实现代码
  • 2017-05-11JS实现加载和读取XML文件的方法详解

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 用file标签实现多图文件上传预览
    • easyui 中的datagrid跨页勾选问题的实现方法
    • 微信小程序 视图容器组件的详解及实例代码
    • js 随机数
    • 深入理解node.js之path模块
    • jQuery向webApi提交post json数据
    • jQuery is not defined 错误原因与解决方法小结
    • HTML中使背景图片自适应浏览器大小实例详解
    • node.js+jQuery实现用户登录注册AJAX交互
    • jquery.cookie.js的介绍与使用方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有