Also dont forget to LOAD mbstring before you load mailparse
example in the php.ini place in this order:
extension=php_mbstring.dll
extension=php_mailparse.dll
Or you will get an error.
Ian
LXXI. Funciones mailparse
Introducción
| Aviso |
Esta extensión es EXPERIMENTAL. Esto significa que el comportamiento de esta extensión, los nombre de sus funciones y en definitiva TODO lo documentado sobre esta extensión, puede cambiar en una futura versión de PHP SIN AVISO. La advertencia queda hecha, y utilizar esta extensión queda bajo su propia responsabilidad. |
This extension has been moved to the PECL repository and is no longer bundled with PHP as of PHP 4.2.0.
Instalación
Esta extension PECL no esta ligada a PHP. Mas informacion sobre nuevos lanzamientos, descargas ficheros de fuentes, informacion sobre los responsables asi como un 'CHANGELOG', se puede encontrar aqui: http://pecl.php.net/package/mailparse.
Para usar éstas funciones, es necesario compilar PHP con soporte mailparse mediante el uso de la opción de configuración --enable-mailparse.
Los usuarios de windows deben habilitar php_mailparse.dll al interior de php.ini para usar éstas funciones. Podeis descargar esta DLL de las extensiones PECL desde la pagina PHP Downloads o desde http://snaps.php.net/.
- Tabla de contenidos
- mailparse_determine_best_xfer_encoding -- Encuentra la mejor forma de codificar el contenido leído desde el apuntador de archivo fp, el cual debe tener capacidades de búsqueda
- mailparse_msg_create -- Devuelve un gestor que puede ser usado para procesar un mensaje
- mailparse_msg_extract_part_file -- Extrae/decodifica una sección de mensaje, operando sobre la codificación de transferencia
- mailparse_msg_extract_part -- Extrae/decodifica una sección de mensaje
- mailparse_msg_free -- Libera un gestor ubicado por mailparse_msg_create()
- mailparse_msg_get_part_data -- Devuelve una matriz asociativa de información sobre el mensaje
- mailparse_msg_get_part -- Devuelve un gestor sobre una sección dada en un mensaje mime
- mailparse_msg_get_structure -- Devuelve una matriz de nombres de sección mime en el mensaje dado
- mailparse_msg_parse_file -- Procesar un archivo y devolver un recurso que represente la estructura
- mailparse_msg_parse -- Procesar datos incrementalmente sobre un búfer
- mailparse_rfc822_parse_addresses -- Procesar direcciones y devolver una matriz asociativa que contenga los datos
- mailparse_stream_encode -- Secuencia datos desde un apuntador de archivo, codifica y escribe a fp_destino
- mailparse_uudecode_all -- Procesa los datos desde un apuntador a archivo y extrae cada archivo embebido con codificación uu
Example how to handle mail content from a variable:
<?php
$buffer = [...] // Mail Content from pipe or whatever
$mail = mailparse_msg_create();
mailparse_msg_parse($mail,$buffer);
$struct = mailparse_msg_get_structure($mail);
foreach($struct as $st) {
$section = mailparse_msg_get_part($mail, $st);
$info = mailparse_msg_get_part_data($section);
print_r($info);
}
?>
[Authors note:
The tarball for 4.2.x can be found here:
http://thebrainroom.com/opensource/php/mailparse.php
and contains a script called try.php that demonstrates the usage of these functions.
]
I've pasted the contents of the file below:
<?php
/*
* This is a simple email viewer.
* make sure that $filename points to a file containing an email message and
* load this page in your browser.
* You will be able to choose a part to view.
* */
$filename = "uumsg";
/* parse the message and return a mime message resource */
$mime = mailparse_msg_parse_file($filename);
/* return an array of message parts - this contsists of the names of the parts
* only */
$struct = mailparse_msg_get_structure($mime);
echo "<table>\n";
/* print a choice of sections */
foreach($struct as $st) {
echo "<tr>\n";
echo "<td><a href=\"$PHP_SELF?showpart=$st\">$st</a></td>\n";
/* get a handle on the message resource for a subsection */
$section = mailparse_msg_get_part($mime, $st);
/* get content-type, encoding and header information for that section */
$info = mailparse_msg_get_part_data($section);
echo "\n";
echo "<td>" . $info["content-type"] . "</td>\n";
echo "<td>" . $info["content-disposition"] . "</td>\n";
echo "<td>" . $info["disposition-filename"] . "</td>\n";
echo "<td>" . $info["charset"] . "</td>\n";
echo "</tr>";
}
echo "</table>";
/* if we were called to display a part, do so now */
if ($showpart) {
/* get a handle on the message resource for the desired part */
$sec = mailparse_msg_get_part($mime, $showpart);
echo "<table border=1><tr><th>Section $showpart</th></tr><tr><td>";
ob_start();
/* extract the part from the message file and dump it to the output buff
er
* */
mailparse_msg_extract_part_file($sec, $filename);
$contents = ob_get_contents();
ob_end_clean();
/* quote the message for safe display in a browser */
echo nl2br(htmlentities($contents)) . "</td></tr></table>";;
}
?>
