【问题标题】:How To Do Privilege Elevation on OSX with Objective C如何使用 Objective C 在 OSX 上进行特权提升
【发布时间】:2016-07-16 04:32:55
【问题描述】:

我在 Mac OSX 上使用 Objective C 制作的基于 Cocoa 的自定义 setup.app 需要安装 LaunchDaemon 来执行提升权限的任务,例如需要扫描整个硬盘驱动器并因此需要 root 权限的防病毒程序。如何让我的设置应用程序提示客户进行管理员登录,然后将该 LaunchDaemon 安装到 /Library/LaunchDaemons 中(注意我不是指 ~/Library/LaunchDaemons)?

我目前处理它的方式是使用具有管理员权限的 AppleScript。它提示此登录,然后 AppleScript 将复制到此文件夹中,而操作系统不会抱怨。但是,我认为这不是正确的技术——我应该以某种方式完全在 Objective C 中执行此操作?

请注意,在这种情况下我不能使用 SMBlessJob,因为正是出于这个原因,我首先创建了启动守护程序。

背景信息

我特别需要创建一个自定义 setup.app——就像诺顿的 AV 应用程序使用自定义 setup.app 一样。这是因为 Apple PKG 和 DMG 安装程序不允许在安装过程中从服务器下载非常大的文件(如病毒定义)并提供某种友好的反馈。我的意思是,当运行 Perl 脚本或 Bash 脚本时,我可以让 PKG 文件从服务器下载文件,但是安装程序只会在下载所需的分钟数内挂起进度条,而不给任何其他反馈用户除了挂起的进度条,所以用户认为安装程序坏了,其实不是。这就是为什么我必须制作自己的自定义 setup.app,就像 Norton 为他们的 AV 应用程序所做的那样。

【问题讨论】:

  • 当用户提供其凭据时,用户安装的 pkg 将获得管理员权限。它还可以包含安装前和安装后脚本。使用包安装程序中的脚本来安装守护进程,复制相关的 plist 并开始运行。
  • 但这会卡在需要 10 分钟的非常大的下载中。它有效,但对于正在发生的事情提供了较差的可见进展。试试看,你会看到的。这就是我制作自定义设置应用程序的原因,就像 Symantec/Norton 对他们的应用程序所做的那样。
  • 我不建议使用脚本下载,而是安装守护程序应用程序,然后它会为您下载。

标签: objective-c macos installation elevated-privileges launch-daemon


【解决方案1】:

通常情况下,SMJobBless 将是执行此操作的技术。这是 Apple 在 2016 年现在推荐的。这是 Apple 示例项目的 readme.txt:

https://developer.apple.com/library/mac/samplecode/SMJobBless/Listings/ReadMe_txt.html

但是,这不是唯一的方法。另一种方法是让您的安装程序使用 AppleScript 来提示并运行具有提升权限的 Bash 或 Perl 脚本来安装 LaunchDaemon。 (这实际上比 SMJobBless 更容易。)

基本上,任何一种技术都会将 LaunchDaemon(例如“服务”)安装到一个特殊文件夹中,并且可以使用提升的权限设置该守护程序,然后它可以运行您想要的任何东西——甚至是命令行命令。 LaunchDaemons 和 LaunchAgents 的超棒解释在这里:

http://launchd.info/

现在,问题是安装后如何从您的应用程序与其通信。他们将其留给您,并且有各种技术。但是,他们也让您自己来保护它,以免它成为攻击媒介。

关于如何进行 IPC(应用程序和此服务之间的进程间通信)的精彩文章在这里:

http://nshipster.com/inter-process-communication/

OSX 上的一个 IPC 协议是分布式对象,从架构的角度来看它非常流畅——您会觉得它更像是“编码”,而不是像其他 IPC 协议那样“来回发送消息”。我已经为此写了Stack Overflow post,因为文档质量低劣,Apple 网站上的现有示例和其他示例已经过时(无法在 OSX 10.10+ 的 XCode7.1 上编译)。

在您的应用程序和守护程序/服务之间的通信协议上,您可能会使用 AES256 和长密码加密并转换为 Base64 编码的键/值、XML 或 JSON 消息,然后使用其中一种各种IPC机制。但是,这完全是另一个话题。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2015-01-11
    • 1970-01-01
    • 2016-07-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多