Analyse du téléchargement de fichiers PHP

小云云
Libérer: 2023-03-17 11:18:02
original
6731 Les gens l'ont consulté

Le téléchargement de fichiers PHP est quelque chose que tout programmeur rencontrera. Alors, que savez-vous du téléchargement de fichiers PHP ? Cet article décrit principalement la méthode détaillée de téléchargement de fichiers PHP. Vous pouvez vous y référer.

1. Téléchargement général de fichiers, à moins que le fichier soit très petit comme un fichier de 5 Mo, le téléchargement peut prendre plus d'une minute. Mais en PHP, le temps d'exécution maximum par défaut de cette page est de 30 secondes. C'est-à-dire que s'il dépasse 30 secondes, le script cessera de s'exécuter. Cela entraînera l'impossibilité d'ouvrir la page Web. À ce moment, nous pouvons modifier max_execution_time

et rechercher <.>

La valeur par défaut est de 30 secondes. Remplacez par
max_execution_time
Copier après la connexion

0 pour indiquer aucune limite
max_execution_time = 0
Copier après la connexion

Une autre méthode consiste à ajouter

<🎜. >

au programme php Pour définir le temps d'exécution de la page le plus long.

set_time_limit();
Copier après la connexion

2. Modifiez post_max_size pour définir la taille maximale autorisée pour les données POST. Ce paramètre affecte également les téléchargements de fichiers.

set_time_limit(0);//0表示没有限制
Copier après la connexion
Le post_max_size par défaut de PHP est 2M. Si la taille des données POST est supérieure à post_max_size, $_POST et $_FILES, les superglobales seront vides.

Recherchez post_max_size. Remplacez-le par

3. De nombreuses personnes modifieront la deuxième étape. Mais lors du téléchargement de fichiers, le maximum est toujours de 8 Mo.

post_max_size = 150M
Copier après la connexion
Pourquoi ? Nous devons également modifier un paramètre upload_max_filesize pour représenter la taille maximale du fichier téléchargé.

Recherchez upload_max_filesize, la valeur par défaut est 8M et remplacez-la par

Une autre chose à noter est : post_max_size est meilleur que upload_max_filesize.

upload_max_filesize = 100M
Copier après la connexion
Analyse du téléchargement de fichiers :

Le téléchargement de fichiers utilise la méthode POST. Un formulaire de téléchargement de fichier de base est le suivant :

fileupload.htm

Sélectionnez le fichier à télécharger :

<form enctype="multipart/form-data" action="dealfileupload.php" method="POST">
Copier après la connexion

Ce qu'il faut noter, c'est la valeur de l'attribut enctype et de l'attribut name dans le contrôle de fichier, qui sont utilisés pour identifier le fichier téléchargé. Le script de traitement de ce formulaire est le suivant :

<input name="userfile" type="file"/>
<input type="submit" value="上传"/>
</form>
Copier après la connexion
dealfileupload.php

Si le téléchargement réussit, le fichier sera enregistré dans le répertoire de téléchargement dans le répertoire racine du site Web. . Analysons ce simple script de traitement.

<?php
$docroot=$_SERVER[&#39;DOCUMENT_ROOT&#39;];
$fileupload=$docroot."/upload/".$_FILES[&#39;userfile&#39;][&#39;name&#39;];
if (move_uploaded_file($_FILES[&#39;userfile&#39;][&#39;tmp_name&#39;],$fileupload))
{
echo "文件上传成功";
}
else
{
echo "文件上传失败";
}
?>
Copier après la connexion
1.1 Tableau $_FILES

1. Fonction système $_FILES

Notez ici, $_FILES['myFile'][ 'name '] dans "myFile" est la valeur de l'attribut name de la zone de texte utilisée pour stocker le chemin du fichier dans le formulaire de téléchargement de fichier. Analyse du téléchargement de fichiers PHP

2. Fonction move_uploaded_file (fonction pour déplacer les fichiers vers l'emplacement cible après le téléchargement)

move_uploaded_file (fichier temporaire, chemin relatif de l'emplacement cible et nom du fichier) ; . Fonction is_uploaded_file (fonction pour déterminer la fonction de fichier de type MIME téléchargé)

is_uploaded_file(MIME);

Si la valeur de l'attribut name dans le contrôle de fichier du formulaire est userfile, alors $_FILES ['userfile'] contient des informations sur le fichier téléchargé. Supposons que nous téléchargeons un fichier nommé temp.txt, puis :

$_FILES['userfile']['name']="temp.txt" Nom du fichier

$_FILES['userfile' ]['tmp_name']="c:/tmp1" Nom complet du fichier temporaire

$_FILES['userfile']['type']="text/plain" Type de fichier

$ _FILES['userfile']['size']=1024 Taille du fichier (nombre d'octets)

$_FILES['userfile']['error']=0 Code d'erreur, 0 signifie succès

1.2 

 Cette fonction est spécifiquement responsable du transfert des fichiers téléchargés. filename représente le nom complet du fichier temporaire, généralement $_FILES['file1']['tmp_name'] ; la destination représente le nom complet du fichier de destination, généralement $_SERVER['DOCUMENT_ROOT']."/upload/".$_FILES[ 'file1 ']['nom']. Si le téléchargement réussit, 1 est renvoyé, sinon 0 est renvoyé et une erreur est signalée. Si vous souhaitez masquer le message d'erreur, vous pouvez écrire comme ceci : @move_uploaded_file(...)

1.3 Si vous devez télécharger plusieurs fichiers, vous pouvez définir plusieurs contrôles de fichiers. Notez que l'attribut name doit être spécifié. être réglé sur des valeurs différentes. Par exemple :

bool move_uploaded_file (string filename, string destination)
Copier après la connexion
filesupload.htm

Sélectionnez le fichier à télécharger 1 :

Sélectionnez le fichier à télécharger 2 :
<form enctype="multipart/form-data" action="dealfilesupload.php" method="POST">
Copier après la connexion

 <input name="file1" type="file"/>
Copier après la connexion
1.4 Principe de génération de fichiers HTML par PHP

1. Certaines fonctions d'opération de fichier PHP
<input name="file2" type="file"/>
Copier après la connexion
<input type="submit" value="上传"/>
</form>
dealfilesupload.php
<?php
$docroot=$_SERVER[&#39;DOCUMENT_ROOT&#39;];
$file1upload=$docroot."/upload/".$_FILES[&#39;file1&#39;][&#39;name&#39;];
$file2upload=$docroot."/upload/".$_FILES[&#39;file2&#39;][&#39;name&#39;];
if (@move_uploaded_file($_FILES[&#39;file1&#39;][&#39;tmp_name&#39;],$file1upload))
{
echo "文件1上传成功";
}
else
{
echo "文件1上传失败";
}
print "<br/>";
if (@move_uploaded_file($_FILES[&#39;file2&#39;][&#39;tmp_name&#39;],$file2upload)){
echo "文件2上传成功";
}else{
echo "文件2上传失败";
}
?>
Copier après la connexion
(1) fonction d'ouverture de fichier fopen

fopen (chemin et nom du fichier, mode Ouvert); //R-lecture seule W-écriture A-lecture-écriture

'r' Ouvrir en mode lecture seule, pointez le pointeur du fichier vers l'en-tête du fichier.

'r+' Ouvrez en mode lecture et écriture et pointez le pointeur du fichier vers l'en-tête du fichier.

'w' active le mode écriture, pointe le pointeur du fichier vers l'en-tête du fichier et tronque la taille du fichier à zéro. Si le fichier n'existe pas, essayez de le créer.

'w+' Ouvrez en mode lecture et écriture, pointez le pointeur du fichier sur l'en-tête du fichier et tronquez la taille du fichier à zéro. Si le fichier n'existe pas, essayez de le créer.

'a' s'ouvre en mode écriture et pointe le pointeur de fichier vers la fin du fichier. Si le fichier n'existe pas, essayez de le créer.

'a+' Ouvrez en mode lecture-écriture et pointez le pointeur de fichier vers la fin du fichier. Si le fichier n'existe pas, essayez de le créer.

(2) fread lit le contenu du fichier

fread (fichier ouvert, position finale);// en octets

(3) filesize lit la taille du fichier, mesurée en octets, pour les fichiers entre 2 et 4 Go, vous pouvez utiliser sprintf("%u",filesize($file))//(fonction de sortie formatée) pour traiter

filesize (chemin et nom de fichier);

(4) fwrite 写入文件内容

fwrite (打开的文件,写入的内容);

(5) fclose 关闭打开的文件

fclose (打开的文件);

(6) file_get_contents(“路径和文件名”);//功能是读取整个文件内容

(7) file_ exists(path);//函数检查文件或目录是否存在

(8) chmod(相对路径,代表PHP可访问的权限数值八进制);//更改文件或文件夹的访问权限模式

2、目录操作常用函数

mkdir() 建立新目录函数

语法:

mkdir(path,[int mode,][recursive,][context])
Copier après la connexion

说明:path是必须参数,给出将要新建的文件夹所在的路径和名称,最好是使用绝对路径;mode是可选参数,默认值是0777(尝试以最大目录权限进行操作),该参数是八进制,即要设置该参数就必须将数值以0开头;recursive是可选参数,指出是否使用递归模式;context是可选参数,规定文件句柄的环境。Context 是可修改流的行为的一套选项。创建成功返回TRUE,否则返回FALSE。

rmdir()删除一个指定名称的空目录

语法:rmdir(目录路径和名称)

说明:尝试删除 目录路径和名称 所指定的目录。该目录必须是空的,而且要有相应的权限。如果成功则返回 TRUE,失败则返回 FALSE。

unlink() 删除文件函数

   语法:unlink(路径和文件名)

说明:删除 路径和文件名称 所指定的文件。和 Unix C 的 unlink() 函数相似。如果成功则返回 TRUE,失败则返回 FALSE。

3、其它文件操作函数

(1)string basename(string path [,string suffix]) ,path参数给出一个文件的全路径字符串,函数返回基本的文件名。如文件名以suffix结束,则去掉这部分

(2)string dirname(string path) ,返回路径中的目录部分。

(3)array pathinfo(string path) ,返回文件路径的信息,包含以下的数组单元dirname,basename,extension.

(4)string realpath(string path) ,返回规范化的绝对路径名

(5)bool copy( string source ,string dest) ,将文件从source复制到dest

例:copy("hello.txt","temp.php");

(6)float disk_free_space(string directory ) ,返回目录中的可用空间

例:$df = disk_free_space("F:\");

echo $df.''
'';

(7)float disk_total_space(string directory) ,获取指定磁盘总空间

例:

$df=disk_total_space("F:\");
echo $df.&#39;&#39;<br>&#39;&#39;;
Copier après la connexion

(8)int file_put_contents(string filename,string data[,int flags[,resource context]]),将一个字符串写入文件

(9)string file_get_contents(string filename [,int use_include_path[,resource context]]) ,将整个文件作为一个字符串读入。不需要之前fopen()

例:

$lines=file_get_contents("hello.txt");
  echo nl2br($lines);
Copier après la connexion

(10)int fileatime(string filename) ,取得文件的上次访问时间

例:

echo date("F d Y H:i:s",fileatime($filename);
Copier après la connexion

(11)int filemtime(string filename),取得文件的最近修改时间

例:

echo date("F d Y H:i:s",filemtime($filename);
Copier après la connexion

(12)array stat(string filename) 给出文件的信息or lstat( string filename) or fstat( resource handle)

例:

 $fileinfo =stat($filename);
Copier après la connexion
echo "<table border=1><th>数字下标</th><th>关键(自PHP 5.1.4)</th>";
foreach($fileinfo as $num=>$info)
{
echo "<tr><td>".$num."</td><td>".$info."</td></tr>";
}
echo "</table>";
Copier après la connexion

(13)string filetype(string filename) ,获取文件的类型

例:echo filetype($filename);

(14)bool is_dir(string filename) ,判断给定的文件名是否是一个目录

例:

if(is_dir($filename))
echo $filename.&#39;&#39;为目录<br>&#39;&#39;;
else
echo $filename.&#39;&#39;非目录<br>&#39;&#39;;
Copier après la connexion

(15)bool flock(int handle,int operation [,int &wouldblock]) ,进行文件锁定

operation: LOCK_SH:共享锁定

LOCK_EX: 独占锁定

LOCK_UN: 释放锁定

(16)bool is_uploaded_file(string filename)

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

(17)bool move_uploaded_file(string filename,string destination)

检测文件是否是合法的上传文件,是则移动到destination 指定的文件

(18)array file(path,include_path,context)

函数把整个文件读入一个数组中。与 file_get_contents() 类似,不同的是 file() 将文件作为一个数组返回。数组中的每个单元都是文件中相应的一行,包括换行符在内。如果失败,则返回 false。

path 必需。规定要读取的文件。include_path 可选。如果也想在 include_path 中搜寻文件的话,可以将该参数设为 "1"。context 可选。规定文件句柄的环境。 context 是一套可以修改流的行为的选项。若使用 null,则忽略。

注释:如果碰到 PHP 在读取文件时不能识别 Macintosh 文件的行结束符,可以激活 auto_detect_line_endings 运行时配置选项。

(19) string fgetss()

fgetss() 函数从打开的文件中读取一行并过滤掉 HTML 和 PHP 标记。与 fgets() 相同,不同的是 fgetss 尝试从读取的文本中去掉任何 HTML 和 PHP 标记。

使用方法:fgetss(file,length,tags)

file 必需。规定要读取的文件。length 可选。规定要读取的字节数。默认是 1024 字节。该参数在 PHP 5 之前是必需的。tags 可选。规定将被删除的标签。可以用可选的第三个参数 tags 指定哪些标记不被去掉。若失败,则返回 false。

<?php
$file = fopen("test.htm","r");
echo fgetss($file,1024,"<p>,<b>");//保留p和b标记
fclose($file);
?>
Copier après la connexion

(20) string fgets()

fgets() 函数从文件指针中读取一行。file 必需。规定要读取的文件。length 可选。规定要读取的字节数; 默认是 1024 字节。

从 file 指向的文件中读取一行并返回长度最多为 length - 1 字节的字符串。碰到换行符(包括在返回值中)、EOF 或者已经读取了 length - 1 字节后停止(要看先碰到那一种情况)。如果没有指定 length,则默认为 1K,或者说 1024 字节。

若失败,则返回 false。

4、遍历文件夹中的文件

$dir=opendir(''文件夹路径名'');//打开文件夹,返回一个文件夹对象(句柄)

while($fileName=readdir($dir))//readdir(参数是用opendir打开的文件夹对象名),每执行一次都会

取出指定文件夹中的一个文件名称,且文件指针向下移动一个

{
echo &#39;&#39;fileName=&#39;&#39;.$fileName. &#39;&#39;<br />&#39;&#39;;//输出取得的文件名
}
?>
Copier après la connexion

opendir() 函数返回一个目录句柄即文件夹对象,可由 closedir(),readdir() 和 rewinddir() 使用。

若成功,则该函数返回一个目录流,否则返回 false 以及一个 error。可以通过在函数名前加上 "@" 来隐藏 error 的输出。

readdir() 函数返回由 opendir() 打开的目录句柄中的文件名称。若成功,则该函数返回一个文件名,否则返回 false。

5、文件上传成功后要清除其所占用的内存,方法是使用imagedestroy()函数。详见手册

篇幅有点长,希望帮助到大家,让大家对PHP文件上传有更清楚的思路。

相关推荐:

php实现文件上传的示例代码分享

php网页常见文件上传功能的实现实例

用php实现常用文件上传类的方法

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal