1

我正在通过我的应用程序将一些文件移动到 /Applications 目录,并使用 SMJobBless() 提升到管理员权限。

但是它会提示任何类型的帐户-admin 或standard_user 的管理员凭据,我们是否可以使用任何objective-c API 只为标准用户进行检查并要求管理员凭据?

编辑——如果有人尝试或完成了安装 Dropbox 的过程,那么 Dropbox 安装程序也会这样做(即,它只要求标准帐户的管理员权限,以便将其 .app 文件复制到 /Applications)。

4

1 回答 1

1

根据另一个问题的答案,我制作了一个似乎适合您的文件(我刚刚将它从 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

于 2015-07-20T22:26:43.057 回答