根据另一个问题的答案,我制作了一个似乎适合您的文件(我刚刚将它从 C 翻译为 Objective-C 并删除了 printf;原始链接在答案的末尾)。
NSPrivileges.h
#import <Foundation/Foundation.h>
@interface NSPrivileges : NSObject
+(BOOL)hasAdminPrivileges;
@end
NSPrivileges.m
#import "NSPrivileges.h"
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <strings.h>
#include <pwd.h>
#include <grp.h>
@implementation NSPrivileges
+(BOOL)hasAdminPrivileges{
uid_t current_user_id = getuid();
struct passwd *pwentry = getpwuid(current_user_id);
struct group *grentry = getgrgid(getgid());
struct group *admin_group = getgrnam("admin");
while(*admin_group->gr_mem != NULL) {
if (strcmp(pwentry->pw_name, *admin_group->gr_mem) == 0) {
return YES;
}
admin_group->gr_mem++;
}
return NO;
}
@end
现在,您只需要将 NSPrivileges.h 导入到需要知道用户是否为管理员的文件中,然后使用命令[NSPrivileges hasAdminPrivileges]
查找(它将返回 a BOOL
,因此很容易处理)。希望对您有所帮助。
这是我的参考:
Objective C and OS user type