Peertalk是一个通过闪电/USB 电缆提供 Mac 和 iOS 设备之间通信的库。它通过执行以下操作建立连接:
struct sockaddr_un addr;
addr.sun_family = AF_UNIX;
strcpy(addr.sun_path, "/var/run/usbmuxd");
socklen_t socklen = sizeof(addr);
if (connect(fd, (struct sockaddr*)&addr, socklen) == -1) {
if (error) *error = [[NSError alloc] initWithDomain:NSPOSIXErrorDomain code:errno userInfo:nil];
return NO;
}
这在非沙盒应用程序中很好。在沙盒应用程序中,即使允许网络和 USB,它也会失败并显示 errno EPERM
- 操作不允许。
有什么方法可以让它在沙盒 Mac 应用程序中工作吗?
更新:
向 .entitlements
添加临时异常(exception)不起作用:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>com.apple.security.app-sandbox</key>
<true/>
<key>com.apple.security.network.client</key>
<true/>
<key>com.apple.security.network.server</key>
<true/>
<key>com.apple.security.temporary-exception.files.absolute-path.read-write</key>
<string>/var/run/usbmuxd</string>
</dict>
</plist>
最佳答案
不,这是不可能的。
我最终找到的解决方案是一个中继应用程序,用户可以手动下载并安装该应用程序作为非沙盒应用程序。主应用程序通过网络环回地址与中继通信,然后中继通过usbmuxd与设备通信。
关于ios - 我可以在沙盒 macOS 应用程序中使用 Peertalk 或 usbmuxd 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40999008/