a creare un file utilizzando il codice qui sotto:aperti i permessi dei file() non correttamente l'impostazione
#include <stdio.h>
#include <stdlib.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <errno.h>
#include <fcntl.h>
#include <unistd.h>
int main()
{
const char* filename = "./test.out";
int fd;
if(-1 == (fd = open(filename, O_CREAT|O_RDWR, 0666)))
{
perror("Error");
errno = 0;
}
else
puts("File opened");
if(-1 == (close(fd)))
{
perror("Error");
errno = 0;
}
else
puts("File closed");
return 0;
}
ho specificare l'argomento mode
come 0666
, che dovrebbe concedere leggere, scrivere l'accesso a tutti. Tuttavia, un ls -l
mostra
-rw-r--r-- 1 kmehta users 0 2012-01-29 16:29 test.out
Come si può vedere, scrivere autorizzazioni vengono concesse solo per il proprietario del file. Non so perché a tutti gli altri non sono concesse le autorizzazioni correttamente. chmod a+w test.out
imposta le autorizzazioni correttamente però.
codice compilato come gcc -Wall test.c
Spec: gcc v 4.5.0 in openSUSE 11.3 a 64 bit
controllare umask. controlla umask. – wildplasser
Hai provato a utilizzare le costanti per i flag, ad es. S_IRUSR, S_IRGRP, ecc.? – dasblinkenlight
@dasblinkenlight L'uso delle costanti non ha aiutato. Era un problema di umask, usando fchmod dopo l'apertura del file ora come mostrato nella risposta – jitihsk