Sdílet prostřednictvím


_access_s _waccess_s

Určuje oprávnění ke čtení a zápisu souborů.Toto je verze _access _waccess s vylepšení zabezpečení popsaným v Funkce zabezpečení v CRT.

errno_t _access_s( 
   const char *path, 
   int mode 
);
errno_t _waccess_s( 
   const wchar_t *path, 
   int mode 
);

Parametry

  • path
    Cesta k souboru nebo adresáře.

  • mode
    Nastavení oprávnění.

Vrácená hodnota

Funkce vrátí hodnotu 0, pokud má soubor daného režimu.Funkce vrátí kód chyby, pokud pojmenovaný soubor neexistuje nebo není k dispozici v daném režimu.V tomto případě funkce vrátí kód chyby takto ze sady a také nastaví errno na stejnou hodnotu.

  • EACCES
    Přístup byl odepřen.V souboru nastavení oprávnění neumožňuje zadaný přístup.

  • ENOENT
    Název souboru nebo cesta nebyla nalezena.

  • EINVAL
    Neplatný parametr.

Další informace naleznete v tématu Kód chyby, _doserrno, _sys_errlist a _sys_nerr.

Poznámky

Při použití se soubory, _access_s funkce určuje, zda zadaný soubor existuje a je přístupný jako určený hodnotou mode.Při použití adresáře, _access_s pouze určuje, zda zadaný adresář neexistuje.V Windows 2000 a novější operační systémy, všechny adresáře mají přístup Číst a zapisovat.

Hodnota režimu

Soubor kontroly

00

Pouze existence.

02

Oprávnění zapisovat.

04

Oprávnění pro čtení.

06

Oprávnění číst a zapisovat.

Oprávnění pro čtení nebo zápis souboru není dostatečně zajistit možnost otevření souboru.Například, pokud soubor je uzamčen jiným procesem, nemusí být přístupný i v případě _access_s vrátí hodnotu 0.

_waccess_sje verze celého znaku _access_s, kde path argument _waccess_s je řetězec znaků wide.Jinak _waccess_s a _access_s se chovají stejně.

Tyto funkce ověřit jejich parametrů.Pokud path je NULL nebo mode neurčuje platný režim vyvolat neplatný parametr popisovače, jak je popsáno v Ověření parametrů.Pokud je povoleno spuštění pokračovat, nastavit tyto funkce errno na EINVAL a vrátit se EINVAL.

Obecný Text rutinní mapování

Rutina Tchar.h

_UNICODE a _MBCS není definován

_MBCS, definice

_UNICODE, definice

_taccess_s

_access_s

_access_s

_waccess_s

Požadavky

Rutina

Požadované záhlaví

Volitelné záhlaví

_access_s

<io.h>

<errno.h>

_waccess_s

<wchar.h> nebo <io.h>

<errno.h>

Příklad

V tomto příkladu _access_s ke kontrole souboru s názvem crt_access_s.c, zda existuje a zda je povolen zápis.

// crt_access_s.c

#include <io.h>
#include <stdio.h>
#include <stdlib.h>

int main( void )
{
    errno_t err = 0;

    // Check for existence. 
    if ((err = _access_s( "crt_access_s.c", 0 )) == 0 )
    {
        printf_s( "File crt_access_s.c exists.\n" );

        // Check for write permission. 
        if ((err = _access_s( "crt_access_s.c", 2 )) == 0 )
        {
            printf_s( "File crt_access_s.c does have "
                      "write permission.\n" );
        }
        else
        {
            printf_s( "File crt_access_s.c does not have "
                      "write permission.\n" );
        }
    }
    else
    {
        printf_s( "File crt_access_s.c does not exist.\n" );
    }
}
  
  

Ekvivalent v rozhraní .NET Framework

System.IO.FileAccess

Viz také

Referenční dokumentace

Zpracování souborů

_access _waccess

_chmod _wchmod

_fstat, _fstat32, _fstat64, _fstati64, _fstat32i64, _fstat64i32

_open, _wopen

_stat funkce _wstat