fopen() crée une ressource nommée, spécifiée par le paramètre filename, sous la forme d'un flux. Si filename est de la forme "protocole://...", filename est supposé être une URL, et PHP va rechercher un gestionnaire de protocole adapté pour lire ce fichier. Si aucun gestionnaire pour ce protocole n'est disponible, PHP va émettre une alerte qui vous permettra de savoir que vous avez des problèmes dans votre script, et il tentera d'exploiter filename comme un fichier classique.
Si PHP décide que le fichier filename est un fichier local, il va essayer d'ouvrir un flux avec ce fichier. Le fichier doit être accessible à PHP. Il vous faut donc vous assurer que vous avez les droits d'accès à ce fichier. Si vous activé le safe mode, ou la directive open_basedir, d'autres conditions peuvent aussi s'appliquer.
Si PHP a décidé que filename spécifie un protocole enregistré, et que ce protocole est enregistré comme un protocole réseau, PHP s'assurera que la directive allow_url_fopen est activée. Si elle est inactive, PHP va émettre une alerte, et l'ouverture va échouer.
Note : La liste des protocoles supportés est disponible Annexe I. Certains protocoles (appelé aussi wrappers ou gestionnaires) supportent des contexte et/ou des options dans le fichier php.ini. Référez vous aux pages du manuel traitant le protocole, pour connaître la liste des options qui sont disponibles. ( i.e. l'option de php.ini user_agent est utilisée par le gestionnaire http) Pour une description des contexts et du paramètre zcontext, voyez Référence CI, Flux.
mode peut prendre les valeurs suivantes :
'r' - Ouvre en lecture seule, et place le pointeur de fichier au début du fichier.
'r+' - Ouvre en lecture et écriture, et place le pointeur de fichier au début du fichier.
'w' - Ouvre en écriture seule; place le pointeur de fichier au début du fichier et réduit la taille du fichier à 0. Si le fichier n'existe pas, on tente de le créer.
'w+' - Ouvre en lecture et écriture; place le pointeur de fichier au début du fichier et réduit la taille du fichier à 0. Si le fichier n'existe pas, on tente de le créer.
'a' - Ouvre en écriture seule; place le pointeur de fichier à la fin du fichier file. Si le fichier n'existe pas, on tente de le créer.
'a+' - Ouvre en lecture et écriture; place le pointeur de fichier à la fin du fichier. Si le fichier n'existe pas, on tente de le créer.
Vous pouvez utiliser le troisième paramètre optionnel pour explorer le dossier include_path, en le mettant à 1.
Le paramètre optionnel zcontext est utilisé pour spécifier des paramètres d'optimisation et de callback.
Si l'ouverture échoue, fopen() retournera FALSE.
Si vous rencontrez des problèmes en lecture ou écriture de fichier et que vous utilisez PHP en version module de serveur, n'oubliez pas que les fichiers auxquels vous accédez ne sont pas nécessairement accessibles au processus serveur.
Sous Windows, assurez-vous de bien échapper les anti-slash utilisés dans le chemin du fichier, ou bien utilisez des slash.
Voir aussi Annexe I, fclose(), fgets(), fsockopen(), file(), file_exists(), is_readable(), socket_set_timeout() et popen().
Précédent | Sommaire | Suivant |
fnmatch | Niveau supérieur | fpassthru |