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

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

相关推荐:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/550399.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

软件工程详细设计说明书_软件工程导论知识点梳理之简答题

1. 软件危机的表现形式对软件开发成本和进度估计不准确已完成的软件不符合用户需求软件产品质量差,可靠性得不到保证软件产品可维护性差软件成本在计算机总成本中的比例逐渐变大软件开发生产率提高速度比不上计算机应用速度2. 产生软件危机的原因(1)软件是计算机系统…

css中absolute设置问题和如何让div居中

今天设置多个div到页面正中间的时候&#xff0c;在第一层<div class"map">中设置如下&#xff1a; .map{ position&#xff1a;absolute&#xff1b; top:50%; left:50% transform: translate(-50%, -50%); } 该div就移到页面的正中间&#xff0c;达到预定效果…

php模板意思,php中的 是什么意思

php调用类的内部静态成员&#xff0c;或者是类之间调用就要用两个冒号(::)。说明&#xff1a;“::”符号可以认为是与C语言中的“.”相似的&#xff0c;而它更像C中(Perl)的::类范围操作符。示例&#xff1a;{$0;(){//}(){();$;}};/*C语言中的*/a::b::c();//C中的函数$a::b::c;…

程序员为什么老得快_这段 Python 代码让程序员赚 300W,公司已确认!网友:神操作!...

点击上方“Python大本营”&#xff0c;选择“置顶公众号”python大本营 IT人的职业提升平台Python到底还能给人多少惊喜&#xff1f;笔者最近看到了这两天关于Python最热门的话题&#xff0c;关于《地产大佬潘石屹学Python的原因》&#xff0c;结果被这个回答惊到了&#xff1…

Mercedes-Benz won’t start| Step by Step Troubleshooting Guide

Mercedes won’t start or turn over? Are you experiencing Mercedes-Benz no start problems? Key won’t turn at all? Engine turning over but the car will not start? Maybe it finally starts, runs for a few seconds and then dies. These are common Mercedes-…

php如何设置页面布局,excel页面布局怎么调整

excel页面布局调整的方法&#xff1a;首先点击菜单的页面布局&#xff0c;选择纸张大小&#xff1b;然后点击“纸张方向”&#xff0c;单击以选择横向或者纵向&#xff1b;最后点击“页边距”即可。点击菜单——页面布局&#xff0c;工具栏将出现页面布局的许多项目&#xff0c…

无法获取未定义或 null 引用的属性“value”_SpringBoot之Spring@Value属性注入使用详解

在使用Spring框架的项目中&#xff0c;Value是使用比较频繁的注解之一&#xff0c;它的作用是将配置文件中key对应的值赋值给它标注的属性。在日常使用中我们常用的功能都比较简单&#xff0c;本篇文章系统的带大家来了解一下Value的使用方法。Value注入支持形式Value属性注入功…

0x11 栈

【例题】Push,Pop,GetMin 手写一个栈 1 #include <iostream>2 #include <cstdio>3 #include <cmath>4 #include <cstring>5 #include <algorithm>6 #include <queue>7 using namespace std;8 const int maxn1000000;9 int stack[maxn], m[…

java war包合并,使用maven warpath插件合并多module的war包

查看原文&#xff1a;http://www.yeetrack.com/?p899现在java项目一般使用maven、gradle等工具来管理jar包、打包、发布。如果一个项目有很多模块&#xff0c;那般是分成多个module&#xff0c;主目录有个parent&#xff0c;负责包含全部的module&#xff0c;然后目录中多个mo…

儿童编程python入门_儿童编程python入门

经常会有小朋友问我&#xff0c;“我想做个黑客&#xff0c;我该学什么编程语言&#xff1f;”&#xff0c;或者有的小朋友会说&#xff1a;“我要学c&#xff0c;我要做病毒”。其实对于这些小朋友而言他们基本都没有接触过编程语言&#xff0c;只是通过影视或者其他地方看到的…

ARM GNU 常用汇编伪指令介绍

abort.abort: 停止汇编 .align absexpr1, absexpr2: 以某种对齐方式,在未使用的存储区域填充值. 第一个值表示对齐方式,4, 8,16 或 32. 第 二个表达式值表示填充的值. if...else...endif.if .else .endif: 支持条件预编译 include.include "file": 包含指定的头文件,…

java 同类型转换失败,你们见过java类型转换,自己转自己失败的情况吗?很神奇的操作...

问题就是上面这个问题。List slaughterProducts slaughterForm.getSlaughterProductModelForm();for (SlaughterProductModelForm e : slaughterProducts) {....}居然运行到for的时候出现上面这个错误。很神奇吧&#xff0c;工作这么多年了第一次发现 JAVA自己转自己转不成功。…

python可视化代码_python可视化实现代码

python可视化#导入两个库import numpy as npimport matplotlib.pyplot as plt#第一个参数就是x轴的初始值#第二个参数是x轴的终止值#第三个返回num均匀分布的样本&#xff0c;也就是0-12的区间取多少个点&#xff0c;如果为曲线的最好数值大一点x np.linspace(0, 12, 50)y np…

用户管理与文件权限

一&#xff1a;用户管理 现代操作系统一般属于多用户的操作系统&#xff0c;也就是说&#xff0c;同一台机器可以为多个用户建立账户&#xff0c;一般这些用户都是为普通用户&#xff0c;这些普通用户能同时登录这台计算机&#xff0c;计算机对这些用户分配一定的资源。 普通用…

php中划线,html中下划线、删除线、上划线的样式与用法实例

这篇文章主要介绍了下划线、删除线、上划线等常用的实例&#xff0c;划线是非常常见的一种样式&#xff0c;为了网页中的视觉效果以及对文字的说明&#xff0c;我们经常对文体进行一些划线操作。下面文章就是对各种划线的详细介绍。一. 下划线的详细介绍在我们日常的Web的开发中…

rabbitmq3.7集群搭建实战

环境&#xff1a; 3台 centos7.4rabbitmq3.7erlang 22 1. 有几种方式安装&#xff0c;这里使用的yum安装&#xff08;官方推荐&#xff09;2. 使用rabbitmq时需要安装erlang&#xff0c;在各个节点上使用vim添加两个repo文件**/etc/yum.repos.d/rabbitmq_erlang.repo**[rabbitm…

php获取页面中的指定内容,php 获取页面中指定内容的实现类

[email protected]image&#xff1a;Grep.class.php/** grep class* Date: 2013-06-15* Author: fdipzone* Ver: 1.0** Func:** set: 设置内容* get: 返回指定的内容* replace: 返回替换后的内容* get_pattern 根据type返回pattern*/class Grep{ // class startprivate $_patte…

数据增量更新定义_TiDB 在 OPPO 准实时数据仓库中的实践

作者介绍OPPO 数据分析与解决方案团队主要负责 OPPO 全集团的大数据分析和解决方案提供&#xff0c;团队成员多来自一线互联网公司及著名高校&#xff0c;在 OPPO 众多场景的大数据应用方面有很深经验&#xff0c;极大的支撑了业务迅速发展。文章具体作者&#xff1a;羊欢&…

Python之模块初识-自定义模块

1. 模块的定义与分类 什么是模块&#xff1f;一个模块就是一个py文件。 模拟博客园系统作业&#xff0c;100000行代码. 不可能全部存在一个文件. 不易维护.效率低.分文件: 10个文件.每个文件有50个函数,有一写相同功能或者相似功能的函数.代码冗余,重复性.我们应该将这10个函数…

php统计用户留存脚本,SQL 统计用户留存

问题描述有一个用来记录每日客户消耗数据的表 t&#xff0c;它的表结构如下&#xff1a;字段类型描述created_dayDate消耗日期customer_idInteger客户IDamountInteger消耗金额要求&#xff1a;统计出头部客户、腰部客户、尾部客户在上个月(2020-06-01 ~ 2020-06-30)的留存情况。…