It confuses me about NAT networking, but I can use VMware and Parallels Desktop to do that.
I knew NAT how it works, just need an explain about this situation.
The following is from official documents. Why HOST can't connect GUEST with NAT.

It confuses me about NAT networking, but I can use VMware and Parallels Desktop to do that.
I knew NAT how it works, just need an explain about this situation.
The following is from official documents. Why HOST can't connect GUEST with NAT.

If you want to connect to the guest machine from the host, using NAT Network:
First, create a NAT Network - create the network in the VirtualBox Manager, File -> Preferences -> Network, and give it a name.
Assign that named NAT Network to each of the guest machines in their Network configurations in VirtualBox.
Make a note of what IP address is assigned to your guest machines when you run them. It will be something like 10.0.2.15 or 10.0.2.4. In Posix systems, run "ifconfig" and see what ip addresses show up for em0. Make a record of which address goes to which guest machine.
Edit the NAT Network's port forwarding. In VirtualBox manager, go to File -> Preferences -> Network and click the edit button for the NAT Network you are using. Click on Port Forwarding. Add rules that forward ports on your host machine to ip address + port on the guests (You don't need to set the IP address for your host machine, that's optional).
I know this is old, but the topic is relevant still, and I don't think I've seen this response yet, so here goes... I came to this thread with the same question. Then I thought about it for a bit and realized an ideal solution that is easy to implement.
Add a second interface!!
One is the NAT interface for the VM to talk to the Internet. The other is a host-only interface. In my case, I'm installing a CentOS guest OS. The new interface shows up, both get their IPs on the respective networks. The host-only doesn't establish a default route, so no conflicts. It just works. I access the guest OS openly from the host using the IP on the host-only network that is defined within VirtualBox.
To connect from HOST to GUEST VM with NAT networking, just add a port forward.
After that, you can access the forwarded port like a local port:
ssh root@localhost
It seems the official documentation has been improved to make it clearer of which direction the communication occurs, as I discovered from this answer:
Was bitten by this 2 years ago. For the sake of simplicity i wanted to have all my guests on the same subnet as the VirtualBox interface of the host, to SSH or VNC into any of them. And also have them see eachother, and access Internet (client-only).
As i have about 10 guest VMs for development, on a laptop host that frequently changes from a network to another, i couldn't use bridging (wanted to use fixed-IPs for all the guests for easy access from host).
NAT network was nearly perfect, except no communication between guests and host.
Host-only network was nearly perfect, except no internet access for the guests.
I eventually managed to get a working configuration with one minimal Debian VM acting as DNSmasq with two interfaces, and a bridge of those two interfaces. Well, until last week i just toggled off the virtualbox network interface because of conflict with another software, and when re-enabling it, host to guest access wouldn't work at all anymore.
After 2 hours managed to get back either internet access to guests, or guests access between them and not to the host.
Might maybe try as a last resort Host-Only for all guests, and the gateway VM doing NAT, albeit it'd be very ugly to have both two NATs daisy-chained, and the guests having different addresses between them and from the host.