diff options
author | hackademix | 2019-05-28 00:48:00 +0200 |
---|---|---|
committer | hackademix | 2019-05-28 01:35:44 +0200 |
commit | 37d148e3af8f33f9a8b89ebc392b869c30dafb54 (patch) | |
tree | 14fc40b04e29e45fac42cb309c22a880f479063e /src/xss | |
parent | c2f0ce0dfc8fcb514b620c75415601c78eb8c669 (diff) | |
download | noscript-37d148e3af8f33f9a8b89ebc392b869c30dafb54.tar.gz noscript-37d148e3af8f33f9a8b89ebc392b869c30dafb54.tar.xz noscript-37d148e3af8f33f9a8b89ebc392b869c30dafb54.zip |
Fixed JSON parsing preamble regression.
Diffstat (limited to 'src/xss')
-rw-r--r-- | src/xss/InjectionChecker.js | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/xss/InjectionChecker.js b/src/xss/InjectionChecker.js index d750232..ae5fea0 100644 --- a/src/xss/InjectionChecker.js +++ b/src/xss/InjectionChecker.js @@ -172,7 +172,8 @@ XSS.InjectionChecker = (async () => { const toStringRx = /^function\s*toString\(\)\s*{\s*\[native code\]\s*\}$/; // optimistic case first, one big JSON block - let m = s.match(/{[^]+}|\[\s*{[^]+}\s*\]/); + s = s.replace(/[^{"]+=/, "") + let m = s.match(/{[^]+}|\[[^]*{[^]*}[^]*\]/); if (!m) return s; // semicolon-separated JSON chunks, like on syndication.twitter.com |