两种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 相关文章推荐
PHP开发不能违背的安全规则 过滤用户输入
May 01 PHP
比较好用的PHP防注入漏洞过滤函数代码
Apr 11 PHP
php接口与接口引用的深入解析
Aug 09 PHP
php提示Warning:mysql_fetch_array() expects的解决方法
Dec 16 PHP
使用PHP接受文件并获得其后缀名的方法
Aug 05 PHP
PHP中使用GD库绘制折线图 折线统计图的绘制方法
Nov 09 PHP
thinkphp实现分页显示功能
Dec 03 PHP
Laravel 5.4.36中session没有保存成功问题的解决
Feb 19 PHP
Smarty模板变量与调节器实例详解
Jul 20 PHP
PHPExcel实现的读取多工作表操作示例
Apr 14 PHP
通过PHP实现获取访问用户IP
May 09 PHP
PHP基本语法
Mar 31 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采集相关教程之一 CURL函数库
2010/02/15 PHP
PHP实现将浏览历史页面网址保存到cookie的方法
2015/01/26 PHP
浅谈PHP eval()函数定义和用法
2016/06/21 PHP
JavaScript中的私有成员
2006/09/18 Javascript
ext for eclipse插件安装方法
2008/04/27 Javascript
node.js中的fs.futimesSync方法使用说明
2014/12/17 Javascript
js+canvas绘制矩形的方法
2016/01/28 Javascript
JavaScript该如何学习 怎样轻松学习JavaScript
2017/06/12 Javascript
详解vue-resource promise兼容性问题
2017/06/20 Javascript
微信小程序新手教程之页面打开数量限制
2019/03/03 Javascript
Vue 自定义指令功能完整实例
2019/09/17 Javascript
PHP 502bad gateway原因及解决方案
2020/11/13 Javascript
在Python中使用全局日志时需要注意的问题
2015/05/06 Python
PHP网页抓取之抓取百度贴吧邮箱数据代码分享
2016/04/13 Python
Python分支结构(switch)操作简介
2018/01/17 Python
Django开发的简易留言板案例详解
2018/12/04 Python
python网络编程 使用UDP、TCP协议收发信息详解
2019/08/29 Python
Python 异常处理Ⅳ过程图解
2019/10/18 Python
Python TKinter如何自动关闭主窗口
2020/02/26 Python
Pytorch中的自动求梯度机制和Variable类实例
2020/02/29 Python
OpenCV读取与写入图片的实现
2020/10/13 Python
Python 实现3种回归模型(Linear Regression,Lasso,Ridge)的示例
2020/10/15 Python
Django web自定义通用权限控制实现方法
2020/11/24 Python
CSS3实现银灰色动画效果的导航菜单代码
2015/09/01 HTML / CSS
Merrell迈乐澳大利亚网站:购买户外登山鞋
2017/05/28 全球购物
伦敦剧院门票:From The Box Office
2018/06/30 全球购物
英国在线潜水商店:Simply Scuba
2019/03/25 全球购物
馥蕾诗美国官网:Fresh美国
2019/10/09 全球购物
描述RIP和OSPF区别以及特点
2015/01/17 面试题
自荐信如何“自荐”
2013/10/24 职场文书
房地产还款计划书
2014/01/10 职场文书
商学院大学生求职的自我评价
2014/03/12 职场文书
2014年测量员工作总结
2014/12/12 职场文书
2015年会计年终工作总结
2015/05/26 职场文书
2016年校长新年寄语
2015/08/17 职场文书
Nginx安装配置详解
2022/06/25 Servers