How to Configure Windows Defender Firewall to Allow HTTP Traffic
BLOGSARTICLES
data:image/s3,"s3://crabby-images/c396b/c396b69a59e68d3892fb27a768756ad460a997e1" alt=""
data:image/s3,"s3://crabby-images/3c2dd/3c2dd0cf6a59097bf7c0a50c26ea73fbdbd1a99d" alt=""
In this guide, I’ll walk you through how I configured the Windows Defender Firewall to allow HTTP traffic using both the GUI (Graphical User Interface) and PowerShell. This step-by-step tutorial will help you understand how to manage firewall rules like a pro. Let’s get started!
Why Configure the Firewall?
Firewalls are your system’s gatekeepers. By default, Windows Defender Firewall blocks all incoming traffic unless there’s a rule that specifically allows it. While this is great for security, it can also block legitimate traffic—like HTTP requests for web servers. So, when I needed to access a web server, I had to configure the firewall to allow HTTP traffic on port 80. Here’s how I did it.
Step 1: Testing the Firewall
First, I tested what happens when HTTP traffic tries to pass through the firewall without a rule.
Opened Internet Explorer on my workstation.
Typed the IP address of the server (http://172.30.0.16) into the browser and hit Enter.
As expected, the browser threw an error saying it couldn’t connect to the server.
data:image/s3,"s3://crabby-images/25d91/25d91e4c819f251a770ca6e4c4ced40f50b30833" alt=""
data:image/s3,"s3://crabby-images/a95c8/a95c8bc9f5db1bd4cd3e159dc6b5f7a6fc8614ed" alt=""
Why This Happens:
Without a rule to allow HTTP traffic, the firewall blocks everything. This is the default behavior for Windows Defender Firewall, which uses a “deny all unless explicitly allowed” policy.
Step 2: Enabling HTTP Traffic Using the GUI
To allow HTTP traffic, I enabled a built-in firewall rule for World Wide Web Services (HTTP Traffic-In).
1. Navigate to the Firewall Settings
Logged into the server.
Opened Control Panel > System and Security > Windows Defender Firewall > Advanced Settings.
Clicked on Inbound Rules.
2. Find and Enable the Rule
Located the rule named World Wide Web Services (HTTP Traffic-In).
Right-clicked the rule and selected Enable Rule.
Opened the rule’s Properties and verified:
Under Protocols and Ports, it was set to TCP on port 80.
In General, the rule was enabled.
data:image/s3,"s3://crabby-images/30e68/30e6868353971f8839ed7368d4b483af83f6bfdf" alt=""
data:image/s3,"s3://crabby-images/54e0f/54e0f302ba913cb7dbd021069a6f458d54258516" alt=""
data:image/s3,"s3://crabby-images/a9004/a9004eb684d7bddcdbe55c1fc89cf011f14e023c" alt=""
data:image/s3,"s3://crabby-images/c3ad9/c3ad98249f4d38828ca530fd7814268ffe83b554" alt=""
Why This Works:
Enabling this rule tells the firewall, “It’s okay to allow HTTP traffic on port 80.” Once this is done, the firewall permits web requests to reach the server.
Step 3: Verifying the Rule
Next, I tested if the rule worked as intended.
Opened Internet Explorer on my workstation again.
Typed the server’s IP address (http://172.30.0.16) into the browser.
This time, the browser successfully loaded the IIS homepage.
data:image/s3,"s3://crabby-images/70c2e/70c2e4721741aa457bd058f14872c43311f0f617" alt=""
data:image/s3,"s3://crabby-images/cbb78/cbb783e42dce041f2a711c4714cca1f251b28cc7" alt=""
What This Proves:
The firewall rule was applied correctly, and HTTP traffic is now allowed!
Step 4: Configuring the Firewall Using PowerShell
To make things more efficient, I also configured the same firewall rule using PowerShell. This method is especially useful when working with multiple systems or automating tasks.
1. Check the Status of the Rule
First, I checked if the HTTP rule was enabled using this command:
Get-NetFirewallRule -DisplayName "World Wide Web Services (HTTP Traffic-In)"
The output showed the rule’s current status, including whether it was enabled or disabled.
data:image/s3,"s3://crabby-images/b4f5b/b4f5bee4de0fdb5f1912ae6691066b89feb4a0e4" alt=""
data:image/s3,"s3://crabby-images/a69f7/a69f7a40dca95745b56dc38fa51eeab9c4946d81" alt=""
2. Enable the Rule
To enable the rule, I ran this command:
Set-NetFirewallRule -DisplayName "World Wide Web Services (HTTP Traffic-In)" -Enabled True
I verified the status again using Get-NetFirewallRule.
data:image/s3,"s3://crabby-images/6e683/6e683ff3337bb33eea9ef87d22a1a4172c946c28" alt=""
data:image/s3,"s3://crabby-images/ac8d4/ac8d43efc26e65d26d4c173eef6c702a22fd2dca" alt=""
Why Use PowerShell?
PowerShell is faster and more flexible, especially when managing multiple machines. Instead of clicking through menus, you can configure everything with a few commands.
3. Test the Rule Again
Finally, I tested the HTTP connection one more time by visiting the server’s IP address in the browser. The IIS homepage loaded successfully, just like before.
data:image/s3,"s3://crabby-images/f282d/f282db8b6da80f431ee2e9d58d1a827db06bdf58" alt=""
data:image/s3,"s3://crabby-images/c732e/c732ee08257379b949cdc3353b19311effb0bc1d" alt=""
If you’re managing multiple systems or want to save time, PowerShell is your best friend. For one-off configurations, the GUI is intuitive and easy to use. Mastering both methods will make you a well-rounded network administrator.