- Dowload an example implementation at http://www.webfan.de/install/
- Example
- Current Version
<?php
$vm = \webfan\MimeStubAPC::vm();
// echo print_r($vm, true);
$newFile = __DIR__. DIRECTORY_SEPARATOR . 'TestMimeStubAPC.php';
$a = <<<PHPE
echo ' TEST-modified.';
PHPE;
$stub = $vm->get_file($vm->document, '$HOME/index.php', 'stub index.php')
// ->clear()
->append($a)
;
$vm->to('[email protected]');
$vm->from('me@localhost');
$stub->from('[email protected]');
$vm->location = $newFile;
require $newFile;
$run($newFile);
Riverline\MultiPartParse
is a one class lib to parse multipart document ( multipart email, multipart form, etc ...) and manage each part encoding and charset to extract their content.
- PHP 5.3 or HHVM
Riverline\MultiPartParse
is compatible with composer and any prs-0 autoloader.
composer require riverline/multipart-parser
<?php
use Riverline\MultiPartParser\Part;
$content = <<<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;
$document = new Part($content);
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 Part::getHeaderValue($contentDisposition); // Output form-data
echo Part::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
}
}