PHP开发之文件的上传下载

从字符串开始和结束的位置删除空格或者其他字符

表单发送方式为post
指定enctype=multipart/form-data
客户端的代码:


$_FILES[‘userfile’][‘type’]

假设我们要支持上传20M的文件,那么我们可以设置以下选项:

一般地,设置好上述四个参数后,上传<=8M的文件是不成问题,在网络正常的情况下。

string date_default_timezone_get(void);
三、字符函数库
strlen

我们可以通过在服务端来判断文件类型、文件大小,上传方式等来判断是否满足条件,然后才处理文件!

在本机上测试上传100M的文件成功。如有问题请留言!

str_ireplace

客户端配置

把上述参数修改后,在网络所允许的正常情况下,就可以上传大体积文件了。

简单文件下载只需要使用HTML的链接标记,并将属性href的URL值指定下载的文件即可。这种方法只能处理一些浏览器不能识别的MIME类型文件。

二,上传文件类

【注】

$_FILES[‘userfile’][‘error’]

要上传文件,我们需要采用表单,并且表单发送的形式来POST请求,而且要求将enctype设置为multipart/form-data,总结上传的条件如下:

UPLOAD_ERR_NO_FILE
值:4; 没有文件被上传。

从字符串结束的位置删除空格或者其他字符

移动文件方式一
上传文件到服务器端是在一个临时路径下,我们需要将文件移动到指定的目录下,我们可以通过下面的函数来实现移动:

foreach($_FILES as $upfile)
{
  $uploadfile = $uploaddir.$upfile[‘name’];
  
  if(move_uploaded_file($upfile[‘tmp_name’], $uploadfile))
    echo “true”;
  else
  {
       echo  $_FILES[‘userfile’][‘error’]; //具体见下面的注释
       echo “<br/>false”;

mixed str_ireplace(mixed $search, mixed $replace, mixed $subject, [int
$count]);

 
// 判断文件是否是通过HTTP POST上传的,如果是返回TRUE,否则返回FALSE
bool is_uploaded_file ( string $filename )
 
移动文件方式二


图片 1

我们可以通过隐藏域来实现限制上传的文件大小,同时可以通过accept来限制上传的文件的类型,如下所示:

  }
}
?>

设置默认时区

一,比较简单的实现文件上传

 

● getdate

// 参数一:待移动的文件
// 参数二:移动到的目标路径
bool copy ( string $source , string $dest [, resource $context ] )
 
处理上传

post_max_size  =  100M
;指通过表单POST给PHP的所能接收的最大值,包括表单里的所有值。默认为8M

返回一个字符在另一个字符第一次出现的位置

 

 

upload_tmp_dir(string)

浏览器表单页面

<form enctype=”multipart/form-data” action=”upload.php” method=”POST”>
    <!– MAX_FILE_SIZE must precede the file input field –>
    <input type=”hidden” name=”MAX_FILE_SIZE” value=”100000000″ />
    <!– Name of input element determines name in $_FILES array –>
    Send this file: <input name=”userfile” type=”file” />
    <input type=”submit” value=”Send File” />
</form>

is_upload_file

下面是上传一个图片然后打印整理出来的数据:

前台:

mixed microtime([bool get_as_float]);

移动文件

 

获取默认时区

 
<?php
 
define(‘UPLOAD_PATH’, ‘Uploads’);
 
$name = $_FILES[‘myfile’][‘name’];
$type = $_FILES[‘myfile’][‘type’];
$tmp_name = $_FILES[‘myfile’][‘tmp_name’];
$error = $_FILES[‘myfile’][‘error’];
$size = $_FILES[‘myfile’][‘size’];
 
if ($error == UPLOAD_ERR_OK) {
    if (is_uploaded_file($tmp_name)) {
        move_uploaded_file($tmp_name, UPLOAD_PATH . ‘/’ . $name);
    } else {
        if (is_file($tmp_name) && !copy($tmp_name, UPLOAD_PATH . ‘/’
. $name)) {
            var_dump(‘ok’);
        }
    }
} else {
    // 上传到服务器就已经出错了
    var_dump($error);
}
 
php.ini上传配置

memory_limit  = 128M ;每个PHP页面所吃掉的最大内存,默认8M

上传文件存储的临时位置

// 将指定的文件移到的目录路径下
// 要求待移动的文件是通过HTTP POST上传的
bool move_uploaded_file ( string $filename , string $destination )
 
我们需要判断一下是否是通过HTTP POST上传的,下面的方法可以判断:

<?php
$uploaddir = ‘./video/’;

array getdate([int timestamp]);

<?php
 
ini_set(‘display_errors’, ‘On’);
error_reporting(E_ALL);
header(‘Content-type:text/html;Charset=utf-8’);
 
/**
* Class for Uploading a single image 
*/
class Upload {
    protected $fileName; /* eg, $_FILES[‘file’], the name is file.
*/
    protected $allowExt; /* Allow extension for uploading a file */
    protected $allowMIMEType;      /* Allow uploading file mine types
*/
    protected $fileMaxSize; /* Limit a uploading file size */
    protected $uploadPath;  /* The destination path */
    protected $isImageFlag;     /* Note that file is an image or not.
*/
    protected $errorMessage;   
    protected $fileExt;
    protected $fileInfos;
    protected $fileUniqueName;
    protected $fileDestPath;
 
    public function __construct($fileName = ‘file’, $uploadPath =
‘./Uploads’, $isImageFlag = true, $fileMaxSize = 1048576, $allowExt =
array(‘png’, ‘jpg’, ‘jpeg’, ‘gif’), $allowMIMEType = array(‘image/png’,
‘image/jpeg’, ‘image/gif’)) {
        $this->fileName = $fileName;
        $this->allowExt = $allowExt;
        $this->allowMIMEType = $allowMIMEType;
        $this->uploadPath = $uploadPath;
        $this->isImageFlag = $isImageFlag;
        $this->fileMaxSize = $fileMaxSize;
        // print_r($_FILES);
        $this->fileInfos = $_FILES[$fileName];
    }
 
    public function uploadFile() {
        if ($this->isValidExt()
            && $this->isValidMIMEType()
            && $this->isValidFileSize()
            && $this->isRealImage()
            && $this->isHTTPPOST()
            && !$this->hasError()) {
            $this->isUploadPathExist();
            $this->fileUniqueName = $this->getUniqueName();
            $this->fileDestPath = $this->uploadPath . ‘/’ .
$this->fileUniqueName . ‘.’ . $this->fileExt;
// echo iconv(‘gb2312’, ‘UTF-8’,
$this->fileDestPath);
            if
(@move_uploaded_file($this->fileInfos[‘tmp_name’],
$this->fileDestPath)) {
                return $this->fileDestPath;
            } else {
                $this->errorMessage = ‘文件上传失败’;
            }
        } else {
            $this->errorMessage = ‘文件上传失败’;
        }
 
        exit(‘<span
style=”color:red”>’.$this->errorMessage.'</span>’);
    }
 
    protected function hasError() {
        $ret = true;
 
        if (!is_null($this->fileInfos)) {
            switch ($this->fileInfos[‘error’]) {
                case UPLOAD_ERR_INI_SIZE:
                   $this->errorMessage =
‘文件大小超过PHP.ini文件中upload_max_filesize’;
                   break;
                case UPLOAD_ERR_FORM_SIZE:
                    $this->errorMessage =
‘文件大小超过了表单中MAX_FILE_SIZE设置的值’;
                    break;
                case UPLOAD_ERR_NO_TMP_DIR:
                    $this->errorMessage = ‘找不到临时文件目录’;
                    break;
                case UPLOAD_ERR_NO_FILE:
                    $this->errorMessage = ‘没有选择任何文件上传’;
                    break;
                case UPLOAD_ERR_CANT_WRITE:
                    $this->errorMessage = ‘文件不可写’;
                    break;
                case UPLOAD_ERR_PARTIAL:
                    $this->errorMessage = ‘只有部分文件被上传’;
                    break;
                case UPLOAD_ERR_EXTENSION:
                    $this->errorMessage =
‘文件上传过程中被PHP扩展程序中断’;
                    break;
                default:
                    $this->errorMessage = ”;
                    $ret = false;
            }
        } else {
            $this->errorMessage = ‘文件上传出错’;
        }
 
        return $ret;
    }
 
    protected function isValidFileSize() {
        if ($this->fileInfos[‘size’] > $this->fileMaxSize)
{
            $this->errorMessage = ‘文件太大’;
            return false;
        }
 
        return true;
    }
 
    protected function isValidExt() {
        $ext = pathinfo($this->fileInfos[‘name’],
PATHINFO_EXTENSION);
        if (!in_array($ext, $this->allowExt)) {
            $this->errorMessage = ‘不支持的文件类型’;
            return false;
        }
 
        $this->fileExt = $ext;
        return true;;
    }
 
    protected function isValidMIMEType() {
        $type = $this->fileInfos[‘type’];
 
        if (!in_array($type, $this->allowMIMEType)) {
            $this->errorMessage = ‘不支持的文件MIME类型’;
            return false;
        }
 
        return true;
    }
 
    protected function isHTTPPOST() {
        if (!is_uploaded_file($this->fileInfos[‘tmp_name’])) {
            $this->errorMessage = ‘文件不是通过HTTP POST传上来的’;
 
            return false;
        }
 
        return true;
    }
 
    protected function isRealImage() {
        if ($this->isImageFlag &&
!getimagesize($this->fileInfos[‘tmp_name’])) {
            $this->errorMessage = ‘文件不是图片’;
            return false;
        }
 
        return true;
    }
 
    protected function isUploadPathExist() {
        if (!file_exists($this->uploadPath)) {
            mkdir($this->uploadPath, 0777, true);
        }
    }
 
    protected function getUniqueName() {
        return md5(microtime(true), true);
    }
}
 
$upload = new Upload(‘myfile’);
if ($upload->uploadFile()) {
    echo “文件上传成功”;
}

但如果要上传>8M的大体积文件,只设置上述四项还一定能行的通。除非你的网络真有100M/S的上传高速,否则你还得关心关心下面的参数:

图片 2

文件上传原理:将客户端的文件先上传到服务器端,然后再将服务器端的临时文件移动到指定的目录。

UPLOAD_ERR_PARTIAL
值:3; 文件只有部分被上传。

5、文件上传函数

客户端限制上传


图片 3
三、文件函数库

我们还可以通过下面的函数来实现移动文件:

UPLOAD_ERR_OK
值:0; 没有错误发生,文件上传成功。

PHP脚本运行的最大内存

文件上传原理


post_max_size 8M 限制通过POST方法可以接受信息的最大值

<form action=”uploadFile.php” method=”post” accept-charset=”utf-8″
enctype=”multipart/form-data”>
    请选择要上传的文件:
    <input type=”file” name=”myfile”>
    <input type=”submit” value=”上传文件”>
</form>
 
$_FILES文件变量

 

6、错误信息描述

 
// name => ‘QC8054R7QPGQ_1000x500.jpg’
// type => ‘image/jpeg’
// tmp_name => ‘/Applications/MAMP/tmp/php/php1X5KZU’
// error => 0
// size => 229936
 
$_FILES上传的参数含义说明:

UPLOAD_ERR_FORM_SIZE
值:2; 上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。

● date_default_timezone_get

name:上传的文件的名称
type: 上传的文件的MIME类型
tmp_name:文件上传到服务器的临时路径
site:上传的文件的大小
error:上传的文件的错误码,0表示上传成功UPLOAD_ERR_OK

 

PHP脚本最长执行时间

 
<?php
 
define(‘UPLOAD_PATH’, ‘Uploads’);
define(‘MAX_FILE_SIZE’, 2 * 1024 * 1024);
 
header(‘Content-type:text/html;Charset=utf-8’);
 
$name = $_FILES[‘myfile’][‘name’];
$type = $_FILES[‘myfile’][‘type’];
$tmp_name = $_FILES[‘myfile’][‘tmp_name’];
$error = $_FILES[‘myfile’][‘error’];
$size = $_FILES[‘myfile’][‘size’];
 
$allowExt = array(‘png’, ‘jpg’, ‘jpeg’);
 
if ($error == UPLOAD_ERR_OK) {
    if ($size > MAX_FILE_SIZE) {
        exit(‘上传的文件过大’);
    }
 
    // 取上传的文件的扩展类型
    $ext = pathinfo($name, PATHINFO_EXTENSION);
    if (!in_array($ext, $allowExt)) {
        exit(‘非法文件类型’);
    }
 
    if (!is_uploaded_file($tmp_name)) {
        exit(‘文件不是HTTP POST上传过来的’);
    }
 
    if (move_uploaded_file($tmp_name, UPLOAD_PATH . ‘/’ . $name))
{
        echo ‘文件上传成功’;
    } else {
        echo “文件上传失败”;
    }
} else {
    // 上传到服务器就已经出错了
    var_dump($error);
}
 
忽略文件重名之类的问题,那些需要额外添加一些小处理哦!

 

string strtolower(string $str);

 
<form action=”uploadFile.php” method=”post” accept-charset=”utf-8″
enctype=”multipart/form-data”>
    <input type=”hidden” name=”MAX_FILE_SIZE” value=”1024″>
    请选择要上传的文件:
    <input type=”file” name=”myfile” accept=”image/png”>
    <input type=”submit” value=”上传文件”>
</form>
 
服务端限制上传

file_uploads  =  on  ;是否允许通过HTTP上传文件的开关。默认为ON即是开

unserialize

 
//
一定要设置为On,才能上传文件,若设置为Off,则服务器是接收不到文件数据的
file_uploads = On
 
// 指定上传文件到服务器的临时目录,默认为不打开的,可以不写
upload_tmp_dir = “d:/uploads_tmp”
 
// 支持上传的文件的最大为20M
upload_max_filesize = 20M
 
// 设置POST请求允许一次请求的最大值为100M
post_max_size = 100M
 
// 上传操作允许的最长时间,超过600秒则会停止脚本运行,0表示无限制
max_execution_time = 600
 
// PHP脚本解析请求数据所用的最大时间,默认为60秒,0表示无限制
max_input_time = 600
 
// 单个PHP脚本所能申请的最大内存,-1表示无限制!
memory_limit = 128M
 
上传文件错误码
UPLOAD_ERR_OK:代表上传成功
UPLOAD_ERR_EXTENSION:上传的文件被PHP扩展程序中断
UPLOAD_ERR_PARTIAL:文件只有部分被上传
UPLOAD_ERR_CANT_WRITE:文件写入失败
UPLOAD_ERR_FORM_SIZE:表单文件超过了post_max_size
UPLOAD_ERR_INI_SIZE:文件大小超过了限制上传的大小
UPLOAD_ERR_NO_FILE:没有文件被上传
UPLOAD_ERR_NO_TMP_DIR:找不到临时目录

 

UPLOAD_ERR_OK{value=0}

upload_tmp_dir  ;文件上传至服务器上存储临时文件的地方,如果没指定就会用系统默认的临时文件夹

将每个单词的首字母转换为大写字母

 

move_upload_file

下面贴个例子:

strpos

打开php.ini, Ctrl+F 找到下面的项并修改之。下面以上传100M为例。

获取字符串长度

后台:

ucfirst

max_input_time = 600 ;每个PHP页面接收数据所需的最大时间,默认60秒

upload_tmp_dir NULL 上传文件的临时路径,可以是一个绝对路径

upload_max_filesize  =  100m  ;望文生意,即允许上传文件大小的最大值。默认为2M

PHP上传文件的最大尺寸

UPLOAD_ERR_INI_SIZE
值:1; 上传的文件超过了 php.ini 中 upload_max_filesize
选项限制的值。

(1)、$_FILES多维数组:用于存储各种上传文件有关的信息

max_execution_time  =  600
;每个PHP页面运行的最大时间值(秒),默认30秒

将上传文件移至新位置

 

string date(string format[, int timestamp]);

UPLOAD_ERR_CANT_WRITE{value=7}
图片 4

file_put_contents

string serialize(mixed $value)

$_FILES[‘userfile’][size]

复制文件

file_get_contents

copy

UPLOAD_ERR_NO_FILE{value=4}

string rtrim(string $str[, string $chirlist]);

int file_put_contents(string $filename, string $data[, int $flag[,
resource $content]])

bool move_upload_file(string $filename, string $destination)

字符串转换为大写

将一个字符串写入文件

ltrim

md5
计算字符串的MD5哈希

序列化

ucwords

$_FILES[‘userfile’][‘name’]

指令 默认值 功能描述

string ucwords(string $str);

mixed str_ireplace(mixed $search, mixed $replace, mixed $subject, [int
$count]);

bool date_default_timezone_set(string timezone_identifier);

判断指定的文件是否是通过HTTP POST上传

字符串转换为小写

获取上传文件的临时位置名称,这是存储在临时目录中所指定的文件名。

file_uploads(boolean)

upload_max_filesize(integer) 单位M

int strlen(string $str);

字符替换

touch

图片 5 为了提高安全性,不希望在a标签中给出文件链接,则必须向浏览器发送必要的头信息,我们可以使用如下代码。

max_execution_time(integer)

int strpos(string haystack, mixed needle[, int offset]);

$_FILES[‘userfile’][‘tmp_name’]

1、客户端设置:
(1)、在标签中将enctype和method两个属性指明相应的值。Enctype=”multipart/form-data”;
Method=”POST”(2)、form表单中设置一个hidden类型的input框,其中name的值为MAX_FILE_SIZE的隐藏值2、服务器端设置:

● date_default_timezone_set

返回当前Unix时间戳和微秒数

格式化一个本地时间/日期

memory_limit(integer) 单位M

bool is_upload_file(string $filename)

(2)、文件上传与php配置文件的设置,如以下php.ini文件中的一些指令

strtoupper

一、文件的上传

字符替换

rtrim

获取上传文件的MIME类型,每种MIME类型都是由“/”分隔的主类型和子类型组成

file_uploads ON 确定服务器上的PHP脚本是否可以接受HTTP文件上传

获取上传文件的原始名称,包含扩展名

UPLOAD_ERR_INI_SIZE{value=1}

upload_max_file 2M
限制PHP处理上传文件大小的最大值,此值必须小于POST_MAX_SIZE值

注意:移动文件请使用rename函数

string ucfirst(string $str);

strtolower

获取上传文件的错误代码,0:无任何错误,文件上传成功;1:上传文件大小超出了PHP配置文件中upload_max_filesize选项限定的值;2:上传文件大小超出了HTML表单中MAX_FILE_SIZE指定的值;3:表示文件只被部分上传;4:表示没有上传任何文件。

图片 6
● date

UPLOAD_ERR_NO_TMP_DIR{value=6}

HTTP POST数据的最大尺寸

获取上传文件的字节数

3、PHP的文件上传及资源指令

UPLOAD_ERR_FORM_SIZE{value=2}

图片 7
● microtime

注意:文件上传后,首先会存储于服务器的临时目录中,可以使用该函数将上传文件移动到新位置,与copy()和move()相比,它能检测并确保第一个参数filename指定的文件是否是合法上传的文件。

string strtoupper(string $str);

图片 8

bool copy(string $source, string $dest)

二、文件下载

4、$_FILES数组

memory_limit 8M
设置脚本可以分配的最大内存量,防止失控的脚本独占服务器内存

UPLOAD_ERR_PARTIAL{value=3}

将整个文件读到字符串

string file_get_contents(string $filename[, bool user_include_path
[, resource $content[, int $offset[, int $maxlen]]]])

图片 9

图片 10

从字符串开始的位置删除空格或其他字符

图片 11

是否开启HTTP POST文件上传功能

取得日期/时间信息

四、序列化与反序列化

注意:serialize()可处理除了resouce之外的任何类型。甚至可以serialize()那些包含了指向其自身引用的数组。

图片 12

string ltrim(string $str [, string $charlist]);

bool touch(string $filename[, int $time[, int $time]])

str_replace

trim

post_max_size(integer) 单位M

首字母大写

serialize

string md5(string $str[, bool $raw_output=false]);

mixed unserialize(string $str)

设置文件的访问和修饰时间

反序列化

发表评论

电子邮件地址不会被公开。 必填项已用*标注