>백엔드 개발 >PHP 튜토리얼 >PHP에서 원시 Multipart/Form-Data 데이터를 수동으로 구문 분석하는 방법은 무엇입니까?

PHP에서 원시 Multipart/Form-Data 데이터를 수동으로 구문 분석하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-02 18:39:03209검색

How to Manually Parse Raw Multipart/Form-Data Data in PHP?

PHP에서 원시 멀티파트/양식 데이터 데이터를 수동으로 구문 분석

멀티파트/양식 데이터 형식을 사용하여 HTTP PUT 요청의 데이터를 처리할 때, PHP는 원시 데이터를 자동으로 구문 분석하지 않습니다. 결과적으로 개발자는 이러한 요청에서 정보를 추출하는 데 어려움을 겪을 수 있습니다.

해결책:

  1. 원시 요청 데이터 읽기:

    • file_get_contents('php://input')를 사용하여 원시 데이터를 읽습니다.
  2. 콘텐츠 유형에서 경계 추출 헤더:

    • 정규식을 사용하여 Content-Type 헤더($_SERVER['CONTENT_TYPE'])에서 경계 값을 캡처합니다.
  3. 경계별로 데이터 분할:

    • preg_split("- $boundary")를 사용하여 원시 데이터를 개별 블록으로 분할합니다.
  4. 블록을 개별 필드로 분리:

    • 각 블록에 대해:

      • 업로드됨 파일:

        • application/octet-stream이 포함된 블록을 찾아 필드 이름과 파일 이름을 추출합니다.
      • 기타 필드:

        • 정규식을 사용하여 필드 이름과 값을 추출합니다.

示例 코드:

<code class="php">function parse_raw_http_request(array &$a_data)
{
  $input = file_get_contents('php://input');
  preg_match('/boundary=(.*)$/', $_SERVER['CONTENT_TYPE'], $matches);
  $boundary = $matches[1];

  $a_blocks = preg_split("/-+$boundary/", $input);
  array_pop($a_blocks);

  foreach ($a_blocks as $id => $block)
  {
    if (empty($block))
      continue;

    if (strpos($block, 'application/octet-stream') !== FALSE)
    {
      preg_match('/name=\&quot;([^\&quot;]*)\&quot;.*stream[\n|\r]+([^\n\r].*)?$/s', $block, $matches);
    }
    else
    {
      preg_match('/name=\&quot;([^\&quot;]*)\&quot;[\n|\r]+([^\n\r].*)?\r$/s', $block, $matches);
    }
    $a_data[$matches[1]] = $matches[2];
  }
}</code>

사용:

<code class="php">$a_data = array();
parse_raw_http_request($a_data);
var_dump($a_data);</code>

위 내용은 PHP에서 원시 Multipart/Form-Data 데이터를 수동으로 구문 분석하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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