目录搜索
文字
分享

imap_rfc822_parse_adrlist

(PHP 4, PHP 5, PHP 7)

imap_rfc822_parse_adrlistParses an address string

说明

array imap_rfc822_parse_adrlist ( string $address , string $default_host )

Parses the address string as defined in » RFC2822 and for each address.

参数

address

A string containing addresses

default_host

The default host name

返回值

Returns an array of objects. The objects properties are:

  • mailbox - the mailbox name (username)
  • host - the host name
  • personal - the personal name
  • adl - at domain source route

范例

Example #1 imap_rfc822_parse_adrlist() example

<?php

$address_string 
"Joe Doe <doe@example.com>, postmaster@example.com, root" ;
$address_array   imap_rfc822_parse_adrlist ( $address_string "example.com" );
if (!
is_array ( $address_array ) ||  count ( $address_array ) <  1 ) {
    die(
"something is wrong\n" );
}

foreach (
$address_array  as  $id  =>  $val ) {
    echo 
"#  $id \n" ;
    echo 
"  mailbox : "  $val -> mailbox  "\n" ;
    echo 
"  host    : "  $val -> host  "\n" ;
    echo 
"  personal: "  $val -> personal  "\n" ;
    echo 
"  adl     : "  $val -> adl  "\n" ;
}
?>

以上例程会输出:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

# 0

  mailbox : doe

  host    : example.com

  personal: Joe Doe

  adl     :

# 1

  mailbox : postmaster

  host    : example.com

  personal:

  adl     :

# 2

  mailbox : root

  host    : example.com

  personal:

  adl     :

参见

  • imap_rfc822_parse_headers() - Parse mail headers from a string

用户评论:

[#1] Ian Eiloart [2005-10-17 06:50:50]

This function does NOT test the syntax of either the local part, or the host part, it will permit illegal characters on either side. 

Note that 'host' refers to the email domain, not actually to any host.

The at domain list is an obsolete addressing method which was available for routing email. RFC2822 says that it must be accepted, but should be ignored in routing.

Note that if an address doesn't contain a personal part, or an "at domain list", that part of the array will be missing.

Although RFC2822 permits consecutive comma separators in a list of email addresses, this function does not. That's probably a bug.

In the following list of examples, #4 uses an "at domain list",  #5 and after are illegal domains, but only the last actually generates an error.

$adds = 'ian eiloart <iane@example.ac.uk>, 
        shuf6@example.ac.uk, 
        blobby, 
        "ian,eiloart"<ian@example.ac.uk>,
        <@example.com:foo@example.ac.uk>,
        foo@#,
        ian@-example.com,
        ian@one@two';
$add_arr = imap_rfc822_parse_adrlist($adds, 'example.com');
var_export ($add_arr);

array (
  0 => 
  class stdClass {
    var $mailbox = 'iane';
    var $host = 'example.ac.uk';
    var $personal = 'ian eiloart';
  },
  1 => 
  class stdClass {
    var $mailbox = 'shuf6';
    var $host = 'example.ac.uk';
  },
  2 => 
  class stdClass {
    var $mailbox = 'blobby';
    var $host = 'example.ac.uk';
  },
  3 => 
  class stdClass {
    var $mailbox = 'ian';
    var $host = 'example.ac.uk';
    var $personal = 'ian,eiloart';
  },
  4 => 
  class stdClass {
    var $mailbox = 'foo';
    var $host = 'example.ac.uk';
    var $adl = '@example.com';
  },
  5 => 
  class stdClass {
    var $mailbox = 'foo';
    var $host = '#';
  },
  6 => 
  class stdClass {
    var $mailbox = 'ian';
    var $host = '-example.com';
  },
  7 => 
  class stdClass {
    var $mailbox = 'ian';
    var $host = 'one';
  },
  8 => 
  class stdClass {
    var $mailbox = 'UNEXPECTED_DATA_AFTER_ADDRESS';
    var $host = '.SYNTAX-ERROR.';
  },
)

[#2] Rainer Perske [2005-01-04 08:20:49]

Invalid addresses, if detected, set host to '.SYNTAX-ERROR.'; but not all invalid addresses get detected as such, e.g. <.@host.do.main> is considered
valid though a single dot is not a valid local part without using quotation marks.

上一篇:imap_reopen下一篇:imap_rfc822_parse_headers