PHP讀取、解析eml文件及生成網(wǎng)頁的方法示例
本文實例講述了PHP讀取、解析eml文件及生成網(wǎng)頁的方法。分享給大家供大家參考,具體如下:
php讀取eml實例,本實例可以將導出eml文件解析成正文,并且可以將附件保存到服務器。不多說直接貼代碼了。
<?php
// Author: richard e42083458@163.com
// gets parameters
error_reporting(E_ALL ^ (E_WARNING|E_NOTICE));
header("Content-type: text/html; charset=utf-8");
echo "<pre>";
define(EML_FILE_PATH,'./yjdata/');
//if ($filename == '') $filename = '21724696_niuyufu@qiaodazhao.com_ZC4422-r7GMz_R9QF3K6XUhmJOXd4c.eml';
//if ($filename == '') $filename = '21724696_niuyufu@qiaodazhao.com_ZC3218-dGquMgm7ytdF6HQgpSReC4c.eml';
//if ($filename == '') $filename = '163.eml';
//if ($filename == '') $filename = '166.eml';
//if ($filename == '') $filename = 'nyf.eml';
//if ($filename == '') $filename = 'email_header_icon.eml';
if ($filename == '') $filename = '20141230133705.eml';
$eml_file = EML_FILE_PATH.$filename;
if (!($content = fread(fopen(EML_FILE_PATH.$filename, 'rb'), filesize(EML_FILE_PATH.$filename))))
die('File not found ('.EML_FILE_PATH.$filename.')');
//標題內(nèi)容
$pattern="/Subject: (.*?)\n/ims";
preg_match($pattern,$content,$subject_results);
$subject = getdecodevalue($subject_results[1]);
echo "標題:".$subject;
//發(fā)件人:
$pattern="/From: .*?<(.*?)>/ims";
preg_match($pattern,$content,$from_results);
$from = $from_results[1];
echo "\n\r";
echo "發(fā)件人:".$from;
//收件人:
$pattern="/To:(.*?):/ims";
preg_match($pattern,$content,$to_results);
$pattern="/<(.*?)>/ims";
preg_match_all($pattern,$to_results[1],$to_results2);
if(count($to_results2[1])>0){
$to = $to_results2[1];
}else{
$pattern="/To:(.*?)\n/ims";
preg_match($pattern,$content,$to_results);
$to = $to_results[1];
}
echo "\n\r";
echo "收件人:";
print_r($to);
echo "\n\r";
//正文內(nèi)容
$pattern = "/Content-Type: multipart\/alternative;.*?boundary=\"(.*?)\"/ims";
preg_match($pattern,$content,$results);
if($results[1]!=""){
$seperator = "--".$results[1];
}else{
die("boundary匹配失敗");
}
$spcontent = explode($seperator, $content);
$items = array();
$keyid = 0;
$email_front_content_array = array();
foreach($spcontent as $spkey=>$item) {
//匹配header編碼等信息
$pattern = "/Content-Type: ([^;]*?);.*?charset=(.*?)\nContent-Transfer-Encoding: (.*?)\n/ims";
preg_match($pattern,$item,$item_results);
if(count($item_results)==4){
$Content_code = str_replace($item_results[0],"",$item);
$item_results[4] = $Content_code;
if(trim($item_results[3])=="base64"){
$item_results[5] = base64_decode($item_results[4]);
}
if(trim($item_results[3])=="quoted-printable"){
$item_results[5] = quoted_printable_decode($item_results[4]);
}
$item_results[5] = mb_convert_encoding($item_results[5], 'UTF-8', trim($item_results[2]));
//echo $item_results[5];exit;
$email_front_content_array[] = $item_results;
}
}
foreach ($email_front_content_array as $email_front_content_each_key=>$email_front_content_each_value){
if($email_front_content_each_value[1]=='text/html'){
$content_html = $email_front_content_each_value[5];
break;
}else{
$content_html = $email_front_content_each_value[5];
}
}
echo "內(nèi)容:";
echo "\n\r";
echo $content_html;
echo "\n\r";
//附件內(nèi)容
$pattern = "/Content-Type: multipart\/mixed;.*?boundary=\"(.*?)\"/ims";
preg_match($pattern,$content,$results);
if($results[1]!=""){
$seperator = "--".$results[1];
$spcontent = explode($seperator, $content);
$items = array();
$keyid = 0;
$email_attachment_content_array = array();
foreach($spcontent as $spkey=>$item) {
//匹配header編碼等信息
$pattern = "/Content-Type: ([^;]*?);.*?name=(.*?)\nContent-Transfer-Encoding: (.*?)\nContent-Disposition: attachment;.*?filename=(.*?)\n/ims";
preg_match($pattern,$item,$item_results);
//print_r($item_results);
if(count($item_results)==5){
$Content_code = str_replace($item_results[0],"",$item);
$item_results[5] = trim($Content_code);
if(trim($item_results[3])=="base64"){
$item_results[6] = base64_decode($item_results[5]);
}
if(trim($item_results[3])=="quoted-printable"){
$item_results[6] = quoted_printable_decode($item_results[5]);
}
$item_results[7] = str_replace("\"","",getdecodevalue($item_results[2]));
$item_results[8] = str_replace("\"","",getdecodevalue($item_results[4]));
//保存附件內(nèi)容到服務器?
//符合規(guī)范的文件名時:有后綴名時。
if(strrpos($item_results[8], '.')!==false){
$ext = substr($item_results[8], strrpos($item_results[8], '.') + 1);
//$filename = "./yjdata/attachment/".date("YmdHis").mt_rand(10000,99999).".".trim($ext);
$attachment_filename = "./yjdata/attachment/".trim(str_replace("\"","",getbase64code($item_results[4]))).".".trim($ext);
mkdirs(dirname($attachment_filename));
$fp = fopen($attachment_filename, "w+");
if (flock($fp, LOCK_EX)) { // 進行排它型鎖定
fwrite($fp, $item_results[6]);
flock($fp, LOCK_UN); // 釋放鎖定
} else {
//echo "Couldn't lock the file !";
}
fclose($fp);
$item_results[9] = $attachment_filename;
$email_attachment_content_array[] = $item_results;
}
}
}
//print_r($email_attachment_content_array);
}
if(count($email_attachment_content_array)>0){
echo "附件:";
echo "\n\r";
//附件讀取
foreach($email_attachment_content_array as $email_attachment_content_each_key=>$email_attachment_content_each_value){
unset($email_attachment_content_each_value[5]);
unset($email_attachment_content_each_value[6]);
print_r($email_attachment_content_each_value[8]);
print_r($email_attachment_content_each_value[9]);
}
}
function getbase64code($content){
$pattern="/=\?GB2312\?B\?(.*?)\?=|=\?GBK\?B\?(.*?)\?=|=\?UTF-8\?B\?(.*?)\?=/ims";
preg_match($pattern,$content,$subject_results);
if($subject_results[1]!=""){
$subject = $subject_results[1];
$charset = "GB2312";
}
elseif($subject_results[2]!=""){
$subject = $subject_results[2];
$charset = "GBK";
}
elseif($subject_results[3]!=""){
$subject = $subject_results[3];
$charset = "UTF-8";
}else{
$subject = $content;
$charset = "";
}
return $subject;
}
function getdecodevalue($content){
$pattern="/=\?GB2312\?B\?(.*?)\?=|=\?GBK\?B\?(.*?)\?=|=\?UTF-8\?B\?(.*?)\?=/ims";
preg_match($pattern,$content,$subject_results);
if($subject_results[1]!=""){
$subject = base64_decode($subject_results[1]);
$charset = "GB2312";
}
elseif($subject_results[2]!=""){
$subject = base64_decode($subject_results[2]);
$charset = "GBK";
}
elseif($subject_results[3]!=""){
$subject = base64_decode($subject_results[3]);
$charset = "UTF-8";
}else{
$subject = $content;
$charset = "";
}
if($charset!=""){
$subject = mb_convert_encoding($subject, 'UTF-8', $charset);
}
return $subject;
}
function mkdirs($dir)
{
if(!is_dir($dir))
{
if(!mkdirs(dirname($dir))){
return false;
}
if(!mkdir($dir,0777)){
return false;
}
}
chmod($dir, 777); //給目錄操作權限
return true;
}
?>
有圖有真相:

附:完整實例代碼點擊此處本站下載。
更多關于PHP相關內(nèi)容感興趣的讀者可查看本站專題:《php文件操作總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語法入門教程》、《php面向?qū)ο蟪绦蛟O計入門教程》、《PHP網(wǎng)絡編程技巧總結(jié)》及《php字符串(string)用法總結(jié)》
希望本文所述對大家PHP程序設計有所幫助。
相關文章
php中convert_uuencode()與convert_uuencode函數(shù)用法實例
這篇文章主要介紹了php中convert_uuencode()與convert_uuencode函數(shù)用法,以實例形式了convert_uuencode()與convert_uuencode進行編碼與解碼的方法,是非常實用的技巧,需要的朋友可以參考下2014-11-11
PHP使用數(shù)組實現(xiàn)矩陣數(shù)學運算的方法示例
這篇文章主要介紹了PHP使用數(shù)組實現(xiàn)矩陣數(shù)學運算的方法,結(jié)合具體實例形式分析了php基于數(shù)組實現(xiàn)矩陣表示與運算的相關操作技巧,需要的朋友可以參考下2017-05-05

