sublime text 原生不支持 md5/sha1 哈希计算,需通过 build system 调用系统命令(如 md5sum、shasum)或 python 脚本实现;推荐使用 python 方案以规避跨平台差异与编码问题。

Sublime Text 没有内置哈希计算功能
直接告诉你:Sublime Text 原生不支持对选中文本做 MD5/SHA1 计算。它不是安全工具,也不是命令行环境,所有哈希操作都得靠外部程序或插件桥接。
常见错误现象是:在菜单里翻半天找不到“Hash”“Digest”这类选项;或者装了某个叫 Hasher 的插件,结果发现只支持 Base64 或 CRC——压根不支持 SHA1/MD5。
- 必须依赖系统命令行工具(如
md5sum、shasum、certutil)或 Python 脚本中转 - Windows/macOS/Linux 的命令名和参数差异大,硬写死会跨平台失效
- 插件若调用
subprocess但没处理编码(比如中文路径或非 UTF-8 终端),容易卡住或输出乱码
推荐方案:用 Sublime 的 Build System 调用系统命令
这是最轻量、最可控的方式,不用装插件,也不依赖网络或第三方服务。关键在于把选中内容临时写入标准输入,交给系统命令处理。
以 macOS/Linux 为例,在 Sublime 中新建 Build System(Tools → Build System → New Build System),填入:
{
"cmd": ["sh", "-c", "cat | md5sum | cut -d' ' -f1"],
"selector": "text.plain",
"working_dir": "$file_path",
"variants": [
{
"name": "SHA1",
"cmd": ["sh", "-c", "cat | shasum -a 1 | cut -d' ' -f1"]
}
]
}
保存为 Hash.sublime-build。之后选中文本 → Ctrl+Shift+P → 输入 Build With: Hash 即可出 MD5;选 Build With: Hash: SHA1 就是 SHA1。
- Windows 用户需改用
certutil -hashfile,但该命令不接受 stdin,得先写临时文件再读取,步骤更繁琐 -
cut -d' ' -f1是为了去掉命令默认输出的空格和破折号,只留哈希值本身 - 如果选中内容含换行符,
cat仍能正确处理;但若含控制字符(如 \x00),部分系统命令会截断,此时建议切到 Python 方案
更稳的替代:用 Python 构建快速哈希命令
当系统命令不可靠(比如 Windows 无 shasum、旧版 macOS 缺 md5sum),或需要统一行为时,Python 是最兼容的选择。Sublime 原生支持 Python 构建系统。
新建一个 PyHash.sublime-build,内容如下:
{
"cmd": ["python3", "-c", "import sys, hashlib; s=sys.stdin.read().encode(); print(hashlib.md5(s).hexdigest() if sys.argv[1]=='md5' else hashlib.sha1(s).hexdigest())", "md5"],
"selector": "text.plain",
"variants": [
{
"name": "MD5",
"cmd": ["python3", "-c", "import sys, hashlib; s=sys.stdin.read().encode(); print(hashlib.md5(s).hexdigest())", "md5"]
},
{
"name": "SHA1",
"cmd": ["python3", "-c", "import sys, hashlib; s=sys.stdin.read().encode(); print(hashlib.sha1(s).hexdigest())", "sha1"]
}
]
}
这个方案绕过了 shell 差异,也避免了临时文件权限问题。
- 必须确保系统 PATH 中有
python3;若只有python,把命令里的python3全换成python - 注意
.encode()—— 不加这句,中文或 emoji 会报UnicodeEncodeError - Mac 用户若用 Homebrew 安装的 Python,可能需要写绝对路径如
/opt/homebrew/bin/python3
别踩这些坑
实际用起来,最容易卡在三件事上:编码、空格、上下文。
- 选中内容末尾自带换行?多数哈希命令会把它算进去。如果校验目标字符串不含换行,就得先用
rstrip()处理,否则哈希值对不上 - Build System 默认不捕获选中内容——必须确保你是在「有选中文本」状态下按
Ctrl+B,否则它会去哈希整个文件 - 某些插件(如
Text Pastry)会干扰选区行为;如果突然发现哈希结果变长了,先关掉其他插件试试 - 安全校验场景下,别用哈希值反推原文——MD5/SHA1 已不适用于密码存储,仅适合完整性比对
真正麻烦的从来不是怎么算哈希,而是确保输入字节流和你要校验的目标完全一致。多一个空格、少一个 BOM、换行符类型不同(CRLF vs LF),哈希就全错。










