찾다
php教程php手册PHP와 서버 파일 시스템 간의 간단한 상호 작용

php.ini中关于文件上传的设置指令

文件上传过程

(1)上传文件提交表单html代码:

<!--向服务器上传文件的HTML表单(限制为文本文件)--> 
<!DOCTYPE html> 
<html lang="en"> 
<head> 
<meta charset="UTF-8"> 
<title>Adminstration - upoload new files</title> 
</head> 
<body> 
<h1 id="Upload-nbsp-new-nbsp-files">Upload new files</h1> 
<form action="upload.php" method="post" enctyple="multipart/form-data" > 
<!--enctyple:规定在发送到服务器之前对表单数据进行编码的方式(在上传控件时必须按照以上方式设置该属性)--> 
<div> 
<input type="hidden" name="MAX_FILE_SIZE" value="1000000">
 <!--规定传输文件的最大字节数-->
  <label for="userfile">Upload a file</label> 
  <!--在<label>内点击文本,会触发该控件,此时浏览器会自动对焦到标签for属性所指向的表单控件上面--> 
  <input type="file" name="userfile" id="userfile"> 
  <!--id属性为<label>标签for所指向控件元素的id号--> 
  <input type="submit" value="Send File"> 
  </div> 
  </form> 
  </body> 
  </html>

(2)php处理上传文件代码

①在php脚本中,需要处理的数据保存在超级变量数组$_FILES中,开启register_globals指令可以直接通过变量名访问这些信息;

②假如表单变量名为“username“则有:

$_FILES['userfile']['tmp_name']:储存文件在Web服务器中的临时保存位置;
$_FILES['userfile']['name']:储存用户系统中文件的名称;
$_FILES['userfile']['size']:储存文件的大小;
$_FILES['userfile']['type']:储存文件的类型;
$_FILES['userfile']['error]:储存任何与文件上传相关的错误代码;

错误类型说明:

UPLOAD_ERR_INI_SIZE:1,上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。
UPLOAD_ERR_FORM_SIZE:2,上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。
UPLOAD_ERR_PARTIAL:3,文件只有部分被上传。
UPLOAD_ERR_NO_FILE:4,没有文件被上传。
UPLOAD_ERR_NO_TMP_DIR:6,找不到临时文件夹。PHP 4.3.10 和 PHP 5.0.3 引进。
UPLOAD_ERR_CANT_WRITE:7,文件写入失败。PHP 5.1.0 引进。

③php代码

<?php 
//检验文件传输异常 
if($_FILES[&#39;userfile&#39;][&#39;error&#39;]>0){ 
echo &#39;Problem&#39;; 
switch($_FILES[&#39;userfile&#39;][&#39;error&#39;]){ 
case 1: echo &#39;File exceeded upload_max_filesize&#39;;break; 
case 2: echo &#39;File exceeded max_file_size&#39;;break; 
case 3: echo &#39;File only partially upload&#39;;break; 
case 4: echo &#39;No file uploaded&#39;;break; 
case 6: echo &#39;Cannot upload file: No temp directory specified&#39;;break; 
case 7: echo &#39;Upload failed:Cannot write to disk&#39;;break; 
} 
exit; 
} 
//检验传输的文件是否为文本文件 
if($_FILES[&#39;userfile&#39;][&#39;type&#39;] != &#39;text/plain&#39;){ 
echo &#39;Problem: file is not plain text&#39;; 
exit; 
} 
//将上传文件包含在服务器中/uploads/的目录下(该目录必须独立于Web文档树) 
$upfile = &#39;/uploads/&#39;.$_FILES[&#39;userfile&#39;][&#39;name&#39;]; //在指定目录下以传输文件的文件名创建一个新文件 
if(is_uploaded_file($_FILES[&#39;userfile&#39;][&#39;tmp_name&#39;])){ 
if(! move_uploaded_file($_FILES[&#39;userfile&#39;][&#39;tmp_name&#39;],$upfile)){ //将传输文件的临时文件移动到创建的新文件 
echo &#39;Problem: Could not move file to destination directory&#39;; 
exit; 
} 
} 
else{ 
echo &#39;Problem: Possible file upload attack.Filename:&#39;; 
echo $_FILES[&#39;username&#39;][&#39;name&#39;]; 
exit; 
} 
echo "File uploaded seuucessfully<br/><br/>"; 
//对传输文件清除html和php标记 
$contents = file_get_contents($upfile); //将文件内容提取为一个字符串; 
$contents = strip_tags($contents); //对该字符串擦除html和tags标记; 
file_put_contents($_FILES[&#39;userfile&#39;][&#39;name&#39;],$contents); //将该字符串重新写入文件中; 
//在浏览器上显示传输的文本文件内容 
echo "<p>Preview of uploaded file contents:<br/><hr>>"; 
echo nl2br($contents); 
echo "</br></hr>";

3、使用目录函数

(1)从目录中读取文件名

①使用opendir(),readdir(),closedir()函数;

<?php 
$current_dir = &#39;/uploads/&#39;; //创建目录url对象 
$dir = opendir($current_dir); //打开目录,结果返回一个目录对象 
echo "<p>Upload directory is $current_dir</p>"; 
echo "<p>Directory Listing:</p><ul>"; 
while(($file = readdir($dir)) !== false){ //读取目录对象 
if($file != "." && $file != ".."){ //过滤当前目录和上一级目录 
echo "<li>$file</li>"; 
echo "<a href=\"filedetails.php?file=\&#39;.$file.\&#39;\">".$file."</a><br/>"; 
} 
} 
echo "</ul>"; 
closedir($dir); //关闭目录; 
?>

②使用php的dir类

<?php 
$current_dir = &#39;/uploads/&#39;; //创建目录url对象 
$dir = dir($current_dir); //创建dir对象 
echo "<p>Handle is $dir->handle</p>"; 
echo "<p>Upload directory is $current_dir</p>"; 
echo "<p>Directory Listing:</p><ul>"; 
while(($file = $dir->read()) !== false){ //通过dir对象读取目录下的文件名 
if($file != "." && $file != ".."){ 
echo "<li>$file</li>"; 
} 
} 
echo "</ul>"; 
$dir->close(); //关闭目录 
?>

(2)使用scandir()函数对文本名称进行字母表的排序方式

<?php 
$current_dir = &#39;/uploads/&#39;; //创建目录url对象 
$files1 = scandir($current_dir); //将指定目录下的文件名保存为一个数组,默认以字母升序排序 
$files2 = scandir($current_dir,1); //将指定目录下的文件名保存为一个数组,以字母降序排序 
echo "<p>Upload directory is $current_dir</p>"; 
echo "<p>Directory Listing in alphabetical order,ascending:</p><ul>"; 
foreach($files1 as $file1) { 
if($file1 != "." && $file1 != "..") 
echo "<li>$file1</li>"; 
} 
echo "</ul>"; 
?>

(3)获取当前目录的其他信息

dirname($path):返回路径的目录部分;

basename($path):返回路径的名称部分;

disk_free_space($path):返回路径所在磁盘可以保存上传文件的容量;

(4)创建和删除目录

①mkdir():创建目录;

代码:

$oldumask = umask(0); //重置当前权限码
mkdir("/tmp/testing",0777); //创建目录
umask($oldumask); //恢复当前权限码

②rmdir():删除目录;

代码:

rmdir("/temp/testing");
或rmdir("c:\\tmp\\testing&#39;);

    ※要删除的目录必须是空目录;

4、与文件系统的交互

(1)获取文件信息:

while(($file = readdir($dir)) !== false){ 
echo "<a href=\"filedetails.php?file=\&#39;.$file.\&#39;\">".$file."</a><br/>";
}
<?php 
$current_dir = &#39;/uploads/&#39;; 
$file = basename($file); //获取文件文件名 
echo "<h1 id="Details-nbsp-of-nbsp-file">Details of file</h1>"; 
echo "<h2 id="File-nbsp-data">File data</h2>"; 
echo &#39;File last accessed: &#39;.date(&#39;j F Y H:i&#39;,fileatime($file))."<br>"; //返回最近访问的时间戳 
echo &#39;File last modifixed: &#39;.date(&#39;j F Y H:i&#39;,filemtime($file))."<br>"; //返回最近修改的时间戳 
$user = posix_getpwuid(fileowner($file)); //返回用户标识uid 
echo &#39;File owner: &#39;.$user[&#39;name&#39;]."<br/>"; 
$group = posix_getgrgid(filegroup($file)); //返回组织标识gid 
echo &#39;File group: &#39;.$group[&#39;name&#39;]."<br/>"; 
echo &#39;File permissions: &#39;.decoct(fileperms($file))."<br/>"; //返回8位的权限码 
echo &#39;File type&#39;.filetype($file)."<br/>"; //返回文件类型 
echo &#39;File size&#39;.filesize($file)."<br/>"; //返回文件字节数 
echo "<h2 id="File-nbsp-Tests">File Tests</h2>"; 
echo &#39;is_dir?&#39;.(is_dir($file) ? &#39;true&#39;:&#39;false&#39;)."<br/>"; 
echo &#39;is_executable?&#39;.(is_executable($file) ? &#39;true&#39;:&#39;false&#39;)."<br/>"; //判断文件是否可执行; 
echo &#39;is_file?&#39;.(is_file($file) ? &#39;true&#39;:&#39;false&#39;)."<br/>"; 
echo &#39;is_link?&#39;.(is_link($file) ? &#39;true&#39;:&#39;false&#39;)."<br/>"; 
echo &#39;is_readable?&#39;.(is_readable($file) ? &#39;true&#39;:&#39;false&#39;)."<br/>"; 
echo &#39;is_writable?&#39;.(is_writable($file) ? &#39;true&#39;:&#39;false&#39;)."<br/>"; 
?>

(2)更改文件属性

chgrp(file,group):修改文件的分组;

chmod(file,permissions):修改文件的权限;

chown(file,user):修改文件的所有者;

(3)创建、删除和移动文件

bool touch($filename,[int time,[ int atime]]):创建一个文件(time指定创建时间戳,atime指定可选时间戳)

unlink($filename):删除一个文件

copy($source_path,$destination_path):复制一个文件

rename($oldfile,$newfile):重命名一个文件;

(4)使用程序执行函数

①String exec(String command[ ,array result [ ,int result_value]])

返回命名结果的最后一行,result变量可以返回字符组数,这些字符串代表输出的每一行,result_value获取返回代码;

②void passthru(String command[ ,int result_value])

结果直接输出到浏览器;

③String system(string command[ ,int return_value])

输出结果到浏览器,返回命令结果的最后一行或false;

※在用户提交的数据包括执行命令的一部分,应该进行以下包装:

system(escapeshellcmd($command));

5、与环境变量交互

phpinfo()函数:获取php的所有变量列表;

getenv("$key_name"):

setenv("$key_name=$value");


성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.