来自沙盒帮助应用程序的NSTask失败并显示“无法设置沙箱配置文件数据”

时间:2013-11-04 09:57:00

标签: macos nstask appstore-sandbox

我正在开发一个由主应用程序和帮助程序组成的Mac OS应用程序:

Backup.app/
└── Contents
    ├── Library
    │   └── LoginItems
    │       └── BackupHelper.app
    ├── MacOS
    │   └── Backup

Backup.app :要求用户选择路径并保存应用范围的安全书签。 BackupHelper.app :备份此路径。

Backup.app和BackupHelper.app都是沙箱 backupHelper应用程序已注册,使用SMLoginItemSetEnabled登录时启动。

当BackupHelper.app需要访问Backup.app保存的书签时,
我希望它调用Backup.app(带有一些参数)来获得最终的NSURL(带有applesecurityscope参数的NSURL)

我尝试使用NSTask启动Backup.app, 它以NSTaskTerminationReasonUncaughtSignal终止 我得到了这个堆栈跟踪:

Process:         Backup [18095]
Path:            /Applications/Backup.app/Contents/MacOS/Backup
Identifier:      Backup
Version:         1.0 (1)
Code Type:       X86-64 (Native)
Parent Process:  BackupHelper [18093]
Responsible:     BackupHelper [18093]
User ID:         501

Date/Time:       2013-11-04 10:23:06.016 +0100
OS Version:      Mac OS X 10.9 (13A603)
Report Version:  11
Anonymous UUID:  84A150C3-31C4-BE29-AAC9-338910633B1C

Crashed Thread:  0  Dispatch queue: com.apple.main-thread

Exception Type:  EXC_BAD_INSTRUCTION (SIGILL)
Exception Codes: 0x0000000000000001, 0x0000000000000000

Application Specific Information:
Could not set sandbox profile data: Operation not permitted (1)

Application Specific Signatures:
SYSCALL_SET_PROFILE

Thread 0 Crashed:: Dispatch queue: com.apple.main-thread
0   libxpc.dylib                       0x00007fff9079c5a1 _xpc_runtime_init_once + 2482
1   libdispatch.dylib                  0x00007fff8e59c2ad _dispatch_client_callout + 8
2   libdispatch.dylib                  0x00007fff8e59c21c dispatch_once_f + 79 

当我尝试直接启动Backup.app时,它工作正常 当我尝试使用相同的NSTask启动另一个应用程序时,它也能正常工作。 你知道为什么它没有专门用于Backup.app吗?

谢谢!

0 个答案:

没有答案