riverline / multipart-parser
一个用于解析具有编码和字符集支持的multipart内容的类库。
2.1.2
2024-03-12 16:46 UTC
Requires
- php: >=5.6.0
- ext-mbstring: *
Requires (Dev)
- laminas/laminas-diactoros: ^1.8.7 || ^2.11.1
- phpunit/phpunit: ^5.7 || ^9.0
- psr/http-message: ^1.0
- symfony/psr-http-message-bridge: ^1.1 || ^2.0
README
什么是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-7
、HttpFoundation
和本地请求。
<?php use \Riverline\MultiPartParser\Converters; // Parse $_SERVER and STDIN $document = Converters\Globals::convert();
向后兼容性
旧的Part
解析器现在已弃用,并被一个包装类替代,该类从字符串内容创建一个临时流,并调用新的StreamedPart
解析器。