我正在从Gmail帐户中检索XML ADF格式的电子邮件。我正在使用imap_body检索电子邮件。查看电子邮件帐户,我可以看到电子邮件以两种方式收到。第一个开始时:
<?xml version="1.0" encoding="UTF-8"?>
<?adf version="1.0"?>
<adf>
<prospect status="new">
<id sequence="1" source=...
第二种类型的开始如下:
<?xml version="1.0" encoding="UTF-8"?><?adf version="1.0"?><adf><prospect status="new"><id sequence="1" source=...
对于第二种类型,iMap_body返回已固定为75个字符。第75个字符被插入作为平等标志(=(。此外,在产生正常平等标志之后,添加字符3D:
<?xml version=3D"1.0" encoding=3D"UTF-8"?><?adf version=3D"1.0"?><adf><pros=
pect status=3D"new"><id sequence=3D"1" source=3D...
i可以使用第75个字符的循环校正字符串,但是如果第74个字符是一个相等的标志,则在非插入的平等标志之前插入相等符号和空间。
ex。
<name part=3D"full" type=
=3D"business"
这抛出了计数。我也要补偿这一点,但是如果可能的话,想在这里尝试修复实际的imap_body请求。
//Retrieve emails, make corrections if needed, convert to array
$inbox = imap_open($cred['host'],$cred['user'],$cred['pass']);
if(!$inbox){
$output = ['success' => false,'error' => "Unable to connect to host. ".imap_last_error()];
}else{
/* Get email list */
$emails = imap_num_msg($inbox);
/* Cycle through each email based on count */
if($emails > 0){
for($key = 1;$key <= $emails;$key++) {
/* Retrieve the email body */
$pull = imap_body($inbox,$key);
$init = str_replace(["r","n"],'',stripslashes($pull));
//Clears the breaks having the = character and clears the added characters 3D
if(substr($init,14,2) == "3D" && substr($init,75,1) == "="){
$max = strlen($init);
$cnt = 75;//First = character occurance
while($cnt < $max){
$init = substr($init,0,$cnt).substr($init,$cnt + 1);//remove =
$cnt += 75;//Set for next iteration
}
$init = str_replace("3D",'',$init);//Remove additional
}
$data = simplexml_load_string($init);
$xml[$key] = json_decode(json_encode($data),true);
}
}
}
第二种电子邮件需要进行更正,但由于电子邮件的双重相等/空间问题,因此将关闭。由于这些问题,sumplexml_load_string失败了。同样,从imap_body进行纠正将是理想的,否则我将继续进行更正,希望不会有更多类型的问题。
这是一个引用的可打印编码问题