A technique on Windows that is less known is how to do basic port-proxying.
Proxying ports is useful when a process binds on one (maybe only the local) interface and you want to expose that endpoint on another network interface.
Let’s say you have an existing process that listens only on the loopback interface, and you want to expose it remotely. Or there are two network interfaces and you want expose traffic from one to the other (maybe some evil persistence for port 3389) - or think of basic pivoting.
It took me quite a while to figure how to do this on Windows the first time I needed this. If you know Linux, you probably are familiar with the power of
ssh and it’s range of command line options.
The good news is that Windows 10 ships with
ssh - but this post is not about ssh.
In this post we will look at built-in Windows tools such as
portproxy that can be used.
Diving into netsh interface portproxy
As an example, let’s say we have a web server running locally on port 80 - but it indeed only binds on 127.0.0.1. Now we want to tunnel that traffic out on a remote interface.
In Windows this can be done by an Administrator using:
netsh interface portproxy
The following command shows how this is performed:
netsh interface portproxy add v4tov4 listenaddress=0.0.0.0 listenport=48333 connectaddress=127.0.0.1 connectport=80
This is the basic setup to configure proxying traffic.
A quick explanation of the most important command line options:
listenport: Interface and port of the new endpoint. In our example, this exposes a new endpoint on all interfaces on port 48333
connectport: IP and port of the proxy address. In our example, the proxy to connect to is on 127.0.0.0 port 80.
This is the basic configuration to expose that web server remotely on a different interface.
Although, by default remote connections to port 48333 will be blocked by the firewall.
We have to add a new firewall rule to allow port 48333.
How does that work on Windows you might ask?
Allowing traffic through the firewall
There are multiple ways to update firewall rules in Windows. Besides the UI the following commands might come in handy:
- Use netsh to add a new firewall rule:
netsh advfirewall firewall add rule name="Open Port 48333" dir=in action=allow protocol=TCP localport=48333
On modern Windows machines, this can also be done via PowerShell commands:
New-NetFirewallRule -Name FirefoxRemote -DisplayName "Open Port 48333" -Direction Inbound -Protocol tcp -LocalPort 48333 -Action Allow -Enabled True
Now, it is all setup to connect to from another machine to port 48333.
It also works between IPv4 and IPv6. Very cool. :)
Cleaning up and reverting changes
In order to remove port forwarding and revert to the defaults, we can run the following commands:
netsh interface portproxy reset
Alternatively, there is a delete argument.
The same applies for opening port 48333 on the machine. The firewall rule can be removed again using the following command:
netsh advfirewall firewall del rule name="Open Port 48333"
or if you like PowerShell:
Remove-NetFirewallRule -Name FirefoxRemote
In this post we explored some simple commands to expose ports (proxy/forward them) on different network interfaces. Hope the post was informative and useful.
Feel free to follow or message me on Twitter @wunderwuzzi23.
The detailed documentation for
netsh interface portproxy can be found here: