两种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 相关文章推荐
IIS6的PHP最佳配置方法
Mar 19 PHP
学习discuz php 引入文件的方法DISCUZ_ROOT
Jun 21 PHP
php与paypal整合方法
Nov 28 PHP
php实现统计邮件大小的方法
Aug 06 PHP
54个提高PHP程序运行效率的方法
Jul 19 PHP
在Mac OS上搭建Nginx+PHP+MySQL开发环境的教程
Dec 21 PHP
PHP设置images目录不充许http访问的方法
Nov 01 PHP
php实现的错误处理封装类实例
Jun 20 PHP
PHP微信公众号开发之微信红包实现方法分析
Jul 14 PHP
PHP单例模式模拟Java Bean实现方法示例
Dec 07 PHP
详解提高使用Java反射的效率方法
Apr 29 PHP
yii2.0框架使用 beforeAction 防非法登陆的方法分析
Sep 11 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
剧场版动画《PSYCHO-PASS 3 FIRST INSPECTOR》3月27日日本上映!
2020/03/06 日漫
咖啡豆要不要放冰箱的原因
2021/03/04 冲泡冲煮
在php中取得image按钮传递的name值
2006/10/09 PHP
透析PHP的配置文件php.ini
2006/10/09 PHP
fetchAll()与mysql_fetch_array()的区别详解
2013/06/05 PHP
PHP上传图片、删除图片简单实例
2016/11/12 PHP
php实现和c#一致的DES加密解密实例
2017/07/24 PHP
thinkPHP框架乐观锁和悲观锁实例分析
2019/10/30 PHP
基于prototype的validation.js发布2.3.4新版本,让你彻底脱离表单验证的烦恼
2006/12/06 Javascript
模仿JQuery sortable效果 代码有错但值得看看
2009/11/05 Javascript
JS中批量给元素绑定事件过程中的相关问题使用闭包解决
2013/04/15 Javascript
简单的jquery左侧导航栏和页面选中效果
2014/08/21 Javascript
javascript瀑布流式图片懒加载实例解析与优化
2016/02/23 Javascript
基于JavaScript实现轮播图代码
2016/07/14 Javascript
微信小程序 Image API实例详解
2016/09/30 Javascript
Jquery Easyui表单组件Form使用详解(30)
2016/12/19 Javascript
使用Bootstrap Tabs选项卡Ajax加载数据实现
2016/12/23 Javascript
js实现交通灯效果
2017/01/13 Javascript
详解vue2.0的Element UI的表格table列时间戳格式化
2017/06/13 Javascript
nodejs+mongodb+vue前后台配置ueditor的示例代码
2018/01/02 NodeJs
Vue写一个简单的倒计时按钮功能
2018/04/20 Javascript
TypeScript之调用栈的实现
2019/12/31 Javascript
浅谈使用nodejs搭建web服务器的过程
2020/07/20 NodeJs
vue中父子组件的参数传递和应用示例
2021/01/04 Vue.js
如何使用pyinstaller打包32位的exe程序
2019/05/26 Python
自定义Django Form中choicefield下拉菜单选取数据库内容实例
2020/03/13 Python
StubHub新加坡:购买和出售全球活动门票
2017/03/10 全球购物
退伍老兵事迹材料
2014/01/31 职场文书
机关单位人员学雷锋心得体会
2014/03/10 职场文书
捐书倡议书
2014/08/29 职场文书
优秀党员事迹材料
2014/12/18 职场文书
解放思想大讨论活动总结
2015/05/09 职场文书
围城读书笔记
2015/06/26 职场文书
《童年》读后感(三篇)
2019/08/27 职场文书
导游词之青城山景区
2019/09/27 职场文书
vue实现在data里引入相对路径
2022/06/05 Vue.js