(PHP 4, PHP 5, PHP 7, PHP 8)
imap_search — Retourne un tableau de messages après recherche
$imap
,$criteria
,$flags
= SE_FREE
,$charset
= ""Effectue une recherche dans la boîte aux lettres courante, sur le flux IMAP courant.
Par exemple, pour rechercher les messages non répondus, envoyés par maman, vous pouvez utiliser : "UNANSWERED FROM maman". Les recherches semblent insensibles à la casse. Cette liste de critères est issue du code d'un client C UW et peut être incomplète ou imprécise. (voir aussi la » RFC1176, et en particulier, la section "tag SEARCH search_criteria").
imap
Une instance de IMAP\Connection.
criteria
Une chaîne de caractères, délimitée par des espaces, dans laquelle les mots-clés
suivants sont acceptés. Tous les arguments à plusieurs mots (e.g.
FROM "joey smith"
) doivent être placés entre guillemets.
Les résultats devront correspondre à toutes les entrées
criteria
.
flags
Les valeurs pour flags
sont SE_UID
, qui fait que le tableau réponse
contient les UID plutôt que les numéros de séquence.
charset
Jeu de caractères MIME à utiliser lors de la recherche de chaîne de caractères.
Retourne un tableau de numéro de messages ou d'UID.
Retourne false
si la recherche n'est pas comprise, ou bien qu'aucun
message n'a été trouvé.
Version | Description |
---|---|
8.1.0 |
La paramètre imap attend désormais une instance de
IMAP\Connection ; auparavant, une ressource imap était attendue.
|
Exemple #1 Exemple avec imap_search()
<?php
$imap = imap_open('{imap.example.com:993/imap/ssl}INBOX', 'foo@example.com', 'pass123', OP_READONLY);
$some = imap_search($imap, 'SUBJECT "HOWTO be Awesome" SINCE "8 August 2008"', SE_UID);
$msgnos = imap_search($imap, 'ALL');
$uids = imap_search($imap, 'ALL', SE_UID);
print_r($some);
print_r($msgnos);
print_r($uids);
?>
Résultat de l'exemple ci-dessus est similaire à :
Array ( [0] => 4 [1] => 6 [2] => 11 ) Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 [5] => 6 ) Array ( [0] => 1 [1] => 4 [2] => 6 [3] => 8 [4] => 11 [5] => 12 )