热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

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

这篇文章主要为大家详细介绍了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函数执行删除文件操作

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

效果如图:

2c68300b76e7f169d2d7a0f532be9fb8.png

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

html+php内嵌:

选择文件

//1.打开目录

$dir = opendir('upload');

//2.遍历目录

$i = 0;

while($file = readdir($dir))

{

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

continue;

echo "

%7B%24file%7D

删除

下载

";

}

//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的大小限制。

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

相关推荐:



推荐阅读
  • 使用圣杯布局模式实现网站首页的内容布局
    本文介绍了使用圣杯布局模式实现网站首页的内容布局的方法,包括HTML部分代码和实例。同时还提供了公司新闻、最新产品、关于我们、联系我们等页面的布局示例。商品展示区包括了车里子和农家生态土鸡蛋等产品的价格信息。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 原文转自:http:blog.csdn.netchinasoftosgarticledetails7903045UploadAction.java:packagecr ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
    本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • 图像因存在错误而无法显示 ... [详细]
  • 如何在php文件中添加图片?
    本文详细解答了如何在php文件中添加图片的问题,包括插入图片的代码、使用PHPword在载入模板中插入图片的方法,以及使用gd库生成不同类型的图像文件的示例。同时还介绍了如何生成一个正方形文件的步骤。希望对大家有所帮助。 ... [详细]
  • 用ESP32与Python实现物联网(IoT)火焰检测报警系统
    下图是本案例除硬件连线外的3步导学开发过程,每个步骤中实现的功能请参考图中的说明。在硬件连线完成之后我们建议您先使用“一分钟上云体验”功能预先体验本案例的实际运行效果 ... [详细]
  • 开发笔记:UEditor调用上传图片上传文件等模块
    1、引入ue相关文件,写好初始代码为了更好的封装整一个单独的插件,这里我们要做到示例化ue后隐藏网页中的编辑窗口,并移除焦点。 ... [详细]
  • UEditor可以如何直接复制word的图文内容到编辑器中
    这种方法是servlet,编写好在web.xml里配置servlet-class和servlet-mapping即可使用后台(服务端)j ... [详细]
author-avatar
yangchang78179
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有