在Drupal中,我首先对私人消息正文中出现的电子邮件进行序列化,并将它们存储在MySQL中,格式如下:
当我尝试恢复邮件时,电子邮件序列化失败,我使用以下方式进行恢复:
也许我序列化邮件的方式不正确?因为:
给出了 Array、Array、Array - 这意味着:
我曾经遇到过与这个情况非常相似的问题,反序列化无法正常工作,有些事情对我来说不太清楚,我需要学习一下。请问有人能确认或告诉我问题出在哪里吗?
注:以上代码仅凭记忆编写,可能不准确,因为我目前无法访问它。
function prvtmsg_list($body) {
$notify = array();
if (isset($body->emails)) {
$notify['mid'] = $body->mid;
$notify['emails'] = serialize($body->emails);
}
if (isset($body->vulgar_words) {
$notify['mid'] = $body->mid;
$notify['vulgar_words'] = serialize($message->vulgar_words);
}
if (isset($notify['mid'])) {
drupal_write_record('prvtmsg_notify', $notify);
}
}
当我尝试恢复邮件时,电子邮件序列化失败,我使用以下方式进行恢复:
function prvtmsg_list_notify() {
// Select fields from prvtmsg_notify and Drupal pm_message tables
$query = db_select('prvtmsg_notify', 'n');
$query->leftJoin('pm_message', 'm', 'n.mid = m.mid');
$query->fields('n', array('mid', 'emails', 'vulgar_words'));
$query->fields('m', array('mid', 'author', 'subject', 'body', 'timestamp'));
orderBy('timestamp', 'DESC');
$query = $query->extend('PagerDefault')->limit(20);
$result = $query->execute()->fetchAll();
$rows = array();
foreach ($result as $notify) {
$rows[] = array(
$notify->author,
$notify->subject,
implode(', ', unserialize($notify->emails)),
implode(', ', unserialize($notify->vulgar_words)),
);
}
$build = array();
$build['table'] = array(
'#theme' => 'table',
'#header' => array(
t('Author'),
t('Message subject'),
t('Emails captured'),
t('Vulgar Words Captured'),
),
'#rows' => $rows,
);
$build['pager']['#theme'] = 'pager';
return $build;
也许我序列化邮件的方式不正确?因为:
dpm(unserialize($notify->emails);
给出了 Array、Array、Array - 这意味着:
Array(
[0] => Array() [1] => Array() [2] => Array() [3] => Array()
)
令人惊讶的是,反序列化后的粗话显示正常!我不确定是否可以像这样序列化电子邮件:$notify['emails'] = serialize (array($body->emails));
我曾经遇到过与这个情况非常相似的问题,反序列化无法正常工作,有些事情对我来说不太清楚,我需要学习一下。请问有人能确认或告诉我问题出在哪里吗?
注:以上代码仅凭记忆编写,可能不准确,因为我目前无法访问它。