riverline/multipart-parser

一个用于解析具有编码和字符集支持的multipart内容的类库。

2.1.2 2024-03-12 16:46 UTC

README

PHP

什么是Riverline\MultiPartParser

Riverline\MultiPartParse是一个类库,用于解析multipart文档(multipart电子邮件、multipart表单等)并管理每个部分的编码和字符集以提取其内容。

需求

  • PHP >= 5.6

安装

Riverline\MultiPartParse与composer兼容,并支持任何psr-0/psr-4自动加载器。

composer require riverline/multipart-parser

用法

<?php

use Riverline\MultiPartParser\StreamedPart;

// Prepare a test stream
$data = <<<EOL
User-Agent: curl/7.21.2 (x86_64-apple-darwin)
Host: localhost:8080
Accept: */*
Content-Type: multipart/form-data; boundary=----------------------------83ff53821b7c

------------------------------83ff53821b7c
Content-Disposition: form-data; name="foo"

bar
------------------------------83ff53821b7c
Content-Transfer-Encoding: base64

YmFzZTY0
------------------------------83ff53821b7c
Content-Disposition: form-data; name="upload"; filename="text.txt"
Content-Type: text/plain

File content
------------------------------83ff53821b7c--
EOL;
$stream = fopen('php://temp', 'rw');
fwrite($stream, $data);
rewind($stream);

$document = new StreamedPart($stream);

if ($document->isMultiPart()) {
    $parts = $document->getParts();
    echo $parts[0]->getBody(); // Output bar
    // It decode encoded content
    echo $parts[1]->getBody(); // Output base64

    // You can also filter by part name
    $parts = $document->getPartsByName('foo');
    echo $parts[0]->getName(); // Output foo

    // You can extract the headers
    $contentDisposition = $parts[0]->getHeader('Content-Disposition');
    echo $contentDisposition; // Output Content-Disposition: form-data; name="foo"
    // Helpers
    echo StreamedPart::getHeaderValue($contentDisposition); // Output form-data
    echo StreamedPart::getHeaderOption($contentDisposition, 'name'); // Output foo

    // File helper
    if ($parts[2]->isFile()) {
        echo $parts[2]->getFileName(); // Output text.txt
        echo $parts[2]->getMimeType(); // Output text/plain
    }
}

转换器

该库还提供了三个转换器,用于快速解析PSR-7HttpFoundation和本地请求。

<?php

use \Riverline\MultiPartParser\Converters;

// Parse $_SERVER and STDIN
$document = Converters\Globals::convert();

向后兼容性

旧的Part解析器现在已弃用,并被一个包装类替代,该类从字符串内容创建一个临时流,并调用新的StreamedPart解析器。