It is well known that Facebook uses javascript responses (JS,not json) which is prefixes with while(1)
& for(;;);
in order to prevent script ta
This attack (loading JSON as a ) is based on a few assumtions:
1) The JSON is itself valid JS (thats what the for(;;)
changes), which also means that it may not start with a {
as that is a block statement, which does not contain key-value pairs:
{ "a": 1 } // invalid JS, valid JSON *
[{ "a": 1 }] // valid JS, valid JSON
2) The browser is very old (< 1% of the total users), as constructing arrays with the literal does not call the Array
function in newer browsers (ES5 support is a good estimation for those).
Therefore this attack isn't possible in this case, as the API you mentioned returns an object, therefore (1) is not fullfilled. And even if the API would return an array, only a very small amount of people could theoretically be hijacked:
1) The browser has to be very old, and then the browser itself is probably a bigger risk, and the browser has to even support JavaScript.
2) The client has to visit a malicious site, which is very unlikely due to spam filters / blacklists at various levels.
3) The user has to be logged in at facebook while visiting the malicious website.
Worth to mention that there are still others responses with infinite loop
I guess this is generally a thing of the past. It will take a while until all APIs got refactored / migrated. I assume adding/removing these 5 characters causes a significant overhead if you think at Facebook's scale.
*: If you try to load { a: 1 }
you'll find out that it does not throw a SyntaxError! However this is neither valid JSON, nor does it create an object (it's a labelled 1 inside of a blocn statement).