0

0

Unicode 中的隐形字符:从零宽空格到不可见分隔符的完整指南

霞舞

霞舞

发布时间:2026-01-07 14:34:53

|

627人浏览过

|

来源于php中文网

原创

Unicode 中的隐形字符:从零宽空格到不可见分隔符的完整指南

本文详解 unicode 中多种隐形字符(如零宽空格 u+200b、零宽非连接符 u+200c 等)的特性、输入方法、编程处理技巧及实际应用注意事项,帮助开发者安全识别、插入与防御隐形字符风险。

Unicode 标准定义了大量视觉上不可见但具有语义或格式功能的字符,远不止普通空格(U+0020)。这些“隐形字符”在文本渲染中不显示图形符号,却可能影响排版、分词、比较、复制粘贴甚至安全逻辑——例如被用于混淆代码、绕过内容审核或构造隐蔽水印。

常见隐形 Unicode 字符一览

以下是最常用且具代表性的几类:

Beautiful.ai
Beautiful.ai

AI在线创建幻灯片

下载
Unicode 名称 作用说明 可视性
U+200B 零宽空格(Zero Width Space, ZWS) 允许断行,但不占空间;常用于长单词内软换行点 完全不可见,多数编辑器默认不渲染
U+200C 零宽非连接符(Zero Width Non-Joiner, ZWNJ) 阻止相邻字符连字(如阿拉伯文、梵文中) 不可见,无空白效果
U+200D 零宽连接符(Zero Width Joiner, ZWJ) 强制连接字符(如 emoji 组合 ?‍?) 不可见,仅影响渲染逻辑
U+2060 词连接符(Word Joiner) 类似 ZWS 但禁止断行,更“强硬”的连接控制 不可见,无空白
U+FEFF 字节顺序标记(BOM) 常见于 UTF-8/16 文件头,作为签名;若出现在文本中间则为“零宽不中断空格”(已弃用) 编辑器通常隐藏,但可能引发解析异常
✅ 提示:U+200B 是最常被用作“纯隐形占位符”的选择——它既不会产生空白间隙,也不会触发断行(除非上下文需要),因此比空格更“隐蔽”。

如何输入与验证隐形字符?

✅ 手动输入(Windows / macOS / Linux)

  • Windows:按住 Alt,输入 Unicode 十六进制码(需前置 0),再松开 Alt + 按 X。
    例如:输入 200B → 按 Alt+X → 得到 U+200B(需确保输入法为英文)。
  • macOS:启用「Unicode Hex Input」输入法后,按住 Option + 输入 200B。
  • VS Code / IntelliJ 等现代编辑器:启用「渲染不可见字符」功能(如 VS Code 设置 "editor.renderWhitespace": "all" 或安装插件 Highlight Bad Chars),可高亮显示 ZWS、ZWJ 等。

✅ 编程方式插入(Python 示例)

# 插入零宽空格
text = "Hello" + "\u200b" + "World"
print(repr(text))  # 'Hello\u200bWorld'
print(len(text))   # 11(比 "HelloWorld" 多 1)

# 批量检测文本中是否含隐形字符
invisible_ranges = [
    (0x200B, 0x200F),  # 零宽系列
    (0x202A, 0x202E),  # 方向覆盖控制符
    (0x2060, 0x2064),  # 词连接符等
    (0xFEFF, 0xFEFF),  # BOM
]

def has_invisible_char(s: str) -> bool:
    for ch in s:
        c = ord(ch)
        if any(start <= c <= end for start, end in invisible_ranges):
            return True
    return False

print(has_invisible_char("Hello\u200bWorld"))  # True

⚠️ 实际开发中的关键注意事项

  • 复制粘贴陷阱:网页中嵌入的隐形字符(如 invisiblecharacter.net 提供的)在复制时可能丢失或被编辑器过滤——并非所有环境都保留其原始编码
  • 字符串比较失效:"test" == "test\u200b" 返回 False,但肉眼无法分辨,易导致权限校验、哈希比对、白名单匹配等逻辑漏洞;
  • 正则与清洗盲区:\s(空白符)不匹配 U+200B 等零宽字符;需显式排除:
    [\u200B-\u200F\u202A-\u202E\u2060-\u2064\uFEFF]
  • 安全建议
    • 用户输入文本入库前,应调用 normalize('NFKC', text)(Python unicodedata)进行标准化,并可选移除零宽控制符;
    • 敏感字段(如用户名、token、命令参数)建议使用白名单正则(如 ^[a-zA-Z0-9_\-]+$)严格校验;
    • CI/CD 或代码审查中,可用工具(如 truffleHog, git-secrets 扩展)扫描隐形字符注入。

掌握隐形 Unicode 字符不是为了“隐藏”,而是为了看见不可见之处——在文本处理日益复杂的今天,它们既是排版利器,也是潜在的安全暗礁。合理识别、审慎使用、主动防御,方能在细节处守住系统稳健的底线。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

734

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

631

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

755

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1259

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

577

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

705

2023.08.11

java学习网站推荐汇总
java学习网站推荐汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

3

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.8万人学习

Git 教程
Git 教程

共21课时 | 2.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号