两种php实现图片上传的方法


Posted in PHP onJanuary 22, 2016

图片上传在项目中经常用到,几乎没有任何一个项目可以脱离图片或者是文件上传。本篇我在这向大家介绍两种常规的上传方式。(注:在这里我们仅仅是对功能的实现,不去做过多的前端的样式)
一、利用form表单上传
此种方式是最原始的上传方式,前端就是简单的form表单,后端我们有PHP处理传输过来的文件。
首先看前端的代码 upload.html

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

然后新建php文件 handle.php 代码如下

$file = $_FILES['file'];//得到传输的数据
//得到文件名称
$name = $file['name'];
$type = strtolower(substr($name,strrpos($name,'.')+1)); //得到文件类型,并且都转化成小写
$allow_type = array('jpg','jpeg','gif','png'); //定义允许上传的类型
//判断文件类型是否被允许上传
if(!in_array($type, $allow_type)){
  //如果不被允许,则直接停止程序运行
  return ;
}
//判断是否是通过HTTP POST上传的
if(!is_uploaded_file($file['tmp_name'])){
  //如果不是通过HTTP POST上传的
  return ;
}
$upload_path = "D:/now/"; //上传文件的存放路径
//开始移动文件到相应的文件夹
if(move_uploaded_file($file['tmp_name'],$upload_path.$file['name'])){
  echo "Successfully!";
}else{
  echo "Failed!";
}

当然,此php处理代码不是很完善,其中对错误的情况没有进行处理,然而使用php处理上传文件的原理就是这样的,大家可以在此基础上进行优化,使其更加完善。
二、利用uploadify实现无刷新并且带进度条的上传
首先下载uploadify插件,保存在项目中的某个文件夹下面,然后引入三个文件

<link href="js/uploadify/uploadify.css" rel="stylesheet" type="text/css" />
<script type="text/javascript" src="js/uploadify/jquery.min.1.7.js"></script>
<script type="text/javascript" src=js/uploadify/jquery.uploadify.min.js"></script>

然后引用以下代码

<script type="text/javascript">
    $(function(){
      $(".uploadbutton").each(function(){
       
        bidtype="上传";
        $(this).uploadify({
          swf: 'js/uploadify/uploadify.swf',
          uploader: "handle.php",  //处理上传的php文件或者方法
          multi: true,  //是否开启一次性上传多个文件
          queueSizeLimit:20,  //最大允许上传的文件数量
          buttonText: bidtype,        //按钮文字
          height: 34,               //按钮高度
          width: 82,               //按钮宽度
          auto:false,  //选择完图片以后是否自动上传
          method:'post',
          fileTypeExts: "*.jpg;*.png;*.gif;*.jpeg;",      //允许的文件类型
          fileTypeDesc: "请选择图片文件",      //文件说明
          postData:{},
          formData: { "imgType": "normal","timestamp":"asdfsa","token":"48f262516b3912a060d21ef6af564668" }, //提交给服务器端的参数
          onUploadSuccess: function (file, data, response) {  //一个文件上传成功后的响应事件处理
            var data = $.parseJSON(data);
          }
        });
      })
    });
  </script>
<body>
  <span id="commercial_upload" class="uploadbutton"></span>
</body>

样式如下

两种php实现图片上传的方法

当然此按钮的样式我改动过,大家可以根据自己的需要修改样式文件,改变此按钮的样式
同样的php代码 handle.php

$file = $_FILES['Filedata'];//得到传输的数据
//得到文件名称
$name = $file['name'];
$type = strtolower(substr($name,strrpos($name,'.')+1)); //得到文件类型,并且都转化成小写
$allow_type = array('jpg','jpeg','gif','png'); //定义允许上传的类型
//判断文件类型是否被允许上传
if(!in_array($type, $allow_type)){
  //如果不被允许,则直接停止程序运行
  return ;
}
//判断是否是通过HTTP POST上传的
if(!is_uploaded_file($file['tmp_name'])){
  //如果不是通过HTTP POST上传的
  return ;
}
$upload_path = "D:/now/"; //上传文件的存放路径
//开始移动文件到相应的文件夹
if(move_uploaded_file($file['tmp_name'],$upload_path.$file['name'])){
  echo "Successfully!";
}else{
  echo "Failed!";
}

以上两种方式上传可以说PHP处理的原理是相同的,只是前台显示的样式不同,第二种方式是无刷新,并且带有返回值,可以方便我们做其它的处理。虽然常用,但是总归会受限制,使用起来不是很灵活。
随着html5的发展的越来越成熟,我们可以利用h5中的一些方法实现上传功能,此时后台PHP的处理代码完全不同于以上两种方式,并且使用起来很灵活。由于篇幅限制,本篇我不向大家介绍这种方式,有兴趣的可以参考php+html5实现无刷新图片上传教程,希望大家会喜欢。

PHP 相关文章推荐
Gregarius中文日期格式问题解决办法
Apr 22 PHP
UCenter Home二次开发指南
May 28 PHP
php array_map()数组函数使用说明
Jul 12 PHP
php 多关键字 高亮显示实现代码
Apr 23 PHP
国外十大最流行的PHP框架排名
Jul 04 PHP
php json_encode值中大括号与花括号区别
Sep 30 PHP
PHP5.5和之前的版本empty函数的不同之处
Jun 13 PHP
windows7下安装php的imagick和imagemagick扩展教程
Jul 04 PHP
Smarty简单生成表单元素的方法示例
May 23 PHP
老生常谈PHP 文件写入和读取(必看篇)
May 22 PHP
PHP receiveMail实现收邮件功能
Apr 25 PHP
PHP配合fiddler抓包抓取微信指数小程序数据的实现方法分析
Jan 02 PHP
php+html5实现无刷新图片上传教程
Jan 22 #PHP
PHP中的随机性 你觉得自己幸运吗?
Jan 22 #PHP
PHP中的session安全吗?
Jan 22 #PHP
PHP下载远程图片并保存到本地方法总结
Jan 22 #PHP
PHP连接MYSQL数据库实例代码
Jan 20 #PHP
CodeIgniter配置之autoload.php自动加载用法分析
Jan 20 #PHP
Twig模板引擎用法入门教程
Jan 20 #PHP
You might like
php Notice: Undefined index 错误提示解决方法
2010/08/29 PHP
用 Composer构建自己的 PHP 框架之构建路由
2014/10/30 PHP
php查询mysql数据库并将结果保存到数组的方法
2015/03/18 PHP
PHP封装的数据库保存session功能类
2016/07/11 PHP
php实现姓名根据首字母排序的类与方法(实例代码)
2018/05/16 PHP
ExtJS TabPanel beforeremove beforeclose使用说明
2010/03/31 Javascript
jquery maxlength使用说明
2011/09/09 Javascript
jquery 页眉单行信息滚动显示实现思路及代码
2014/06/26 Javascript
JavaScript修改浏览器tab标题小技巧
2015/01/06 Javascript
jQuery+AJAX实现网页无刷新上传
2015/02/22 Javascript
javascript类型系统——日期Date对象全面了解
2016/07/13 Javascript
vue实现的组件兄弟间通信功能示例
2018/12/04 Javascript
使用p5.js实现动态GIF图片临摹重现
2019/10/23 Javascript
vue中动态select的使用方法示例
2019/10/28 Javascript
[07:31]DOTA2卡尔工作室 英雄介绍主宰篇
2013/06/25 DOTA
python使用点操作符访问字典(dict)数据的方法
2015/03/16 Python
在Python中处理XML的教程
2015/04/29 Python
python字符串编码识别模块chardet简单应用
2015/06/15 Python
python实现井字棋游戏
2020/03/30 Python
解决Scrapy安装错误:Microsoft Visual C++ 14.0 is required...
2017/10/01 Python
python保存二维数组到txt文件中的方法
2018/11/15 Python
Flask框架工厂函数用法实例分析
2019/05/25 Python
Python线程threading模块用法详解
2020/02/26 Python
Python抓包程序mitmproxy安装和使用过程图解
2020/03/02 Python
django模板获取list中指定索引的值方式
2020/05/14 Python
python实现图像高斯金字塔的示例代码
2020/12/11 Python
为2021年的第一场雪锦上添花:用matplotlib绘制雪花和雪景
2021/01/05 Python
迪卡侬印度官网:购买所有体育用品
2017/06/24 全球购物
为什么要用EJB
2014/04/17 面试题
Prototype如何实现页面局部定时刷新
2013/08/06 面试题
学习雷锋精神演讲稿
2014/05/10 职场文书
学生党员一帮一活动总结
2014/07/08 职场文书
银行转正自我鉴定
2014/09/29 职场文书
派出所副所长四风问题个人整改措施思想汇报
2014/10/13 职场文书
员工辞职信怎么写
2015/02/27 职场文书
幼儿园开学家长寄语(2016春季)
2015/12/03 职场文书