Tracking via pasted text
Plain text steganography and how it can be used against youZero-width characters can be used to embed hidden information inside of plain text. This is of primary concern to journalists and their sources, but it can affect anyone browsing the Internet. For example, a page can be dynamically generated server-side to include, between every few words:
- your username, if logged in
- your IP address
- the current timestamp
By copying text from the page and pasting it somewhere public, you would be revealing this information to anyone who knew how to look for it. Details and demo in this article:
To check if your browser displays zero-width characters, see the zero-width character test.
Other plain text watermarking techniques / canary traps are explained on Zach Aysan's blog:
- Zero-Width Characters: Invisibly fingerprinting text (2017)
- Text Fingerprinting Update: Stories and ideas from readers (2018)
To fingerprint text, server software could embed a hidden number between every few words, matching a log entry that contains information about the visitor (username, IP address, cookie, browser details, referrer link, timestamp). For easily finding pasted excerpts online, the software could similarly hide a static page-specific identifier within the text, that can later be put into search engines.
To achieve this, aside from zero-width characters, the software could use some of the other techniques described by Zach Aysan: "differences in dashes (en, em, and hyphens), quotes (straight vs curly), word spelling (color vs colour), and the number of spaces after sentence endings", different types of spaces, homoglyphs (a vs а), diacritic forms (ț vs ţ), ligatures (fi vs fi, Ⅳ vs IV, ½ vs 1/2), as well as inserting hard to detect typos into the text. However, zero-with characters are by far the most potent technique, since they can be used to encode any number of bits between any two visible characters.
Solutions
A partial solution is to convert the text to ASCII, if language allows. There are also tools such as:
- bat - displays all zero-width characters when used with the "-A" option.
- cat - displays all zero-width characters when used with the "-v" option.
- Less (CLI) - displays most zero-width characters when used with the "-U" option.
- SafeText (CLI) - also detects some homoglyphs. It started out well, but development has stopped; in its current state, there are many problematic characters that it does not detect - see issues.
- Several browser extensions that detect a few zero-width characters.
However, they don't protect against the more sophisticated versions of this hack. A more complete tool would have to include not just a list of forbidden/allowed characters, but also a a spellchecker and a way to detect trailing whitespace - an x-ray mode that might be triggered when dubious text is detected in the clipboard. And not just text, image-based steganography can be used in a similar way. A technical solution might never be perfect, but it could cover the vast majority of cases.
An almost perfect non-technical solution is to retype the text. You can also try downloading the page twice from different accounts / IP addresses and diff the two versions, or check if the hashes match. Another solution is to take a screenshot of the text and run it through OCR software.
Tools for text steganography
- StegCloak
- Spam Mimic (see Encode -> Alternate encodings)
- zwfp
- SNOW
- Snow10
- WORDLISTTEXTSTEGANOGRAPHY & EMAILSTEGANO
- inØsight — Zero Width Obfuscation (extension for Firefox and Chromium)
- Zero Width Shortener - Shorten URLs using invisible spaces
Further reading
Text steganography
- Text based steganography (Robert Lockwood and Kevin Curran, 2017)
- Text Steganography with Multi level Shielding (Sharon Rose Govada et al., 2012) [PDF]
- Any efficient text-based steganographic schemes? (crypto.stackexchange.com)
- Steganography to hide text within text (security.stackexchange.com)
- Chaffing and winnowing (Wikipedia)
Control characters
- Zero-width space (Wikipedia)
- Article explaining the role of a few zero-width characters
- Partial list of Unicode spaces
- Unicode control characters (Wikipedia)
- Tags (Unicode block) (Wikipedia)
- Unicode Character Database
- ANSI Terminal security in 2023 and finding 10 CVEs