When create a Google API Oauth2.0 Credentials on Google Developers Console, I choose "Web Application" Application type.
In the "Authorized redirect URIs" field, I can use http://127.0.0.1/callback, it work fine for me on local development.
but when I want to use Google API Oauth2.0 Credentials on my server(let's say 99.99.99.99), I have to use http://99.99.99.99/callback as my "Authorized redirect URIs", but google give me a warning:
Invalid Redirect: http://99.99.99.99/callback must end with a public top-level domain (such as .com or .org)
Except to bind a public top-level domain to my server, what else can I do?
I develop in Django and use oauth2client to deal with Google API Oauth2 , So there are two table "oauth2_authentication_credential", "oauth2_authentication_flowmodel" in my database which have the credential value in it, I copy them from my localhost to sever, but it doesn't work.
The redirect URIs are the endpoints to which the OAuth 2.0 server can send responses. These endpoints must adhere to Google's validation rules. For testing, you can specify URIs that refer to the local machine, such as http://localhost:8080 .
To modify your app's allowed redirect URIs, go to console.cloud.google.com , click the left side panel, and navigate to APIs & Services > Credentials . From there, find the OAuth credential that you want to modify. Click "Edit" and you should see a list of "Authorized redirect URIs".
From a technical point of view, the top private domain is simply the rightmost superdomain preceding the public suffix. So for example, www.foo.co.uk has a public suffix of co.uk , and a top private domain of foo.co.uk .
There is help text near "Authorized redirect URIs" field, that clearly states that you cannot use public IP addresses:
Authorized redirect URIs
For use with requests from a web server. This is the path in your application that users are redirected to after they have authenticated with Google. The path will be appended with the authorization code for access. Must have a protocol. Cannot contain URL fragments or relative paths. Cannot be a public IP address.
127.0.0.1
is not public IP, but a loopback, that's why http://127.0.0.1/callback works fine. localhost also could be used: http://localhost/callback
Except to bind a public top-level domain to my server, what else can I do?
You can use free DNS by http://xip.io/. So for IP 99.99.99.99
use http://99.99.99.99.xip.io/callback. And it would be resolved to http://99.99.99.99/callback.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With