>백엔드 개발 >PHP 튜토리얼 >php 파일 업로드

php 파일 업로드

不言
不言원래의
2018-06-04 17:21:152450검색

정말로 PHP 파일 업로드 기술을 마스터하셨나요? 이 글은 모든 사람을 위한 PHP 파일 업로드에 대한 관련 정보를 정리한 것입니다. 관심 있는 친구들이 참고할 수 있습니다.

먼저 이 장에는 내용이 많고 어렵다는 점을 알려드립니다. 자기 자신과 죽음에 맞서 싸우는 태도. 미묘한 부분도 놓치지 말고, 점점 더 많이 연습하는 것이 갈 길입니다.
배움은 산을 오르는 것과 같습니다. 먼저 작은 목표를 세우고 꾸준히 노력하여 정상에 도달하세요.
위의 두 가지 조언을 주의 깊게 고려하시기 바랍니다.

1. 나의 준비에 대한 설명.

Editor: sublime text3 (어떤 편집기를 사용하는지는 선호도에 따라 다름)
서버 구성: phpstudy2014를 사용하여 서버를 구축하며, 서버 파일은 D 드라이브의 www 파일에 저장됩니다. 내 컴퓨터의. (phpstudy를 설치하면 www 파일이 자동으로 생성됩니다. 설치할 디스크를 결정하세요.) phpstudy를 실행하고 브라우저 주소 표시줄에 localhost를 입력하여 서버에 있는 파일에 액세스합니다.
파일 업로드 프로세스: 브라우저가 클라이언트에 파일을 업로드하고 제출을 클릭하면 파일이 처리를 위해 서버의 PHP 파일로 전송되고 PHP는 업로드된 파일을 서버에 저장합니다.

2. 양식 만들기

내 HTML 코드를 참조하세요

enctype

Form 요소의 구문에서 EncType은 전송 시 제출된 데이터의 형식을 나타냅니다. 데이터를 서버로 다시 보냅니다. enctype에는 세 가지 유형이 있습니다.
1.application/x-www-form-urlencoded: 양식 데이터는 이름/값 쌍으로 인코딩됩니다. 이는 표준 인코딩 형식입니다.
2. multipart/form-data: 양식 데이터는 메시지로 인코딩되며 페이지의 각 컨트롤은 메시지의 일부에 해당합니다.
3. 텍스트/일반: 양식 데이터는 컨트롤이나 서식 지정 문자 없이 일반 텍스트로 인코딩됩니다.
보충 사항(한번 살펴보세요): ORM의 enctype 속성은 일반적으로 사용되는 두 가지 방법입니다: application/x-www-form-urlencoded 및 multipart/form-data. -양식-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 파일을 만듭니다.

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

업로드된 각 파일에는 이름, 유형, 크기, 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 코드를 기반으로 업로드된 파일 코드에 대한 제한 사항을 추가합니다.
먼저 여러 함수의 사용법을 숙지하세요:
explode()이 함수는 문자열을 분할하는 데 사용됩니다. 예: 폭발(".","aaa.HTML")은 문자열을 "aaa"와 " HTML로 나눕니다. " 두 개의 문자열이 있는 경우 두 문자열이 동일한 배열에 순서대로 저장됩니다.
end()배열의 마지막 요소 값을 가져옵니다.
in_array() 배열의 요소를 검색하여 존재하는지 확인합니다. 존재하면 true를 반환하고 존재하지 않으면 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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