A years-old security oversight has been addressed in basically all web browsers – Chromium-based browsers, including Microsoft Edge and Google Chrome, WebKit browsers like Apple’s Safari, and Mozilla’s Firefox.
It can be – and reportedly has been – exploited by miscreants to get access to software services they shouldn’t have access to. It affects the aforementioned browsers on macOS and Linux – and possibly others – but at least not on Windows.
A firm called Oligo Security flagged up the vulnerability this month and named it a 0.0.0.0 Day because it involves the 0.0.0.0 IPv4 address. And it appears attackers have been abusing this flaw since at least the late 2000s – judging by this Mozilla Bugzilla thread from that era, which is still listed as open.
According to Oligo, each of the three browsers’ teams have promised to block all access to 0.0.0.0 and also enact their own mitigations to close the localhost loophole.
The problem is as simple as this: If you open a malicious webpage in a vulnerable browser on a vulnerable OS, that page can fire off requests to 0.0.0.0 and a port of its choosing. And if you have servers or other services running locally on your box on that port, those requests will go to it.
So if you have some service running on your macOS or Linux workstation on port 11223, and you assume no one can reach it because it’s behind your firewall, and that your big-name browser blocks outside requests to localhost, guess again because that browser will route a 0.0.0.0:11223 request by a malicious page you’re visiting to your service.
It’s quite a long shot, in terms of practical exploitation – but you wouldn’t want to find out the hard way that some site hit your local endpoint by luck. In fact, it’s wryly amusing this is a thing in 2024.
There are supposed to be security mechanisms in place to prevent external websites from reaching your localhost in this way. Specifically, the Cross-Origin Resource Sharing (CORS) specification, and then the more recent Private Network Access (PNA), which is used by browsers to distinguish between public and non-public networks, and fortify CORS by restricting outside sites’ ability to communicate with servers on private networks and host machines.
The Oligo team, however, was able to bypass PNA. The researchers set up a dummy HTTP server running on 127.0.0.1 aka localhost, on port 8080, and was then able to access it from an external public site using JavaScript, by sending a request to 0.0.0.0:8080.
“This means public websites can access any open port on your host, without the ability to see the response,” Oligo security researcher Avi Lumelsky reported.
In response to this, Chrome will block access to 0.0.0.0 starting with Chromium 128, and Google will gradually roll out this change to be completed by Chrome 133. Apple has made changes to its WebKit open source software that block access to 0.0.0.0.
Mozilla doesn’t have an immediate fix, and has not implemented PNA in Firefox. According to Olgio, Mozilla did change the Fetch specification (RFC) to block 0.0.0.0 following its report.
A Mozilla spokesperson sent The Register the following statement via email:
According to Oligo, this research makes a strong case for PNA.
“Until PNA fully rolls out, public websites can dispatch HTTP requests using Javascript to successfully reach services on the local network,” Lumelsky wrote. “For that to change, we need PNA to be standardized, and we need browsers to implement PNA according to that standard.” ®