調用API函數NetShareAdd()將文件夾設置為共享,調用此函數后如果不做其他設置,網絡用戶是無法訪問共享文件夾的,因為此文件夾在NTFS分區中,同時受到NTFS文件系統的訪問控制,因此還需要第2步;
調用DOS命令cacls,賦予Guest用戶組讀寫權限;
如果要取消文件共享,直接調用API函數NetShareDel()
對于FAT32分區中文件夾,cacls命令是不起作用的,這個命令專用于NTFS格式下的文件和文件夾。也就是說上面這種解決方法的第步不能用了,那么現在只能使用NetShareAdd()函數添加文件共享。調用此函數后如果不做其他設置,網絡用戶可以訪問共享文件夾,但擁有完全控制權限(這是默認的共享權限設置),而在實際項目中我們希望能夠編程控制讀寫權限。在NTFS分區中,我們還有NTFS文件系統的訪問控制功能罩著,在FAT32分區中就只能依賴于操作系統文件夾共享自身的權限設置功能了。
1
NET_API_STATUS NetShareAdd(
2
_In_ LPWSTR servername,
3
_In_ DWORD level,
4
_In_ LPBYTE buf,
5
_Out_ LPDWORD parm_err
6
);
7
typedef struct _SHARE_INFO_2
{
8
LPWSTR shi2_netname;
9
DWORD shi2_type;
10
LPWSTR shi2_remark;
11
DWORD shi2_permissions;
12
DWORD shi2_max_uses;
13
DWORD shi2_current_uses;
14
LPWSTR shi2_path;
15
LPWSTR shi2_passwd;
16
} SHARE_INFO_2, *PSHARE_INFO_2, *LPSHARE_INFO_2; addShare.cpp
1
// 說明:
2
// FAT 系統調用此函數,shi502_permissions參數無效。有且僅有共享權限為最高權限。
3
// NTFS 系統調用此函數,請修改shi502_permissions參數,可使用如下權限:
4
// ACCESS_READ, ACCESS_WRITE, ACCESS_CREATE, ACCESS_EXEC
5
// ACCESS_DELETE, ACCESS_ATRIB, ACCESS_PERM, ACCESS_ALL
6
BOOL addShare(LPTSTR lpShareName, LPTSTR lpShareDir)
7

{
8
NET_API_STATUS res;
9
SHARE_INFO_502 p;
10
11
p.shi502_netname = lpShareName; //共享名
12
p.shi502_type = STYPE_DISKTREE;
13
p.shi502_remark = NULL;
14
p.shi502_permissions = ACCESS_ALL;
15
p.shi502_max_uses = SHI_USES_UNLIMITED; //最大鏈接數
16
p.shi502_current_uses = 0;
17
p.shi502_path = lpShareDir; //需要共享的路徑
18
p.shi502_passwd = NULL;
19
p.shi502_reserved = 0;
20
p.shi502_security_descriptor = NULL;
21
22
res = NetShareAdd(NULL, 502, (LPBYTE)&p, NULL);
23
24
if (NERR_Success == res)
25

{
26
printf("Share created.\n");
27
}
28
else
29

{
30
printf("NetShareAdd error: %u\n", res);
31
}
32
return (res==NERR_Success);
33
}
34
delShare.cpp