NSJSONSerialization serialization of a string containing forward slashes / and HTML is escaped incorrectly
I believeNSJSONSerialization
is behaving as designed in regards to encoding HTML.
If you look at some questions (1, 2) on encoding HTML in JSON you'll see the answers always mention escaping the forward slashes.
JSON doesn't require forward slashes to be escaped, but HTML doesn't allow a javascript string to contain </
as it can be confused with the end of the <SCRIPT>
tag.
See the answers here, here and most directly the w3.org HTML4 Appendix which states in B.3.2 Specifying non-HTML data
ILLEGAL EXAMPLE:
The following script data incorrectly contains a "</" sequence (as part of "</EM>") before the SCRIPT end tag:
<SCRIPT type="text/javascript">
document.write ("<EM>This won't work</EM>")
</SCRIPT>
Although this behaviour may cause issues for you NSJSONSerialisation
is just playing by the age old rules of encoding HTML data for use in <SCRIPT>
tags.