596

What can I do in the Android emulator to connect it to my localhost web server page at http://localhost or http://127.0.0.1?

I've tried it, but the emulator still takes my request like a Google search for localhost or worse it says that it didn't found the page while my web server is normally running.

Ryan M
  • 18,333
  • 31
  • 67
  • 74
Fopa Léon Constantin
  • 11,863
  • 8
  • 48
  • 82
  • 3
    This question is about the Android **Emulator** and has solutions applicable to that case *alone*. If you face this problem when using a **physical Android device**, please see instead https://stackoverflow.com/questions/4779963/how-can-i-access-my-localhost-from-my-android-device – Chris Stratton Jul 23 '17 at 20:15

18 Answers18

1006

The localhost refers to the device on which the code is running, in this case the emulator.

If you want to refer to the computer which is running the Android simulator, use the IP address 10.0.2.2 instead.

enter image description here

You can read more from here.

Primal Pappachan
  • 25,857
  • 22
  • 67
  • 84
  • 16
    why referring to teh other question? simply add the Link [Android emulator Networking](http://developer.android.com/tools/devices/emulator.html#networkaddresses) – Marvin Emil Brach Jul 23 '12 at 11:36
  • Thanks for pointing the link out. I guess it was not there when the answer was posted. – Primal Pappachan Jul 24 '12 at 14:48
  • 1
    @primpap :Can I use the machine name instead of the ip address?? – KJEjava48 Jun 17 '15 at 10:17
  • @primpap this is not working with Mobile debugging. Is there some other ? Or i am doing mistake somewhere because 10.0.2.2 is working on emulator but not working when i connect mobile for usb debugging. ? – Jawad Zeb Jun 23 '15 at 12:55
  • what if , I am using mobile device – Mansuu.... Mar 03 '17 at 07:40
  • I think this is not working anymore, I noticed an error when the emulator started – Omer Levi Hevroni Jul 06 '17 at 08:25
  • 13
    **This solution only works on emulators**, as asked in the specific question here. Those debugging on a physical Android device will have to use the server's actual IP address or name, they can't use this special emulator-only alias. **This answer is good** - but readers need to be careful that their situation is one in which it is *applicable*. – Chris Stratton Jul 23 '17 at 20:09
  • For flutter, it is still the same: `10.0.2.2` – Ng Sek Long Apr 07 '19 at 13:53
  • 1
    @Marvin Emil Brach The link doesn't anymore. Currently it is: https://developer.android.com/studio/run/emulator-networking – The incredible Jan Jul 02 '21 at 07:16
  • @Ng Sek Long Why should it differ? Don't you use the same emulator(s) with Flutter? – The incredible Jan May 26 '23 at 12:35
175

Use 10.0.2.2 for default AVD and 10.0.3.2 for .

frogatto
  • 28,539
  • 11
  • 83
  • 129
qgicup
  • 2,189
  • 1
  • 16
  • 13
34

I used 10.0.2.2 successfully on my home machine, but at work, it did not work. After hours of fooling around, I created a new emulator instance using the Android Virtual Device (AVD) manager, and finally the 10.0.2.2 worked.

I don't know what was wrong with the other emulator instance (the platform was the same), but if you find 10.0.2.2 does not work, try creating a new emulator instance.

Peter Mortensen
  • 30,738
  • 21
  • 105
  • 131
31

Try http://10.0.2.2:8080/ where 8080 is your port number. It worked perfectly. If you just try 10.0.2.2 it won't work. You need to add port number to it. Also if Microsoft IIS has been installed try turning off that feature from control panel (if using any windows os) and then try as given above.

Danger14
  • 760
  • 2
  • 12
  • 33
SAMBA
  • 503
  • 2
  • 8
  • 15
26

You can actually use localhost:8000 to connect to your machine's localhost by running below command each time when you run your emulator (tested on Mac only):

adb reverse tcp:8000 tcp:8000

Just put it to Android Studio terminal.

It basically sets up a reverse proxy in which a http server running on your phone accepts connections on a port and wires them to your computer or vice versa.

Nijat Ahmadli
  • 711
  • 6
  • 13
10

according to documentation:

10.0.2.2 - Special alias to your host loopback interface (i.e., 127.0.0.1 on your development machine)

check Emulator Networking for more tricks on emulator networking.

Paul Butcher
  • 10,722
  • 3
  • 40
  • 44
Rahul Tiwari
  • 6,851
  • 3
  • 49
  • 78
7

For My Mac OS mountain Lion device :

http://10.0.2.2:8888

Works perfect !

bora.oren
  • 3,439
  • 3
  • 33
  • 31
Guest
  • 71
  • 1
  • 1
  • The port doesn't matter. It only "works" if you have something listening there. The question was about http://127.0.0.1 which means port 80. – The incredible Jan May 26 '23 at 12:45
5

If you using Android Emulator :

You can connect to your Pc localhost by these IPs : 10.0.2.2:{port of your localhost} => if you set your machine port in xamp you must use that port . In my case 10.0.2.2:2080

enter image description here

enter image description here

Also you can use your network adapter IP .In CMD write ipconfig and find your adapter ip address :

enter image description here

enter image description here

If emulator can not connect to this IPs close the emulator an open it by cold boot from AVD Manager :

enter image description here

If you using Genymotion :

You can connect to machine localhost by this IP : 10.0.3.2:{port number} Or your adapter IP address as I explained above: in my case : 192.168.1.3:2080

mostafa3dmax
  • 997
  • 7
  • 18
3

I needed to figure out the system host IP address for the emulator "Nox App Player". Here is how I figured out it was 172.17.100.2.

  1. Installed Android Terminal Emulator from the app store
  2. Issue ip link show command to show all network interfaces. Of particular interest was the eth1 interface
  3. Issue ifconfig eth1 command, shows net as 172.17.100.15/255.255.255.0
  4. Begin pinging addresses starting at 172.17.100.1, got a hit on `172.17.100.2'. Not sure if a firewall would interfere but it didn't in my case

Maybe this can help someone else figure it out for other emulators.

Hugh Jeffner
  • 2,936
  • 4
  • 32
  • 31
3

Allowing PWA installation

First of all, install the Android debug bridge:

$ sudo apt install adb android-sdk-platform-tools-common

Start your Android emulator as usual, e.g.:

$ ~/Android/Sdk/emulator/emulator -avd Pixel_3a_API_30_x86

Only then, configure a reverse proxy on the bridge of the Android emulator that will forward localhost HTTP requests to the appropriate port (e.g. 8000) of the localhost server running on your host computer and vice versa:

$ adb reverse tcp:8000 tcp:8000

A progressive web application (PWA) being served on localhost:8000 or 127.0.0.1:8000 will be installable and connect to its service-worker.js. Whereas PWA installation is not allowed from IP address 10.0.2.2.

Caveat: adb reverse tcp:8000 tcp:8000 needs to be reissued after each Android emulator evocation.

Hence, a bash script to launch an Android emulator, followed by a reverse proxy, would look like this:

#!/usr/bin/env bash

$HOME/Android/Sdk/emulator/emulator -avd Pixel_3a_API_30_x86 > /dev/null 2>&1

adb reverse tcp:8000 tcp:8000
Serge Stroobandt
  • 28,495
  • 9
  • 107
  • 102
3

Despite reading all the answers here and elsewhere, I have lost several hours trying to debug this issue, as the address 10.0.2.2 did not work, even in Chrome browser. If the same is happening to you, here is a step-by-step guide to try to debug and hopefully fix your issue.

Check emulator gateway is 10.0.2.2

Inside the emulated Android, go to Settings > WiFi, check if it is connected to AndroidWiFi hotspot (which represents your host computer), and then click on Advanced at the bottom, then check the Gateway address: it should point to 10.0.2.2 . If not, then you have another issue, maybe changing proxy settings can fix your issue, see here how to do that with Android Studio since 2022, as the proxy setting is now hidden away: How to configure proxy in emulators in new versions of Android Studio?

Check if your server is accessible from your host computer

Simply open a web browser and type http://localhost:<port> to see if your local web app is accessible. If not, then you likely have an issue with your local server parameters.

Check if your server is accessible from the emulator

Open Chrome browser, and point it to http://10.0.2.2:<port> (for genymotion, replace with http://10.0.3.2:<port>). If your web app shows up, great, you're done. If not, then test the other steps below to pinpoint the root issue.

Test with another server

In case your web app can be accessed from your host computer, but not inside the emulator, the root cause can be that your local server is restricting access to some interfaces for some reason, likely for security reasons.

To check this, try to use another server, just a simple HTTP server will do, such as http-server with nodejs, or python -m http.server 8000 with Python 3.

Then, try to access this simple server from your emulator's Chrome browser, eg, http://10.0.2.2:8000. If it works, then this confirms that your local server is restricting access to some interfaces. You need to read your local server's documentation to broaden permissions.

For example, in my case, my server was angular-cli (AngularJS), which by default restricts serving only to localhost. To make it work, I had to use ng serve --disable-host-check --host 0.0.0.0 instead of just ng serve, as suggested in this other question. The --host 0.0.0.0 instructs the webserver to serve all interfaces. Similar arguments can be provided to most webservers.

An alternative might be to disable some unused adapters, especially virtual ones such as VPNs.

Your Android app permissions to cleartext

Now, your web app should be accessible from inside the emulator, using Chrome app, with the URL http://10.0.2.2:<port>. The last piece of the puzzle is to add permissions in your Android app to access 10.0.2.2 and especially cleartext if your local webserver is not equipped with a SSL certificate (the most likely scenario for a local development webserver - just check if https://localhost:<port> works or only http://localhost:<port> from the host computer). This will allow your Android app to access your local webserver, just like Chrome does.

Adding specific permissions to access cleartext (ie, http://) from your Android app is necessary since Android 9 (API 28) upwards. There are several ways to configure your Android app to add this permission, see: https://stackoverflow.com/a/50834600/1121352

Conclusion

Accessing the host from the Android emulator can be tricky, but by careful step-by-step debugging, it can be possible to overcome the issue in most cases.

This tutorial only covers the issue of accessing/reaching a local webserver on the host computer from inside an Android emulator, but once this is fixed, the webapp may remain dysfunctional, even if reachable. One example is to experience an infinite loading loop. To debug further issues once reachability is resolved, you can use chrome://inspect in the Chrome Browser to attach to the Android WebView inside the Android emulator and live debug it as if it was rendered on your computer.

A last alternative, probably faster, is to get a paid subscription to services such as ngrok, but the free version is useless as they necessarily open the webapp in a web browser, outside of your Android app's webview.

gaborous
  • 15,832
  • 10
  • 83
  • 102
2

The accepted answer is correct, but didn't work in my case. I had to create the virtual device with the company VPN-client on the host machine turned off. This is quite understandable as many company networks use adresses starting with 10 (private network range), which could interfere with the special address 10.0.2.2

Tim Bq
  • 41
  • 4
  • No. There's nothing understandable about that. It doesn't matter how the address starts. As long as it doesn't start with 10.0.2. there isn't any "interference". – The incredible Jan May 26 '23 at 12:58
1

If you are in windows you can go to simbol system and write ipconfig and check what ip is assigned to your machine.

Ricardo
  • 7,921
  • 14
  • 64
  • 111
  • 1
    This is not necessary when debugging from an emulator, as you can use the special alias for the host loopback interface cited in the other answers. However if debugging from a physical android device, then yes, you need to determine the actual address of your test server and use that. – Chris Stratton Jul 23 '17 at 20:10
1

FOR ANYONE TRYING TO REACH A LOCAL IIS Server (ASP.NET)

For me, the accepted answer was not enough. I had to add a binding for 127.0.0.1 in the applicationhost.config, which was at the root of my ASP.NET solution.

Fahad S. Ali
  • 1,284
  • 1
  • 7
  • 7
0

I do not know, maybe this topic is already solved, but when I have tried recently do this on Windows machine, I have faced with lot of difficulties. So my solution was really simple. I have downloaded this soft http://www.lenzg.net/rinetd/rinetd.html followed their instructions about how to make port forwarding and then successfully my android device connected to make asp.net localhost project and stopped on my breaking point.

my rinetd.conf file:

10.1.1.20 1234 127.0.0.1 1234
10.1.1.20 82 127.0.0.1 82

Where 10.1.1.20 is my localhost ip, 82 and 1234 my ports Also I have craeted bath file for easy life yournameofbathfile.bat, put that file inside rinedfolder. My bath file:

rinetd.exe -c rinetd.conf

After starting this soft, start your aps.net server and try to access from android device or any device in your local network(for example Computer ABC starts putty) and you will see that everything works. No need to go to router setting or do any other complicated things. I hope this will help you. Enjoy.

Jevgenij Kononov
  • 1,210
  • 16
  • 11
  • There is nothing "simple" about your solution. Using 10.0.2.2 provided by Google for this purpose is simple. To know if a topic is solved there is a green check mark at the accepted answer. Which existed almost 6 years before you answered. – The incredible Jan Jul 02 '21 at 07:34
0

2023 answer:

I have an express app listening on localhost:5001, and a production api at my-real-api.com so I use:

// BASE_URL.js
import Constants from "expo-constants";
const { manifest } = Constants;

const PORT=5001
export const BASE_URL =
  (typeof manifest?.packagerOpts === `object` &&
  !!manifest.debuggerHost &&
  manifest.packagerOpts.dev)
    // dev server
    ? `http://${manifest.debuggerHost.split(`:`).shift()}:${PORT}` + 
    // production server
    : "https://my-real-api.com";

and then everywhere else:

import { BASE_URL } from "../BASE_URL"
import axios from "axios"
const my_data = await axios.get(BASE_URL+"/some/path")
Jthorpe
  • 9,756
  • 2
  • 49
  • 64
-1

Another workaround is to get a free domain from no-ip.org and point it to your local ip address. Then, instead of using http://localhost/yourwebservice you can try http://yourdomain.no-ip.org/yourwebservice

Ed_
  • 973
  • 11
  • 25
Astri
  • 575
  • 4
  • 10
-2

I know this is old, but if you find that 10.0.2.2 is not working as the computer IP, follow these instructions to find it

Tiago
  • 347
  • 1
  • 3
  • 12