5

当我ls -l在命令行中输入时,有时会在文件权限旁边出现一个@+符号(顺便说一句,我在 OS X 上),如下所示:

-rw-r-----@  1 john  staff      6731 Sep 28 01:10 mutations.txt
drwxr-xr-x+ 71 john  staff      2414 Mar 25 18:16 ..

我知道如何使用该stat结构获取权限位,但我认为这些扩展权限值不存在。有人可以指出我如何通过 C 或 POSIX API 获取这些值的正确方向吗?

编辑

我尝试了以下操作:

#include <sys/types.h>
#include <sys/xattr.h>
#include <sys/types.h>

int main () {
    char  l[1024];
    listxattr("/Users/john/desktop/mutations.txt", l, 1024,  XATTR_SHOWCOMPRESSION);

    printf("%s\n", l);
}

并得到输出:

com.apple.metadata:kMDItemWhereFroms

仍在尝试了解如何将其转换为@or +

4

2 回答 2

6

@表示文件具有扩展属性。用于listxattr()获取所有扩展属性的名称列表,并getxattr()获取特定属性的值。如果listxattr返回非零结果,您将显示@以表明这一点。

扩展属性不在 POSIX 中,但这个 API 至少在 Linux 和 OS X 中可用。

您可以在此处找到如何使用这些功能的示例。

+表示该文件具有访问控制列表。在某些文件系统中,这被存储为特殊的扩展属性;在其他情况下,它是单独存储的。有关访问控制列表,请参阅acl(5)参考资料,您可以在此处找到显示它的示例程序。

于 2016-03-25T22:50:44.017 回答
3

以下是我从 Apple 提供的官方实现中抓取的一些代码,ls您可以在此处找到。代码很长,所以 CMD + F 并搜索“printlong”。

#include <sys/types.h>
#include <sys/xattr.h>
#include <sys/types.h>
#include <sys/acl.h>
#include <stdio.h>

int main () {
    acl_t acl = NULL;
    acl_entry_t dummy;
    ssize_t xattr = 0;
    char chr;
    char * filename = "/Users/john/desktop/mutations.txt";

    acl = acl_get_link_np(filename, ACL_TYPE_EXTENDED);
    if (acl && acl_get_entry(acl, ACL_FIRST_ENTRY, &dummy) == -1) {
        acl_free(acl);
        acl = NULL;
    }
    xattr = listxattr(filename, NULL, 0, XATTR_NOFOLLOW);
    if (xattr < 0)
        xattr = 0;

    if (xattr > 0)
        chr = '@';
    else if (acl != NULL)
        chr = '+';
    else
        chr = ' ';

    printf("%c\n", chr);
 }

根据所使用的文件,输出将为空白、@ 或 +,其显示方式完全相同ls -l。希望这可以帮助 !

于 2016-03-26T03:40:17.437 回答