63

When I switched from my debug map key to my signed map key my maps stop working. I get the following errors in logcat:

09-03 18:18:04.112: WARN/System.err(4073): IOException processing: 26
09-03 18:18:04.112: WARN/System.err(4073): java.io.IOException: Server returned: 3
09-03 18:18:04.112: WARN/System.err(4073):     at android_maps_conflict_avoidance.com.google.googlenav.map.BaseTileRequest.readResponseData(BaseTileRequest.java:115)
09-03 18:18:04.112: WARN/System.err(4073):     at android_maps_conflict_avoidance.com.google.googlenav.map.MapService$MapTileRequest.readResponseData(MapService.java:1473)
09-03 18:18:04.112: WARN/System.err(4073):     at android_maps_conflict_avoidance.com.google.googlenav.datarequest.DataRequestDispatcher.processDataRequest(DataRequestDispatcher.java:1117)
09-03 18:18:04.112: WARN/System.err(4073):     at android_maps_conflict_avoidance.com.google.googlenav.datarequest.DataRequestDispatcher.serviceRequests(DataRequestDispatcher.java:994)
09-03 18:18:04.112: WARN/System.err(4073):     at android_maps_conflict_avoidance.com.google.googlenav.datarequest.DataRequestDispatcher$DispatcherServer.run(DataRequestDispatcher.java:1702)
09-03 18:18:04.112: WARN/System.err(4073):     at java.lang.Thread.run(Thread.java:1019)

I've double checked everything, permissions and library are in place. I've recreated the singed key and no luck.

Any ideas?

Konrad Borowski
  • 11,584
  • 3
  • 57
  • 71
Jen
  • 653
  • 1
  • 5
  • 5

10 Answers10

85

I had the same problem and I figured there wasn't any helpful answer around on the internet so hoping this should help everyone in the future.

When using GoogleMaps for Android, you need two keys - debug and release.

The "debug" key is kind of a misleading term. This key is also to be used when you develop the app in Eclipse. So essentially, use the debug key for development, testing, debugging.

When you're ready to launch the app to Market, set the android:debuggable="false" in the AndroidManifest.xml and use the Signed API key.

When using the signed API key, the MapView will show up ONLY when the app is installed from the Android Market. So, installing the app from Eclipse (Run As, Debug As, etc) or command line (adb install) won't show the MapView. Rest assured, once the app is in the Market - you download it and the MapView will show up.

With the signed API key, if you deploy the app from Eclise, you will get a "Server returned 3, IOProcessing Exception 26" as a warning - just ignore it.

Note: Also ensure there are no duplicate instances of the same MapView. If your app needs "x" no. of MapViews, generate "x" no. of new signed keys (one for each MapView) since GoogleMaps has a query limit for a single MapView instance.

For getting both the keys, follow the steps for Obtaining API keys for GoogleMaps on Android.

Happy Coding!

UPDATE:

The link above for obtaining api keys is now a deprecated procedure. Refer Obtaining API keys for GoogleMaps Android API v2 going forward.

Sagar Hatekar
  • 8,700
  • 14
  • 56
  • 72
  • I don't know how you can create more than 1 GMaps API key per app. AFAIK, GMaps API key is associated with .keystore (which you use to sign your app). It means for each app, you can create only 1 GMaps API key. – anticafe Apr 16 '12 at 04:20
  • Hmm..you have a valid point. Maybe you generate multiple signed keys? Although I am not sure if the signatures would be unique. – Sagar Hatekar Apr 16 '12 at 14:02
  • 11
    Just to be accurate: "When using the signed API key, the MapView will show up ONLY when the app is installed from the Android Market. So, installing the app from Eclipse (Run As, Debug As, etc) or command line (adb install) won't show the MapView. Rest assured, once the app is in the Market - you download it and the MapView will show up." - this is not really correct. In fact, the MapView will work as intended if the app is signed with the key you gave to Google when applying for a Maps key. You can install from the command line and it will work if you signed it with this one. – BoD Jul 04 '12 at 17:07
  • I was confused about that issue... we had a working map for our client, but it was working regardless of being installed from market or from other source. And one day we recognized that it did not work any more. Indeed, we had to change our signing certificate, and we missed to give it to google again... – Schlangi Nov 08 '12 at 17:05
  • @Sagar Are you saying that we cannot see MapView in debug mode anymore? – IgorGanapolsky Dec 13 '12 at 00:06
  • @IgorGanapolsky You can view the MapKey in debug mode, if you use debug key. – Sagar Hatekar Dec 13 '12 at 02:29
  • How I can rest assured if exactly the same symptoms are in the "bad key" situation? Or how I can tell that for sure? – halxinate May 01 '13 at 22:33
  • Note that debuggable false is not necessary in some cases if I interpret this correct: http://stackoverflow.com/a/5701672/1068167 – span Jun 27 '14 at 21:48
3

Finally Its fixed.

I am using Windows machine, so I simply went to C:\Users\rohit\.android and deleted debug.keystore and default.keyset1 once this is done, I went to Eclipse and applied a clean build to my project and its done!

Rohit Mandiwal
  • 10,258
  • 5
  • 70
  • 83
2

I had the same problem. In my case, what I was doing wrong was this. I was writing the keytool command like this:

keytool -list -keystore debug.keystore ...

instead of:

keytool -list -keystore ~\.android\debug.keystore ...

So I wasn't updating the Eclipse's keystore with my fingerprint.

I hope this helps someone :)

Estrella
  • 21
  • 1
2

If you are using a debug key that somebody else has generated and provided to you, that is the reason for the blank map with the following exception.

java.io.IOException: Server returned: 3

You can use this link to get an API key : https://console.developers.google.com/apis/credentials

This link will take you to google credentials page, the new place to get API keys.

FireLordZuko
  • 95
  • 1
  • 13
Prasad Korhale
  • 577
  • 1
  • 5
  • 15
2

Signed map key is used for release app. So you will get such info. if you debug the app via USB-tethered with signed map key. Switch back to debug map key if you want to debug the app, and replace it with signed map key before you release an update or new version.

sma
  • 877
  • 2
  • 9
  • 24
1

one more thing: After adding -v you must remember that the google API just need MD5 not SHA1.So please check what code you give to google.

fly84021210
  • 131
  • 2
  • 10
  • 1
    Then why does Google say: Google verifies that each request originates from an Android application that matches one of the certificate SHA1 fingerprints and package names listed below. You can discover the SHA1 fingerprint of your developer certificate using the following command – IgorGanapolsky Dec 13 '12 at 00:01
1

I just encountered exactly the same problem.

There is no user-written code that throws the Exception: it is generated in the Eclipse logcat and the result is that you do not see any of the Google map tiles. Like Jen, I regenerated the key, to no avail.

The platform is Android 3.2, the device is the Asus Transformer, the connection is WiFi.

FYI my Android 2.2 application works fine, retrieving the map on a Droid over 3G.

Here is the solution to my problem, hope it helps Jen:

In my case, if I install the release version onto the Transformer using the "Debug as" Eclipse icon, with the Transformer USB-tethered, the map is failing as described above (FYI this is a procedure I have used successfully many times with Android 2.2 and other devices).

So I tried this instead: I use the Eclipse File|Export... option to create a release APK, and then install that APK onto the Transformer using its Asus Sync application. Everything is fine. The map tiles appear.

CJ Villa
  • 13
  • 3
  • You're right it's not a code issue. I've tried creating keys in different apps, under different gmail accounts and still the same error. I thought maybe it was my device, a HTC G2 running Anroid 2.3, then I tried using the emulator with different Android apis and no luck there either. I tried your suggestion and installed the apk to my device using AstroFile and the problem is still there. Thank you though, it's good to hear that I'm not the only one getting this error. The only other thing I can think off is moving my project to another computer and trying again. – Jen Sep 04 '11 at 16:11
  • Did you also regenerate the MD5 fingerprint? In my case the MD5 changed so I had to get a new Maps API key. – CJ Villa Sep 04 '11 at 23:37
  • Yes I did regenerate the MD5 fingerprint and still the same error. – Jen Sep 09 '11 at 00:11
  • very interesting, i started having these symptoms this morning. until then, the code was working fine. could my key have expired? will check and post. – tony gil Mar 14 '13 at 01:35
0

I have same question but I think I found the answer!

  1. Decide follow these step https://developers.google.com/android/maps-api-signup and receive your certificate's MD5 fingerprint
  2. While development, if map's not showed, don't worried about this! Simple extract APK use android tools with key tool which's used in first step and use this APK file to install on your phone, you will see MapView

Anyway, while development time, maybe you don't see MapView, but it's till not problem and don't worried about this! Simple wait when finished app & build with your keystore and you will see map display correctly

Khai Nguyen
  • 3,065
  • 1
  • 31
  • 24
0

For the poor souls that tried to build the map example from sdk extras: as soon as I renamed the package from com.example.mapdemo to com.mynmae.mapdemo, the map magically appeared. Yes, I lost an hour searching and trying and it silently rejected the package name.

denispyr
  • 1,403
  • 3
  • 21
  • 34
0

I'm from the future! I've experienced the exact same problem. But this might be an issue for novice developers.

When you created a new google maps activity in the android studio, there's a link to get yourself an API key inside the google_maps_api.xml file. So what happens when you follow this link is that Google will create a "debugging" key for your project. Which, as Sagar Hatekar explained, is indeed, only meant for testing and dev.

To be more clear, Google identifies your project by the SHA-1 certificate fingerprint (also stated inside the comments of google_maps_api.xml) So what I'm trying to say is that you CANNOT use the same key for several projects unlike the open/public APIs out there.

https://developers.google.com/maps/documentation/android-sdk/start

In this link, they have a small section with the topic of A slightly less fast way which might be a try to explain this phenomenon.

Therefore, if you are using the same key for a project which, the key is not meant for, try requesting a new key.

FireLordZuko
  • 95
  • 1
  • 13