我正在写一个命令行工具。在这里,我想在/Users/user_name/Library目录中创建一个目录。当我以root身份从Terminal运行该程序时,一切正常,但问题是当我想要使用该工具作为cups的后端时(当我打印一些东西时,该程序也被称为root )。程序被调用,但在system.log文件中我发现错误: sandboxd: deny file-write-*。我是一个新的Mac程序员,我不确定如何解决这个问题。有人能帮我吗?
发布于 2012-02-16 14:05:22
由于雪豹cups是在一个沙盒中运行,以防止其行为不端-如访问用户的家。根据你的OS版本,你可以使用另一个目录,而不是用户的家。在Lion上,它甚至比这更严格。沙箱规则是内置在cups二进制文件中的(与sb脚本相反),因此您唯一的幸运之处可能是将cups替换为一个专门允许访问沙箱中所需内容的版本(如果您确实想访问沙箱中所需的内容,那么规则由cups/scheduler/process.c中的cupsdCreateProfile定义)。AFAICT在你的应用程序中你什么也做不了,因为沙箱的设计就是为了阻止你想要做的事情。
另一种选择是不以root身份运行cups,因为沙箱仅在cups以root身份运行时使用。
https://stackoverflow.com/questions/9297007
复制相似问题