我想从文件中读取一些文本并使用它写入到另一个open(),read()和write().
这是我open()的文件写入(我想创建一个新文件并写入其中):
fOut = open ("test-1", O_RDWR | O_CREAT | O_SYNC);
这是将文件权限设置为我根本不理解的东西.这是输出ls -l:
---------T 1 chaitanya chaitanya 0 2010-02-11 09:38 test-1
甚至读取权限也被锁定.我试着寻找这个,但找不到任何东西.奇怪的是,write()仍然成功地将数据写入文件.
另外,如果我做'chmod 777 test-1',事情就会再次开始正常工作.
有人可以让我知道我在公开电话中哪里出错吗?
谢谢!
供您参考,我已粘贴以下完整程序:
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
int main () {
    char buffer[512], ch;
    int fIn, fOut, i;
    ssize_t bytes;
    FILE *fp = NULL;
    //open a file
    fIn = open ("test", O_RDONLY);
    if (fIn == -1) {
        printf("\nfailed to open file.");
        return 1;
    }
    //read from file
    bytes =  read (fIn, buffer, sizeof(buffer));
    //and close it
    close (fIn);
    printf("\nSuccessfully read %d bytes.\n", bytes);
    //Create a new file
    fOut = open ("test-1", O_RDWR | O_CREAT | O_SYNC);
    printf("\nThese are the permissions for test-1\n");
    fflush(stdout);
    system("ls -l test-1");
    //write to it and close it.
    write (fOut, buffer, bytes);
    close (fOut);
    //write is somehow locking even the read permission to the file. Change it.
    system("chmod 777 test-1");
    fp = fopen ("test-1", "r");
    if (fp == NULL) {
        printf("\nCan't open test-1");
        return 1;
    }
    while (1)
    {
        ch = fgetc(fp);
        if (ch == EOF)
            break;
        printf("\n%c", ch);
    }
    fclose (fp);
    return 0;
}
Ant*_*ima 79
open()接受第三个参数,即权限集,即
open(filename, O_RDWR|O_CREAT, 0666)
0666是八进制数,即6中的每一个对应于三个许可位
6 = rw
7 = rwx
这是一个典型的陷阱.编译器允许您保留权限参数,因为当您打开现有文件时,权限位没有意义.但是当你在创建文件时忘记了参数时,你会获得一组随机的权限,例如你的情况下的0000(---).
阅读http://linux.die.net/man/2/open似乎你错过了modeopen 的参数:
当O_CREAT在标志中时,必须指定mode,否则忽略.参数模式指定在创建新文件时使用的权限.
这个问题最近帮助了我,所以我想尽我所能来增加一些关于发生了什么的深度.就像之前所说的那样,你错过了第三个参数open().但是,您看到的权限不是随机的; 他们来自堆栈.请查看以下代码段:
    asm("push $0");
    asm("push $0");
    asm("push $0");
    fd = open("base", O_RDWR|O_CREAT);
请注意以下结果:
    ----------. 1 user user 4 Feb 26 08:21 base
让我们将第一次推送更改为1,即执行权限:
    asm("push $1;push $0;push $0");
    fd = open("base", O_RDWR|O_CREAT);
我们得到:
    ---------x. 1 user user 4 Feb 26 08:25 base
将推送更改为4,即读取权限,并将其他两个值弄乱:
    asm("push $4;push $5;push $6");
    fd = open("base", O_RDWR|O_CREAT);
我们得到:
    -------r--. 1 user user 4 Feb 26 08:27 base
因此,我们可以看到从堆栈中弹出的第三个值(首先推送)才是真正重要的.最后为了好玩,我们可以尝试5然后50,分别导致:
    -------r-x. 1 user user 4 Feb 26 08:27 base
    ----rw----. 1 user user 4 Feb 26 08:28 base
希望这增加了一些清晰度!
小智 5
实际上umask()只过滤权限而不设置它们。典型umask()值是0002(“不要放弃对世界的写权限”),如果您的模式值open( "file", O_CREAT, 0777)授予所有权限,则生成的文件将775作为其权限。
| 归档时间: | 
 | 
| 查看次数: | 75961 次 | 
| 最近记录: |