1

I'm creating app that use autocomplete places google api.

And I don't know what is wrong but all the time I got responses like:

{
    "predictions" : [],
    "status" : "REQUEST_DENIED"
}

I send req : https://maps.googleapis.com/maps/api/place/autocomplete/json?input=Paris&types=geocode&language=fr&sensor=true&key=mykey

Documentation says :

REQUEST_DENIED indicates that your request was denied, generally because of lack of a sensor parameter.

I have sensor parameter, maybe it is something with api key.

Is there any page where can I get google's log :), to see why I got REQUEST_DENIED?

I use api key from :

http://code.google.com/intl/pl-PL/android/maps-api-signup.html

Maybe I have to get an api key from somewhere else.

2

5 Answers 5

1

You should be able to view your API Key by going to the API Console first: https://code.google.com/apis/console

If you haven't yet, you will need to create a new "Project" and then enable the Predictions services first by using the On/Off switch.

Please post your results, I have a similar problem with getting the REQUEST_DENIED response, but I've already got the API key and I'm using the sensor parameter like their documentation states.

It is frustrating that Google doesn't give any sort of response code along with REQUEST_DENIED so you can see why it's denying it. This will be difficult to support and troubleshoot in a production environment if this randomly goes out without providing any details as to why.

Update:

I just found this works for me now, but only after changing my requests to GET requests instead of POST. For reasons unknown, Google returns REQUEST_DENIED for POST requests but allows the same request via GET. A quick test for you to see if this is your problem would be to put the URL together with your API key and other parameters and try it through your browser instead. If that works then just rewrite your Android code to use GET instead of POST and you should be all set.

1

It was solved for me when I exchanged the API key. I was using the one under Android device, I changed it to the one "Key for browser apps (with referers)" and it worked for me although I'm using Android Device.

1

I recommend using .getJson() to get an error message along with your response to know what is exactly wrong.

For my case in flutter: I used googlePlace!.autocomplete.getJson(value); and i got the following response.

{ "error_message" : "You must enable Billing on the Google Cloud Project at https://console.cloud.google.com/project/_/billing/enable Learn more at https://developers.google.com/maps/gmp-get-started", "predictions" : [], "status" : "REQUEST_DENIED" }

0

That's the wrong API key. Follow the steps here to get the right one.

1
  • link is broken.
    – temirbek
    Commented Feb 1, 2022 at 10:13
0

Make sure you API keys are generated correctly and that you have enabled the necessary APIS. In my case, when designing iOS application - I need to enable Google Maps SDK for iOS, Google Places API for iOS

And most importantly, and without being mentioned by Google (in any other place as well) enable Google Places API Web Service.

With this, I ended a 2 day search for my pesky problem.

And, of course, make sure you use Key for server applications

Not the answer you're looking for? Browse other questions tagged or ask your own question.