gpt4 book ai didi

objective-c - 监控沙盒应用程序中的文件夹

转载 作者:行者123 更新时间:2023-12-03 16:58:06 25 4
gpt4 key购买 nike

我如何监视用户垃圾箱,以便在添加文件时我可以发送操作。

提前致谢!

最佳答案

沙盒应用程序无法访问垃圾箱。沙盒应用程序出于安全原因而被沙盒化,垃圾箱中可能包含用户已删除的所有类型的文档,而沙盒应用程序在其以前的目的地中永远无法访问这些文档。当然,用户希望这些文件在放入垃圾箱后仍能保存。

如果您的应用程序访问垃圾箱确实有意义,例如因为它是一个垃圾管理应用程序(我知道这是一个愚蠢的例子),如果您只要求的话,Apple 仍然会授予您的应用程序访问垃圾箱的权限。因此,您需要指定一个临时异常权利,无论是哪种类型

com.apple.security.temporary-exception.files.home-relative-path.read-only

如果只读访问权限对您来说足够了或者

com.apple.security.temporary-exception.files.home-relative-path.read-write

如果您还需要写访问权限。这些是权利字典中的键,值是一个字符串数组,每个字符串指定一个目录。在你的情况下,它们数组将包含 /.Trash ,翻译为 /Users/<username>/.Trash对于当前用户。例如:

<key>com.apple.security.temporary-exception.files.home-relative-path.read-write</key>
<array>
<string>/.Trash</string>
</array>

只要您的应用程序仅访问此目录(或其子目录),这将允许您的应用程序部分地从其沙箱中释放。

请注意,Apple 只会批准在 App Store Connect 中列出的某些条件下使用临时异常(exception)权利之一的应用程序。网页端(您必须登录才能看到该端,并且您需要具有使用 App Store Connect 权限的 Apple ID)。

据我所知,这些条件包括您必须使用 Apple's Feedback Assistant 提交错误报告(同样,你必须登录到网页端,但这一次每个 Apple ID 都被允许登录)并且你必须向 Apple 解释为什么你需要这个异常(exception),否则你的应用程序将无法执行其应该执行的操作。你最好好好解释一下!如果 Apple 认为您的用例不合法,他们会将此错误视为无效而关闭,然后您提交的应用程序将被拒绝。如果错误被认为是有效的,则您必须在提交应用程序时告知 Apple 您的应用程序使用临时权利,并且必须向 Apple 指出您创建的错误报告。他们会再次阅读该内容,如果商店团队同意开发团队的观点,认为这是一个有效的理由,他们将允许您的提交通过。

一旦您的应用程序拥有适当的权利,您应该能够像非沙盒应用程序一样监视垃圾箱。例如。使用FSEvent API 。具有功能FSEventStreamCreate()您可以创建一个 FSEventStreamRef它监视某个路径(在您的例子中是垃圾箱),每当该路径上的内容发生变化时调用用户定义的回调函数,并且可以在 RunLoop 上进行调度。一旦安排好,每当目录内容发生变化时,就会调用回调函数。在回调函数中你可以做任何你想做的事情,例如获得更高级别的事件(因为回调函数只是普通的 C,所以您可能想要发布一个可以在 Obj-C 代码中处理的 NSNotification,例如在 UI 代码中)或者直接调用 Obj-C 方法某个对象(存储在回调上下文中、全局变量或可作为单例访问等)

关于objective-c - 监控沙盒应用程序中的文件夹,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14446787/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com