I'm new to the FortiGate routers (I've always been a Cisco guy), and had a hard time figuring out how to properly configure inbound and outbound static one-to-one NAT rules in the router. After doing a fair amount of searching in the FortiGate documentation and Googling, I found the information available online about this topic was either incomplete or out of date. So I thought I’d pass this along in case it is helpful to anyone who finds this tread in the future. I successfully did the below steps today on a FortiGate 60D running Firmware 5.2.7 build 718, but I’m pretty sure it will work the same on other similar models too. How to create an INBOUND static NAT rule:
[ol]Just because you create an Inbound NAT rule, it doesn’t mean that all outgoing traffic from that internal IP will be NAT’ed to that external Public IP. By default, the FortiGate will do outbound NAT to the external IP address only for *replies* sent by the internal server in response to requests that originated from *outside* the firewall. If you want to ensure that *all* traffic originating from the internal server is always NAT’ed to a specific external public IP address, then you must create a custom Outbound Static NAT IPv4 policy. If no custom outbound policy is created, then the outbound traffic that originates from the internal server will be NAT’ed to the router’s default overload one-to-many NAT public IP address. How to create an Outbound Static NAT rule:
[ol]NOTE: The FortiGate ARP tables last for quite a while, so if you are testing your outbound IP NAT to an external website (like www.whatismyip.com) then you need to completely close and restart your browser sessions, or reboot your test computer, or reboot the router, or wait for the router’s ARP tables to expire. I just found that visiting multiple different “show your IP” websites was easiest.
You can also just edit the VIP rule in cli with
set nat-source-vip enable
Thanks Darren for your response. I learned how to setup a Virtual IP and IP Pools. Both are very useful.
Benjamin
DarrenM wrote:You can also just edit the VIP rule in cli with
set nat-source-vip enable
Hi Iyontech,
Can I apply this for internal private network connection? Let say I want the user to connect to a server in the office by using NAT IP instead of the server's real IP.
Currently I have a 1 to 1 NAT configuration that has an A record in DNS on a Fortigate connected to 2 different ISps. . I'm doing maintenance and want to nat this particular host to a vip on a different interface. I thought about setting up the second VIP, then changing my dns to the new address. Once it propagates I can remove the original VIP and do my maintenance. My question is what would happen if I added the second NAT, where would the outbound traffic go? I've got set nat-source-vip enable on the current VIP and I also have an IP pool configured from the outbound traffic policy (belt and suspenders kind of thing.)
What might be best way to get to the configuration I want?
Hi,
Currently have a dynamic IP from my provider. Can I assign an outbound static rule so that all traffic from local network goes to my external interface (Wan1).
Luc
Thank you for this post. I am trying to get an internal PBX working (3CX) and needed this information.
However, I am still having a problem. For some reason, the firewall (60E) is changing incoming ports 5060 to 65476 and 5090 to 65506. This is causing no end of problems for me and I thought (obviously incorrectly) that the setup that you described here would cause the firewall to preserve the port number. On top of that, I have no idea why the firewall is doing that or how to stop it. Any suggestions?
Thanks
Bert
Hello,
Thanks for the tuto
One thing I do not understand, and I am blocked.
At the IPv4 Policy Creation, you indicate:
- "Source Address = Select the name that you specified in Step #1"
And in Step 1 you indicate:
"Interface = Select the correct external WAN interface that the public IP is connected to"
So, my question is : How can I assign an external Virtual IP object to an internal Source Adresse Policy object ?
The Virtual IP I created is not available when I try to assign it to the policy rule.
Can someone help me on that?
Thank you
Hi ,
Thank you for sharing these steps on how to create inbound and outbound one-to-one static NAT rules in FortiGate. Your explanation is clear and concise, and I'm sure it will be helpful to anyone who is new to FortiGate routers.
Just to add to your explanation, it's important to note that the outbound NAT rule will only apply to traffic that originates from the internal network and is destined for the external network. If the traffic is initiated from the external network and is destined for the internal network, then the inbound NAT rule will apply.
Also, when creating the outbound NAT rule, it's a good idea to specify the source port as well as the destination port if you want to control or redirect specific ports. This can be done by selecting "Custom" under the "Service" field and specifying the source and destination ports.
I hope this additional information is helpful. Let me know if you have any further questions or if there's anything else I can assist you with.
 
					
				
				
			
		
| User | Count | 
|---|---|
| 2652 | |
| 1407 | |
| 810 | |
| 697 | |
| 455 | 
The Fortinet Security Fabric brings together the concepts of convergence and consolidation to provide comprehensive cybersecurity protection for all users, devices, and applications and across all network edges.
Copyright 2025 Fortinet, Inc. All Rights Reserved.