>  기사  >  백엔드 개발  >  PHP 파일 업로드에 대한 자세한 소개

PHP 파일 업로드에 대한 자세한 소개

黄舟
黄舟원래의
2017-02-27 09:24:542429검색

먼저 이 장은 내용이 많고 상대적으로 어렵다는 점을 말씀드리고 싶습니다. 미묘한 부분도 놓치지 말고, 점점 더 많이 연습하는 것이 갈 길입니다.

배움은 산을 오르는 것과 같습니다. 먼저 작은 목표를 세우고 정상에 도달할 때까지 점점 더 높이 올라가야 합니다.

위의 두 가지 조언을 주의 깊게 고려하시기 바랍니다

1.

편집기: sublime text3(어떤 편집기를 사용하는지는 선호도에 따라 다름)

서버 구성: phpstudy2014를 사용하여 서버 구축 , 서버 내 컴퓨터 D 드라이브의 www 파일에 파일이 저장되어 있습니다. (phpstudy를 설치하면 www 파일이 자동으로 생성됩니다. 설치할 디스크를 결정하세요.) phpstudy를 실행하고 브라우저 주소 표시줄에 localhost를 입력하여 서버에 있는 파일에 액세스합니다.

파일 업로드 프로세스: 브라우저가 클라이언트에 파일을 업로드하고 제출을 클릭하면 파일이 처리를 위해 서버의 PHP 파일로 전송되고 PHP는 업로드된 파일을 저장합니다. 파일을 서버로.

2. 양식 만들기

양식에서 내 HTML 코드

PHP 파일 업로드에 대한 자세한 소개

enctype
을 확인하세요. 요소 구문에서 EncType은 제출된 데이터의 형식을 나타냅니다. Enctype 속성은 데이터를 서버로 다시 보낼 때 브라우저에서 사용하는 인코딩 유형을 지정합니다. enctype에는 세 가지 유형이 있습니다.

1. application/x-www-form-urlencoded: 양식 데이터가 이름/값 쌍으로 인코딩됩니다. 이는 표준 인코딩 형식입니다.

2. multipart/form-data: 양식 데이터는 메시지로 인코딩되며 페이지의 각 컨트롤은 메시지의 일부에 해당합니다.

3. 텍스트/일반: 양식 데이터는 컨트롤이나 서식 지정 문자 없이 일반 텍스트로 인코딩됩니다.

보충(한번 살펴보세요): ORM의 enctype 속성은 일반적으로 사용되는 두 가지 방법입니다: application/x-www-form-urlencoded 및 multipart/form-data. 애플리케이션/x- www-form-urlencoded. 작업이 get이면 브라우저는 x-www-form-urlencoded 인코딩 방법을 사용하여 양식 데이터를 문자열(name1=value1&name2=value2...)로 변환한 다음 해당 문자열을 URL 끝에 추가합니다. ?로 분할하고 이 새 URL을 로드합니다. 작업이 게시되면 브라우저는 양식 데이터를 http 본문으로 캡슐화한 다음 이를 서버로 보냅니다. type=file 컨트롤이 없으면 기본 application/x-www-form-urlencoded를 사용하세요. 그러나 type=file이 있으면 multipart/form-data가 사용됩니다. 브라우저는 전체 양식을 제어 단위로 나누고 Content-Disposition(양식-데이터 또는 파일), Content-Type(기본값은 text/plain), 이름(컨트롤 이름) 및 구분 기호 추가(경계)와 같은 정보를 추가합니다. .

좀 이해하기 어렵네요.

간단히 말해서 두 문장을 기억하세요. 입력 태그에 type=file이 있으면 enctype=multipart/form-data입니다. type=file이 없으면 일반적으로 application/x-www-form-urlencoded가 사용됩니다.

파일을 업로드할 때 데이터를 어느 정도 변환해야 서버에 업로드할 수 있습니다. application/x-www-form-urlencoded와 multipart/form-data의 차이점은 변환 인코딩입니다. 방법.

3. 업로드된 파일을 처리할 PHP 파일을 생성합니다.

PHP 파일 업로드에 대한 자세한 소개

파일 업로드 후 효과는 다음과 같습니다.

PHP 파일 업로드에 대한 자세한 소개

업로드된 각 파일에는 이름, 유형이 있습니다. , size , tmp_name 및 기타 정보. 파일이 업로드된 후 파일 관련 정보는 FILES 배열 변수에 저장됩니다. _FILES["myfile"]["name"]은 다차원 배열에 액세스하는 것과 같습니다. FILES는 먼저 myfile이라는 입력 형식으로 업로드된 파일 데이터를 얻은 다음 이름, 유형, 크기, 오류 및 기타 데이터에 액세스합니다. _FILES["myfile"]["error"]는 업로드된 파일 크기 제한을 초과하는 등 파일이 정상적으로 업로드되지 않는 상황을 처리하는 데 사용됩니다. FILES["myfile"]["error"]=0이면 파일이 정상적으로 업로드되었음을 의미합니다. _FILES["myfile"]["error"]>0은 파일이 정상적으로 업로드되지 않았음을 의미합니다.

FILES["myfile"]["error"]=1 업로드된 파일이 서버 공간 크기를 초과하는 등 서버 제한을 ​​초과했습니다. _FILES["myfile"]["error"]=2 $_FILES["myfile"]["error"]=3 파일의 일부만 업로드되는 브라우저 제한을 초과합니다

FILES["myfile " ]["error"]=4 업로드된 파일이 없습니다. _FILES["myfile"]["error"]는 5, 6, 7 또는 8일 수도 있습니다. 여기서는 자세히 설명하지 않겠습니다. 0보다 크면 업로드에 오류가 있다는 뜻입니다. 파일.

업로드 제한

보통 서버는 자신이 업로드하는 파일의 크기나 종류를 제한하는 경우가 많습니다. 위의 PHP 코드를 기반으로 업로드된 파일 코드에 대한 제한 사항을 추가합니다.

먼저 몇 가지 기능의 사용법을 숙지하세요.

폭발() 함수는 문자열을 분할하는 데 사용됩니다. 예를 들어, 폭발(".","aaa.HTML")은 문자열을 포인트 위치에서 "aaa"와 "HTML"이라는 두 개의 문자열로 나눕니다. 동일한 배열에 순차적으로 저장됩니다.

end()는 배열의 마지막 요소 값을 가져옵니다.

in_array()는 배열의 요소를 검색하여 해당 요소가 존재하는지 확인하고, 존재하지 않으면 false를 반환합니다.

<?php
//第一步:明确服务器规定上传至服务器的文件类型。这里我们只允许上传以下类型的图片。
$allowedExts = array("gif", "jpeg", "jpg", "png");// 允许上传的图片后缀
//第二部:获取上传的文件名称,通过explorde()函数将其分割成字符串形式的数组。
$temp = explode(".", $_FILES["myfile"]["name"]);
echo $_FILES["file"]["size"];

$extension = end($temp);   // end函数用于获取数组中最后一个元素的值。
//第三步:列出上传文件需要满足的条件
if ((($_FILES["myfile"]["type"] == "image/gif")
|| ($_FILES["myfile"]["type"] == "image/jpeg")
|| ($_FILES[myfile"]["type"] == "image/jpg")
|| ($_FILES["myfile"]["type"] == "image/pjpeg")
|| ($_FILES["myfile"]["type"] == "image/x-png")
|| ($_FILES["myfile"]["type"] == "image/png"))
&& ($_FILES["myfile"]["size"] < 204800)  // 小于 200 kb
&& in_array($extension, $allowedExts))
  //in_array表示在$allowedExts数组中查找$extension这个字符串
{
  if ($_FILES["myfile"]["error"] > 0)
  {
    echo "错误:: " . $_FILES["myfile"]["error"] . "<br>";
    //举个例子服务器空间不足,文件只能上传部分就会出现错误。
  }
  else
  {
    echo "上传文件名: " . $_FILES["myfile"]["name"] . "<br>";
    echo "文件类型: " . $_FILES["myfile"]["type"] . "<br>";
    echo "文件大小: " . ($_FILES["myfile"]["size"] / 1024) . " kB<br>";
    echo "文件临时存储的位置: " . $_FILES["myfile"]["tmp_name"] . "<br>";
  }
}
else
{
  echo "非法的文件格式";
}
?>


4. 업로드한 파일을 저장합니다

파일이 업로드된 후 임시 위치에 저장됩니다. 스크립트가 끝나면 사라집니다. 서버에 영구적으로 저장하려면 다른 위치에 저장해야 합니다.

.file_exists(“upload/” . FILES[“file”][“name”])은 파일이나 디렉터리가 존재하는지 확인합니다. .moveuploadedfile(_FILES["file"]["tmp_name"], "upload/" . $_FILES["myfile"]["name"]); 업로드된 파일을 임시 위치에서 서버 공간으로 이동합니다.

<?php
//第一步:明确服务器规定上传至服务器的文件类型。这里我们只允许上传以下类型的图片。
$allowedExts = array("gif", "jpeg", "jpg", "png");// 允许上传的图片后缀
//第二部:获取上传的文件名称,通过explorde()函数将其分割成字符串形式的数组。
$temp = explode(".", $_FILES["myfile"]["name"]);
echo $_FILES["myfilefile"]["size"];
$extension = end($temp);   // end函数用于获取数组中最后一个元素的值。
//第三步:列出上传文件需要满足的
if ((($_FILES["myfile"]["type"] == "image/gif")
|| ($_FILES["myfile"]["type"] == "image/jpeg")
|| ($_FILES["myfile"]["type"] == "image/jpg")
|| ($_FILES["myfile"]["type"] == "image/pjpeg")
|| ($_FILES["myfile"]["type"] == "image/x-png")
|| ($_FILES["myfile"]["type"] == "image/png"))
&& ($_FILES["myfile"]["size"] < 204800)  // 小于 200 kb
&& in_array($extension, $allowedExts))//in_array表示在$allowedExts数组中查找$extension这个字符串
{
  if ($_FILES["myfilefile"]["error"] > 0)
  {
    echo "错误:: " . $_FILES["myfile"]["error"] . "<br>";
  }
  else
  {
    echo "上传文件名: " . $_FILES["myfile"]["name"] . "<br>";
    echo "文件类型: " . $_FILES["myfile"]["type"] . "<br>";
    echo "文件大小: " . ($_FILES["myfile"]["size"] / 1024) . " kB<br>";
    echo "文件临时存储的位置: " . $_FILES["myfile"]["tmp_name"] . "<br>";

    // 判断当期目录(即www文件夹中)下的 upload 目录(自己创建,名字自取)是否存在该文件
    // 如果没有 upload 目录,你需要创建它,upload 目录权限为 777
    if (file_exists("upload/" . $_FILES["myfile"]["name"]))
    {
      echo $_FILES["myfile"]["name"] . " 文件已经存在。 ";
    }
    else
    {
      // 如果 upload 目录不存在该文件则将文件上传到 upload 目录下
      move_uploaded_file($_FILES["myfile"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);//
      echo "文件存储在: " . "upload/" . $_FILES["myfile"]["name"];
    }
  }
}
else
{
  echo "非法的文件格式";
}
?>

위 내용은 PHP 파일 업로드에 대한 자세한 소개입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!

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