imap_getmailboxes
(PHP 4, PHP 5, PHP 7, PHP 8)
imap_getmailboxes — Read the list of mailboxes, returning detailed information on each one
說明
$imap, string $reference, string $pattern): array|falseGets information on the mailboxes.
參數
- 
imap
- 
IMAP\Connection 實例。 
- 
reference
- 
      referenceshould normally be just the server specification as described in imap_open()警告Passing untrusted data to this parameter is insecure, unless imap.enable_insecure_rsh is disabled. 
- 
pattern
- 
      指定在郵箱層級的何處開始查詢。 在組成 pattern的字元中可使用兩個特殊字元: '*' 和 '%'。 '*' 是指返回所有郵箱目錄. 如果將 '*' 作為pattern參數時, 則會返回整個郵箱層級結構。 '%' 是指只返回目前級次。 '%' 作為pattern參數則只會返回頂層郵箱; '~/mail/%' 用於UW_IMAPD則會返回名為 ~/mail 的目錄, 但不包含其子目錄。
返回值
   Returns an array of objects containing mailbox information. Each
   object has the attributes name, specifying
   the full name of the mailbox; delimiter,
   which is the hierarchy delimiter for the part of the hierarchy
   this mailbox is in; and
   attributes. Attributes
   is a bitmask that can be tested against:
   
- 
     LATT_NOINFERIORS- This mailbox not contains, and may not contain any "children" (there are no mailboxes below this one). Calling imap_createmailbox() will not work on this mailbox.
- 
     LATT_NOSELECT- This is only a container, not a mailbox - you cannot open it.
- 
     LATT_MARKED- This mailbox is marked. This means that it may contain new messages since the last time it was checked. Not provided by all IMAP servers.
- 
     LATT_UNMARKED- This mailbox is not marked, does not contain new messages. If eitherMARKEDorUNMARKEDis provided, you can assume the IMAP server supports this feature for this mailbox.
- 
     LATT_REFERRAL- This container has a referral to a remote mailbox.
- 
     LATT_HASCHILDREN- This mailbox has selectable inferiors.
- 
     LATT_HASNOCHILDREN- This mailbox has no selectable inferiors.
false on failure.
  
 更新日誌
| 版本 | 說明 | 
|---|---|
| 8.1.0 | 現在 imap參數接受 IMAP\Connection
  實例,之前接受 資源(resource)。 | 
範例
示例 #1 imap_getmailboxes() example
<?php
$mbox = imap_open("{imap.example.org}", "username", "password", OP_HALFOPEN)
      or die("can't connect: " . imap_last_error());
$list = imap_getmailboxes($mbox, "{imap.example.org}", "*");
if (is_array($list)) {
    foreach ($list as $key => $val) {
        echo "($key) ";
        echo imap_utf7_decode($val->name) . ",";
        echo "'" . $val->delimiter . "',";
        echo $val->attributes . "<br />\n";
    }
} else {
    echo "imap_getmailboxes failed: " . imap_last_error() . "\n";
}
imap_close($mbox);
?>