问题描述
我的 mac.app 是通过 pakcages 分发成 .pkg 文件进行安装的。
用户安装后,在 /Applications 文件夹下,通过 ls -l 命令查看文件权限信息,他的 owner 和 group 分别是 mac 的当前用户 XXX 和 staff.
之后用户升级了系统,或变更了用户,触发了 owner 变为了 501
我查了一下,有终端命令可以修改文件的 file owner,但是对于整个 .app ,实际上是一整个文件夹。而且部分文件的 owner 是 root。
故障的现象是,如果我需要执行一些读写操作,就会产生闪退的错误。原因就是 file owner 已经不再是当前用户。
解决思路
问题的核心在于
- app 启动后如何检测到当前的 file owner 已经改变
- 发生改变之后,如何重新让 file owner 回归正常
代码实现思路:
启动后执行一段 shell 脚本,取出 file owner. 然后再通过 shell 命令获取当前用户信息,对整个 .app 文件进行授权。
cd /Applications/IGGVPNDialer.app/Contents/Resources
# 执行这句是一种取巧的方法。因为 mac.app 在文件系统里实际上是一个文件夹。无法通过命令查询整个 app 的 file owner.
# 但是任意的 mac.app 一定都会包含 AppIcon.icns 的
ls -l "AppIcon.icns"
执行结果是 -rw-r--r-- 1 501 staff 13029 Jun 3 2020 AppIcon.icns
实际上无法直接获取 501 这个值。(我也没找到对应的 shell 命令)
我的做法是 swift 中调用脚本后,获取到上面这串字符串,然后通过下列代码,拿到 501
let commandResult = "-rw-r--r-- 1 501 staff 13029 Jun 3 2020 AppIcon.icns"
let filter = commandResult.components(separatedBy: " ").filter { (string) -> Bool in // 过滤掉有干扰的单字符
return string != ""
}
let owner = filter[2]
- 接着通过
whoami
命令或echo $USER
拿到当前用户的 owner 作比较 - 执行这个代码完成重授权
sudo chown -R $USER /Applications/mac.app