这篇文章主要为大家详细介绍了php文件上传、下载和删除示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

php文件上传、下载和删除示例大体思路如下,具体内容如下

一.文件上传

1.把上传文件的区域做出来

p1

2.把显示文件的区域做出来

p2

3.提交表单,上传文件

4.服务器接收文件数据

用$_FILE[name]接收

5.处理数据,看上传文件是否有错误

错误有如下几种:

1).上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值

2).上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值

3).文件只有部分被上传

4).没有文件被上传

5).找不到临时文件夹

6).文件写入失败

6.把上传的文件从临时文件夹移到指定文件夹存放

用这个move_uploaded_file函数

其中4 5 6步骤可以做成一个函数直接调用.

注意:文件上传的页面如果要嵌入php代码,文件扩展名不能是html,而是.php

二.文件下载

1.客户端把文件名发送给服务器

2.服务器接收文件名,然后加上文件的路径.

3.然后把文件数据传回客户端

一般是这四步:

//1.重设响应类型

$info = getimagesize($rootPath.$file);

header("Content-Type:".$info['mime']);

//2.执行下载的文件名

header("Content-Disposition:attachment;filename=".$file);

//3.指定文件大小

header("Content-Length:".filesize($rootPath.$file));

//4.响应内容

readfile($rootPath.$file);

三.文件删除

1..客户端把文件名发送给服务器

2.服务器接收文件名,然后加上文件的路径.

3.用unlink函数执行删除文件操作

这里有一个图片上传下载删除的小例子.

效果如图:

文件上传下载删除的界面,代码如下:

html+php内嵌:

选择文件

//1.打开目录

$dir = opendir('upload');

//2.遍历目录

$i = 0;

while($file = readdir($dir))

{

if($file == '.'||$file == '..')

continue;

echo "

删除

下载

";

}

//3.关闭目录

closedir($dir);

?>

css代码:

*{margin:0;padding:0;}

ul,li{list-style: none;}

/*最外层的p,目的是包住选择文件按钮,显示框和上传文件按钮*/

#p1{width:405px;height:38px;position: relative;margin:40px auto;}

/*第二层p包住显示框和上传按钮,右浮动*/

#p2{float: right;}

#p2 input {width:250px;height: 38px;font-size: 22px;}

/*第三层p包住input file*/

#p3{float:left;width:140px;height:38px;position: relative;

background: url("upload.jpg") no-repeat 0 0;margin-left: 5px;}

#p3 input{position: absolute;width:100%;height: 100%;top:0;left: 0;

z-index: 1;opacity:0;}

/*图片(选择文件按钮)上的文字*/

.text{display: block;width:140px;height: 38px;position: absolute;top: 0;

left:0;text-align: center;line-height: 38px;font-size: 28px;

color: orchid;}

/*上传按钮的位置*/

.upload{width:70px;height: 38px;background: greenyellow;position: absolute;top:0;right: -75px;}

/*鼠标停留在选择文件按钮上的时候切换图片*/

#p3:hover{background: url("upload.jpg") no-repeat 0 -40px;}

/*显示图片的p->ul,采用左浮动的方式,一行行的排列图片*/

#show-file{width:760px;height:445px;position: relative;margin:10px auto;overflow: scroll;}

#show-file ul{width:760px;height:445px;position: absolute;top:0;left:0;}

#show-file ul li{float: left;width:120px;height: 100px;margin: 3px 0 0 3px;position: relative;}

/*删除按钮的位置和一些样式*/

#show-file ul li p{display: none;opacity: 0;width:40px;height: 20px;position: absolute;left: 5px;bottom: 5px;

background: gold;color: #d32a0e;z-index: 1;cursor: pointer;text-align: center;line-height: 20px;}

/*下载按钮的位置和一些样式*/

#show-file ul li span{display: none;opacity: 0;width:40px;height: 20px;position: absolute;right: 5px;bottom: 5px;

background: gold;color: #d32a0e;z-index: 1;cursor: pointer;text-align: center;line-height: 20px;}

/*把a标签的自带样式去掉,鼠标停留时字体换颜色*/

#show-file ul li span,p a{text-decoration: none;color:orangered;}

#show-file ul li span,p a:hover{color: #00fa00;}

js代码:

window.onload = function ()

{

//当选择文件后,会触发这个事件

$('upfile').onchange = function ()

{

$('show').value = this.value;//把获取到的文件伪路径传到编辑框

};

//显示下载按钮

var aLi = $('ul-list').getElementsByTagName('li'); //图片

var aSpan = $('ul-list').getElementsByTagName('span'); //下载按钮

var ap = $('ul-list').getElementsByTagName('p'); //删除按钮

for(var i = 0;i

{

aLi[i].index = i;

aLi[i].onmousemove = function ()

{

aSpan[this.index].style.display = 'block';

ap[this.index].style.display = 'block';

startMove(ap[this.index],{opacity:100}); //缓冲运动

startMove(aSpan[this.index],{opacity:100}); //缓冲运动

};

aLi[i].onmouseout = function ()

{

aSpan[this.index].style.display = 'none';

ap[this.index].style.display = 'none';

startMove(ap[this.index],{opacity:0}); //缓冲运动

startMove(aSpan[this.index],{opacity:0}); //缓冲运动

}

}

};

function $(id)

{

return document.getElementById(id);

}

处理上传文件的php文件:

include('myFunctions.php');

if(uploadFile('file','upload'))

header("Location:upFileAndDownFile.php");//会马上跳转回原页面,根本感觉不到页面有跳转到这里

处理下载文件的php文件:

include('myFunctions.php');

//获取要下载的文件名(加上路径)

$file = $_GET['name'];

$rootPath = 'upload/';

downLoadFile($file,$rootPath);

处理删除文件的php文件:

$fileName = 'upload/'.$_GET['name'];

unlink($fileName);

header("Location:upFileAndDownFile.php");

其中move.js在前面的JS完美运动框架文章有讲过。

myFunctions.php中的函数如下:

/**

* @function 下载文件

* @param $file 要下载的文件名

* @param $rootPath 文件根路径

* @return 无

*/

function downLoadFile($file,$rootPath)

{

//1.重设响应类型

$info = getimagesize($rootPath.$file);

header("Content-Type:".$info['mime']);

//2.执行下载的文件名

header("Content-Disposition:attachment;filename=".$file);

//3.指定文件大小

header("Content-Length:".filesize($rootPath.$file));

//4.响应内容

readfile($rootPath.$file);

}

/**

* @function 上传文件

* @param $name 表单名

* @param $path 上传后,文件存放的路径

* @return 返回新的文件路径表示上传成功 false 失败

*/

function uploadFile($name,$path)

{

$file = $_FILES[$name];

//1.过滤上传文件的错误号

if($file['error'] > 0)

{

//获取错误信息

switch($file['error'])

{

case 1:

$info = '上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。';

break;

case 2:

$info = '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。';

break;

case 3:

$info = '文件只有部分被上传。';

break;

case 4:

$info = '没有文件被上传。';

break;

case 6:

$info = '找不到临时文件夹';

break;

case 7:

$info = '文件写入失败。 ';

break;

}

die("上传错误,原因: ".$info);

}

//2.上传文件大小的过滤

if($file['size'] > 100000000) //字节为单位

die('上传文件大小超出限制!');

//3.上传后的文件名定义

$newfile = null;

$fileinfo = pathinfo($file['name']); //解析上传文件名

do{

$newfile = date('YmdHis').".".$fileinfo['extension'];

}while(file_exists($path.'/'.$newfile));

//4.执行文件上传

//判断是否是一个上传文件

if(is_uploaded_file($file['tmp_name']))

{

//执行文件上传(移动文件到指定目录)

if(move_uploaded_file($file['tmp_name'],$path.'/'.$newfile))

return $path.'/'.$newfile;

else

return false;

}

else

die('不是一个上传文件!');

}

上传文件的时候注意要设置好HTML表单的大小限制和服务器的大小限制,post的大小限制。

总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。

相关推荐:

php 删除上传文件,php实现文件上传、下载和删除的方法相关推荐

  1. [转]文件传输协议(FTP)操作(上传,下载,新建,删除,FTP间传送文件等)实现汇总1

    转自:http://blog.csdn.net/soarheaven/archive/2008/12/08/3474152.aspx 最近项目需要对FTP服务器进行操作,现把实现总结如下: 打算分2篇 ...

  2. java使用Jsch实现远程操作linux服务器进行文件上传、下载,删除和显示目录信息...

    1.java使用Jsch实现远程操作linux服务器进行文件上传.下载,删除和显示目录信息. 参考链接:https://www.cnblogs.com/longyg/archive/2012/06/2 ...

  3. nodeJs实现文件上传,下载,删除

    转:https://blog.csdn.net/qq_36228442/article/details/81709272 一.简介 本文介绍了nodeJs+express框架下,用multer中间件实 ...

  4. vscode 将本地项目上传到github、从github克隆项目以及删除github上的某个文件夹

    一.将本地项目上传到github 1.创建本地仓库(文件夹) mkdir study//创建文件夹study cd study //进入study文件夹 2.通过命令git init把这个文件夹变成G ...

  5. servlet实现文件上传,预览,下载和删除

    一.准备工作 1.1 文件上传插件:uploadify: 1.2 文件上传所需jar包:commons-fileupload-1.3.1.jar和commons-io-2.2.jar 1.3 将数据转 ...

  6. Spring Boot配置MinIO(实现文件上传、下载、删除)

    1 MinIO MinIO 是一个基于Apache License v2.0开源协议的对象存储服务.它兼容亚马逊S3云存储服务接口,非常适合于存储大容量非结构化的数据,例如图片.视频.日志文件.备份数 ...

  7. minio实现文件上传下载和删除功能

    前言 之前用到文件上传功能,在这里做个学习记录.使用minio实现,后面会记录使用fastdfs和阿里云的oss实现文件上传以及他们的比较(oss根据流量收费).minio的中文文档:https:// ...

  8. .net fileupload批量上传可删除_【JavaWeb基础】文件上传和下载(修订版)

    前言 只有光头才能变强. 文本已收录至我的GitHub仓库,欢迎Star:https://github.com/ZhongFuCheng3y/3y 什么是文件上传? 文件上传就是把用户的信息保存起来. ...

  9. 使用 vscode将本地项目上传到github、从github克隆项目以及删除github上的某个文件夹...

    安装Git后,可以看到windows环境下有两个命令输入窗口Git CMD 和Git Bash Git GUI是可视化图形界面 Git中的Bash是基于CMD的,在CMD的基础上增添一些新的命令与功能 ...

最新文章

  1. Node.js 和Socket.IO 实现chat
  2. android Set的遍历
  3. 关于眼保健操中的轮刮眼眶
  4. NgRx Store里的StoreModule.forRoot()
  5. Python心得--新手开发注意
  6. IDEA下ANTLR Preview的使用
  7. UI帮手|小样机大作用
  8. php bootstrap 分页 查询,深入了解Bootstrap table表格插件(二)前后端分页模糊查询...
  9. 小米8ios图标包下载_小米手机中这么实用的隐藏功能,知道的人居然那么少?真可惜...
  10. 删远端分支报错remote refs do not exist或git: refusing to delete the current branch解决方法
  11. python numpy 下载地址
  12. Linux显示2015年日历表
  13. 互联网电影购票网站调查思考
  14. c语言编译 创建卡号信息表,C语言超市会员信息管理系统源程序
  15. SpringSecurity之CSRF漏洞保护
  16. 在安装sublime之后,我为何毫不犹豫卸载了Dreamweaver?
  17. python不支持下标访问,Python支持使用字典的“键”作为下标来访问字典中的值。...
  18. hacks cheats injection
  19. TM1637驱动数码管
  20. 多个系统间是怎么保证统一登录的

热门文章

  1. Microsoft.AspNet.Identity 自定义使用现有的表—登录实现
  2. Tomcat 6.0 简介
  3. C#中split分隔字符串的应用
  4. switch芯片和phy芯片的区别_感应式芯片卡CPU卡的FM1208-9和FM1208-10有什么区别,你知道吗?...
  5. 一阶电路中的时间常数_精确移相电路的设计举例
  6. python random()*10的值不可能是_Python
  7. 多线程中ThreadLocal的使用
  8. Spring Bean的生命周期以及IOC源码解析
  9. 怎么把pdf转换为html,如何将PDF转换成HTML网页格式呢?
  10. [转载] 多线程详解java.util.concurrent