.\" -*- coding: UTF-8 -*- .\" Copyright 1993 David Metcalfe (david@prism.demon.co.uk) .\" and Copyright (C) 2007, 2012 Michael Kerrisk .\" .\" %%%LICENSE_START(VERBATIM) .\" Permission is granted to make and distribute verbatim copies of this .\" manual provided the copyright notice and this permission notice are .\" preserved on all copies. .\" .\" Permission is granted to copy and distribute modified versions of this .\" manual under the conditions for verbatim copying, provided that the .\" entire resulting derived work is distributed under the terms of a .\" permission notice identical to this one. .\" .\" Since the Linux kernel and libraries are constantly changing, this .\" manual page may be incorrect or out-of-date. The author(s) assume no .\" responsibility for errors or omissions, or for damages resulting from .\" the use of the information contained herein. The author(s) may not .\" have taken the same level of care in the production of this manual, .\" which is licensed free of charge, as they might when working .\" professionally. .\" .\" Formatted or processed versions of this manual, if unaccompanied by .\" the source, must acknowledge the copyright and authors of this work. .\" %%%LICENSE_END .\" .\" References consulted: .\" Linux libc source code .\" Lewine's "POSIX Programmer's Guide" (O'Reilly & Associates, 1991) .\" 386BSD man pages .\" Modified Sat Jul 24 19:30:29 1993 by Rik Faith (faith@cs.unc.edu) .\" Modified Fri Feb 14 21:47:50 1997 by Andries Brouwer (aeb@cwi.nl) .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH GETENV 3 "15 septembre 2017" GNU "Manuel du programmeur Linux" .SH NOM getenv, secure_getenv \- Lire une variable d'environnement .SH SYNOPSIS .nf \fB#include \fP .PP \fBchar *getenv(const char *\fP\fIname\fP\fB);\fP .PP \fBchar *secure_getenv(const char *\fP\fIname\fP\fB);\fP .fi .PP .RS -4 Exigences de macros de test de fonctionnalités pour la glibc (consulter \fBfeature_test_macros\fP(7))\ : .RE .PP \fBsecure_getenv\fP()\ : _GNU_SOURCE .SH DESCRIPTION La fonction \fBgetenv\fP() recherche dans la liste des variables d'environnement une variable nommée \fIname\fP, et renvoie un pointeur sur la chaîne \fIvalue\fP correspondante. .PP La fonction \fBsecure_getenv\fP() spécifique à GNU est simplement comme \fBgetenv\fP(), à la différence qu'elle renvoie NULL dans les cas où «\ secure execution\ » (exécution sécurisée) est nécessaire. L'exécution sécurisée est nécessaire si l'une des conditions suivantes était vraie quand le programme exécuté pour le processus appelant a été chargé\ : .IP * 3 l'UID effectif du processus ne correspondait pas à son UID réel, ou le GID effectif du processus ne correspondait pas à son GID réel (c'est typiquement le cas lors de l'exécution d'un programme Set\-UID ou Set\-GID)\ ; .IP * le bit de capacité effective a été défini sur le fichier exécutable\ ; .IP * le processus a une capacité non vide permise définie. .PP L'exécution sécurisée pourrait aussi être nécessaire si elle est déclenchée par certains modules de sécurité Linux. .PP La fonction \fBsecure_getenv\fP() a pour but d'être utilisée dans les bibliothèques polyvalentes pour éviter les vulnérabilités qui pourraient survenir si des programmes Set\-UID ou Set\-GID faisaient accidentellement confiance à l'environnement. .SH "VALEUR RENVOYÉE" La fonction \fBgetenv\fP() renvoie un pointeur sur la valeur correspondante de l'environnement ou NULL s'il n'y a pas de correspondance. .SH VERSIONS \fBsecure_getenv\fP() a été introduite dans la glibc dans sa version\ 2.17. .SH ATTRIBUTS Pour une explication des termes utilisés dans cette section, consulter \fBattributes\fP(7). .TS allbox; lbw25 lb lb l l l. Interface Attribut Valeur T{ \fBgetenv\fP(), \fBsecure_getenv\fP() T} Sécurité des threads MT\-Safe env .TE .SH CONFORMITÉ \fBgetenv\fP()\ : POSIX.1\-2001, POSIX.1\-2008, C89, C99, SVr4, 4.3BSD. .PP \fBsecure_getenv\fP() est une extension GNU. .SH NOTES Les chaînes dans la liste des variables d'environnement sont de la forme \fInom=valeur\fP. .PP Telle qu'elle est généralement implémentée, \fBgetenv\fP() renvoie un pointeur vers une chaîne de la liste d'environnement. L'appelant doit faire attention à ne pas modifier cette chaîne car cela modifierait l'environnement du processus. .PP L'implémentation de \fBgetenv\fP() ne nécessite pas qu'elle soit réentrante. La chaîne pointée par la valeur de retour de \fBgetenv\fP() peut être allouée statiquement et peut être modifiée par un appel ultérieur à \fBgetenv\fP(), \fBputenv\fP(3), \fBsetenv\fP(3) ou \fBunsetenv\fP(3). .PP Le mode «\ secure execution\ » (exécution sécurisée) de \fBsecure_getenv\fP() est contrôlé par l'attribut \fBAT_SECURE\fP contenu dans le vecteur auxiliaire passé du noyau à l'espace utilisateur. .SH "VOIR AUSSI" \fBclearenv\fP(3), \fBgetauxval\fP(3), \fBputenv\fP(3), \fBsetenv\fP(3), \fBunsetenv\fP(3), \fBcapabilities\fP(7), \fBenviron\fP(7) .SH COLOPHON Cette page fait partie de la publication\ 5.10 du projet \fIman\-pages\fP Linux. Une description du projet et des instructions pour signaler des anomalies et la dernière version de cette page peuvent être trouvées à l'adresse \%https://www.kernel.org/doc/man\-pages/. .PP .SH TRADUCTION La traduction française de cette page de manuel a été créée par Christophe Blaess , Stéphan Rafin , Thierry Vignaud , François Micaux, Alain Portal , Jean-Philippe Guérard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas François , Florentin Duneau , Simon Paillard , Denis Barbier et David Prévot . .PP Cette traduction est une documentation libre ; veuillez vous reporter à la .UR https://www.gnu.org/licenses/gpl-3.0.html GNU General Public License version 3 .UE concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE. .PP Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à .MT debian-l10n-french@lists.debian.org .ME .