一、文件上传

  前台页面:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>文件上传</title>
</head>
<body>
<div>
<form method="post" action="upload.php" enctype="multipart/form-data" >
用户名<input type="text" name="username"></input>
<br>
文件简单介绍<br><textarea name="fileintro" rows="8" cols="50"></textarea>
<br>选择要上传的文件<br><input type="file" name="myfile"></input><br>
<input type="submit" value="上传文件"></input>
</form>
</div>
</body>
</html>

  后台处理:

<?php
//接收提交页面传送的相关信息
$name = $_POST['username'];
$intro = $_POST['fileintro'];
//$_FILES中存放着文件的相关信息
// echo "<pre>";
// print_r($_FILES);
// echo "</pre>"; //可以在这里对文件大小进行限制
/*$filesize = $_FILES['myfile']['size'];
if($filesize>2*1024*1024){
echo "文件过大,不能上传";
exit();
}*/ //可以对文件类型进行限制
/*$filetype = $_FILES['myfile']['type'];
if($filetype!='image/jpg'&&$filetype!='application/pdf'){
echo "文件类型只能是jpg和pdf";
exit();
}*/ if (is_uploaded_file($_FILES['myfile']['tmp_name'])) {
//把文件转存到你希望存放的目录
$uploaded = $_FILES['myfile']['tmp_name']; //每个用户动态创建一个文件夹
$userpath = $_SERVER['DOCUMENT_ROOT']."/up/".$name;
//判断该用户是否已经有文件夹
if(!file_exists($userpath)){
mkdir($userpath);
} //防止同一用户上传同名文件,可在文件中添加时间戳。
//$moveto = $userpath."/".time().$_FILES['myfile']['name']; //或者对文件名进行修改,但是需要使用字符串处理截得文件后缀名
$truename = $_FILES['myfile']['name'];
$moveto = $userpath."/".time().substr($truename,strrpos($truename,".")); if(move_uploaded_file($uploaded,iconv("utf-8", "gb2312", $moveto))){
echo "上传文件".$_FILES['myfile']['name']."成功";
}else{
echo "上传文件".$_FILES['myfile']['name']."失败";
}
}else{
echo "上传文件".$FILES['myfile']['name']."失败";
}
?>

  二、文件下载:

  单文件下载:

 <?php
function down_file($file_name,$file_path){
//$file_name = iconv("uft-8","gb2312",$file_name); //如果文件名是中文,需要对中文名称转码gb2312
//要下载的文件读取到服务器的内存中
//服务器返回文件数据给浏览器
//浏览器将文件写入用户指定的位置
//1.判断文件是否存在
if(!file_exists($file_name)){
echo "111";
return ;
}
$fp = fopen($file_name,"r");
$file_size = filesize($file_name);
//获取文件大小
//可通过file_size限制浏览器下载文件大小。
//返回的文件
header("Content-type:application/octet-stream");
//按字节大小返回
header("Accept-Ranges:bytes");
//返回文件大小
header("Accept-Length:$file_size");
//客户端弹出对话框,对应的文件名
header("Content-Disposition:attachment;filename=".$file_name);
$buffer = 1024;
//定义缓冲区
//为了下载的安全,最好使用文件字节读取计数器
$file_count = 0;
//feof用于判断文件是否读取到文档尾
while(!feof($fp) && ($file_size-$file_count>0)){
$file_data = fread($fp,$buffer);
//统计读了多少个字节
$file_count+$buffer;
echo $file_data;
//把部分数据会送给浏览器
}
fclose($fp);
//关闭文件
}
?>

  多个文件下载:

  DownList.php:

<a href="downprocess.php?filename=1.jpg">down</a><img src="1.jpg" width="50px" height="50px"><br><br>
<a href="downprocess.php?filename=2.jpg">down</a><img src="2.jpg" width="50px" height="50px"><br><br>
<a href="downprocess.php?filename=3.jpg">down</a><img src="3.jpg" width="50px" height="50px"><br><br>
<a href="downprocess.php?filename=4.jpg">down</a><img src="4.jpg" width="50px" height="50px"><br><br>

  downprocess.php:

<?php
$filename = $_REQUEST['filename'];
function down_file($file_name){ if(!file_exists($file_name)){
echo "111";
return ;
}
$fp = fopen($file_name,"r");
$file_size = filesize($file_name);
header("Content-type:application/octet-stream");
//按字节大小返回
header("Accept-Ranges:bytes");
//返回文件大小
header("Accept-Length:$file_size");
//客户端弹出对话框,对应的文件名
header("Content-Disposition:attachment;filename=".$file_name);
$buffer = 1024;
//定义缓冲区
$file_count = 0;
//feof用于判断文件是否读取到文档尾
while(!feof($fp) && ($file_size-$file_count>0)){
$file_data = fread($fp,$buffer);
//统计读了多少个字节
$file_count+$buffer;
echo $file_data;
//把部分数据会送给浏览器
}
fclose($fp);
}
down_file($filename);
?>

PHP文件上传及下载源码的更多相关文章

  1. 文件上传和下载(可批量上传)——Spring(二)

    针对SpringMVC的文件上传和下载.下载用之前“文件上传和下载——基础(一)”的依然可以,但是上传功能要修改,这是因为springMVC 都为我们封装好成自己的文件对象了,转换的过程就在我们所配置 ...

  2. 19、文件上传与下载/JavaMail邮件开发

    回顾: 一. 监听器 生命周期监听器 ServletRequestListener HttpSessionListener ServletContextListener 属性监听器 ServletRe ...

  3. Selenium常用API用法示例集----下拉框、文本域及富文本框、弹窗、JS、frame、文件上传和下载

    元素识别方法.一组元素定位.鼠标操作.多窗口处理.下拉框.文本域及富文本框.弹窗.JS.frame.文件上传和下载 元素识别方法: driver.find_element_by_id() driver ...

  4. Java 文件上传与下载、email

    1. 文件上传与下载 1.1 文件上传 文件上传,要点: 前台: 1. 提交方式:post 2. 表单中有文件上传的表单项: <input type="file" /> ...

  5. Http服务器实现文件上传与下载(四)

    一.引言 欢迎大家来到和我一起编写Http服务器实现文件的上传和下载,现在我稍微回顾一下之前我说的,第一.二章说明说明了整体的HTTP走向,第三章实现底层的网络编程.接着这一章我想给大家讲的是请求获取 ...

  6. koa2基于stream(流)进行文件上传和下载

    阅读目录 一:上传文件(包括单个文件或多个文件上传) 二:下载文件 回到顶部 一:上传文件(包括单个文件或多个文件上传) 在之前一篇文章,我们了解到nodejs中的流的概念,也了解到了使用流的优点,具 ...

  7. 七、springBoot 简单优雅是实现文件上传和下载

    前言 好久没有更新spring Boot 这个项目了.最近看了一下docker 的知识,后期打算将spring boot 和docker 结合起来.刚好最近有一个上传文件的工作呢,刚好就想起这个脚手架 ...

  8. javaWeb学习总结——文件上传、下载

    目录 1.文件上传环境搭建 2.文件上传代码实现 3.关于下载 @ 嘿,熊dei,你不得不知道在Web开发中,文件上传和下载功能是非常常用的功能,关于文件上传,浏览器上传[文件以流的形式传输]--&g ...

  9. Java实现FTP文件上传与下载

    实现FTP文件上传与下载可以通过以下两种种方式实现(不知道还有没有其他方式),分别为:1.通过JDK自带的API实现:2.通过Apache提供的API是实现. 第一种方式 package com.cl ...

随机推荐

  1. WEB下载显示下载名称乱码--java

    将文件名编码转换为ISO8859-1即可,如下 downloadFileName = new String(fileName.getBytes("gbk"), "ISO8 ...

  2. 【bzoj3172】 Tjoi2013—单词

    http://www.lydsy.com/JudgeOnline/problem.php?id=3172 (题目链接) 题意 $n$个单词组成文本,问每个单词在文本中出现了几次. Solution 题 ...

  3. vue-devtools/安装vue-devtools

    一.在github上下载压缩包,github下载地址:https://github.com/vuejs/vue-devtools 二.解压到本地的某盘 三.用你的npm中进入该文件夹下 在npm中执行 ...

  4. ElasticStack系列之十九 & bulk时 index 和 create 的区别

    区别: 两篇文章 id 都一样的情况下,index 是将第二篇文章覆盖第一篇:create 是在第二篇插入的时候抛出一个已经存在的异常 解释: 在批量请求的时候最好使用 create 方式进行导入.假 ...

  5. Spark记录-spark介绍

    Apache Spark是一个集群计算设计的快速计算.它是建立在Hadoop MapReduce之上,它扩展了 MapReduce 模式,有效地使用更多类型的计算,其中包括交互式查询和流处理.这是一个 ...

  6. ASP.NET MVC学习笔记-----Filter(1)

    Filter类型 接口 MVC的默认实现 Description Authorization IAuthorizationFilter AuthorizeAttribute 最先执行,在其他类型的fi ...

  7. 一些js的小技巧

    这里收集了一些编码上的小技巧,大家可以学习学习. 1.浮点转整型 使用|0快速转换 var a=(12.002)|0;//12 使用~~快速转换 ~取反运算符,2=0010,~2=1101,因为第一位 ...

  8. 【GDOI2018】所有题目和解题报告

    使用说明:题意和数据范围都只是回忆内容,仅供参考.题解陆续补上. Day 1 第一题 题意:给定n个数字,要求划分成k的连续段使得每个连续段内的数字之和相同,求最大的k.n,Σai<=10^6. ...

  9. CTSC2018&APIO2018游记

    CTSC2018&APIO2018游记 Day 0 傍晚出发,从长沙通往帝都的软卧哟. 然而长沙某中学坐高铁比我们晚出发还早到 Day 1 为了正经地写游记我决定忍住不在博客里吐槽酒店. 午饭 ...

  10. CSS float浅析

    写在开篇: 浮动属性的设计初衷,只是为了实现文本环绕效果! 时刻牢记这一点,才能正确使用浮动. 由于浮动元素脱离文档流,它后面的块级元素会忽略它的存在,占据它原本的位置,但是这个块级元素中的内联元素, ...