1

ファイルに関するセキュリティ情報を収集し、それを人間が読める情報に変換するプログラムを作成しようとしています。ただし、構造体へのポインターの初期化で問題に直面しています。

#include <stdio.h>
#include <aclapi.h>
#pragma comment(lib, "advapi32.lib")
struct file_perms {
    char user_domain[2050];
    unsigned long user_mask;
};
static myfunc (){

PSECURITY_DESCRIPTOR pSD = NULL;
PACL pDACL = NULL;
char *file = "D:/code/test.c";
ACL_SIZE_INFORMATION aclSize;

ULONG result = GetNamedSecurityInfo(file,SE_FILE_OBJECT, DACL_SECURITY_INFORMATION, NULL, NULL, &pDACL, NULL, &pSD);
if (ERROR_SUCCESS != result) {
    printf( "GetNamedSecurityInfo Error %u\n", result );
}
if(pDACL != NULL){printf ("2\n");}
//ACL_SIZE_INFORMATION aclSize = {0};
ZeroMemory(&aclSize, sizeof(ACL_SIZE_INFORMATION));
    if(pDACL != NULL){   
        if(!GetAclInformation(pDACL, &aclSize, sizeof(aclSize),
            AclSizeInformation)){
            printf("GetAclInformation Error \n");
            return 0;
        }
        printf("AceCount %d\n",aclSize.AceCount);
    }
file_perms *fp = new file_perms[aclSize.AceCount];

}

コンパイル中に、次のエラーが発生します。getnamed.c

getnamed.c(34) : error C2065: 'file_perms' : undeclared identifier
getnamed.c(34) : error C2065: 'fp' : undeclared identifier
getnamed.c(34) : error C2065: 'new' : undeclared identifier
getnamed.c(34) : error C2106: '=' : left operand must be l-value
getnamed.c(34) : error C2146: syntax error : missing ';' before identifier 'file
_perms'
getnamed.c(34) : error C2065: 'file_perms' : undeclared identifier
getnamed.c(34) : error C2109: subscript requires array or pointer type

file_perms が宣言されていない識別子としてマークされている理由を誰かが理解するのを手伝ってくれますか? すでに構造体として宣言されていますが?

ご協力ありがとうございました。

4

3 に答える 3

2

コードを C コードとしてコンパイルしているためです。しかもC++です。

Cとしてコンパイルしたい場合は、これを試してください:

typedef struct file_perms_ {
    char user_domain[2050];
    unsigned long user_mask;
} file_perms;
于 2012-05-26T09:08:40.340 に答える
2

あなたが持っている必要があります

struct file_perms *fp = new file_perms[aclSize.AceCount];

または最初にタイプを作成します:

typedef struct file_perms {
    char user_domain[2050];
    unsigned long user_mask;
}file_perm;

後で次のように使用できます

file_perms *fp;
fp = (file_perms*)malloc(aclSize.AceCount * sizeof(file_perms));

ところで: operator newは純粋な C ではなく C++ 構文です。おそらく C++ コードを C としてコンパイルしようとしています。

于 2012-05-26T09:09:15.163 に答える
-1

変化する

struct file_perms{ 
    char user_domain[2050]; 
    unsigned long user_mask; 
}; 

これで問題が解決します:

struct{ 
    char user_domain[2050]; 
    unsigned long user_mask; 
}file_perms; 
于 2012-05-26T09:13:23.593 に答える