Sublime如何快速将选中内容转为MD5/SHA1哈希?(安全校验)

2次阅读

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

Sublime如何快速将选中内容转为MD5/SHA1哈希?(安全校验)

sublime text 没有内置哈希计算功能

直接告诉你:Sublime Text 原生不支持对选中文本做 MD5/SHA1 计算。它不是安全工具,也不是命令行环境,所有哈希操作都得靠外部程序或插件桥接。

常见错误现象是:在菜单里翻半天找不到“Hash”“Digest”这类选项;或者装了某个叫 Hasher 的插件,结果发现只支持 Base64 或 CRC——压根不支持 SHA1/MD5。

  • 必须依赖系统命令行工具(如 md5sumshasumcertutil)或 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),哈希就全错。

text=ZqhQzanResources