AI-generated Key Takeaways
- 
          Google Maps Platform secures its products by requiring API keys for authentication and billing purposes. 
- 
          You can create and restrict API keys through the Google Cloud Console or the Cloud SDK. 
- 
          Restricting API keys enhances security by limiting their usage to specific applications and IP addresses. 
- 
          API keys must be included in every Distance Matrix API request using HTTPS. 
- 
          When constructing URLs for web services, special characters need to be URL encoded and the total length should not exceed 2048 characters. 
Google Maps Platform products are secured from unauthorized use by restricting API calls to those that provide proper authentication credentials. These credentials are in the form of an API key - a unique alphanumeric string that associates your Google billing account with your project, and with the specific API or SDK.
This guide shows how to create, restrict, and use your API key for Google Maps Platform.
Before you begin
Before you start using the Distance Matrix API, you need a project with a billing account and the Distance Matrix API enabled. To learn more, see Set up in Cloud console.
Creating API keys
The API key is a unique identifier that authenticates requests associated with your project for usage and billing purposes. You must have at least one API key associated with your project.
To create an API key:
Console
- 
        Go to the Google Maps Platform > Credentials page. 
- 
        On the Credentials page, click Create credentials > API key.
        
 The API key created dialog displays your newly created API key.
- 
        Click Close. 
 The new API key is listed on the Credentials page under API keys.
 (Remember to restrict the API key before using it in production.)
Cloud SDK
gcloud services api-keys create \ --project "PROJECT" \ --display-name "DISPLAY_NAME"
Read more about the Google Cloud SDK , Cloud SDK installation , and the following commands:
Restricting API keys
Google strongly recommends that you restrict your API keys by limiting their usage to those only APIs needed for your application. Restricting API keys adds security to your application by protecting it from unwarranted requests. You are financially responsible for charges caused by abuse of unrestricted API keys. For more information, see API security best practices.
To restrict an API key:
Console
- 
        Go to the Google Maps Platform > Credentials page. 
- Select the API key that you want to set a restriction on. The API key property page appears.
- Under Key restrictions, set the following restrictions:
- Application restrictions:
- To accept requests from the list of web server IP addresses that you supply, select IP addresses (web servers, cron jobs, etc.) from the list of Application restrictions. Specify one or more IPv4 or IPv6 address, or subnet using CIDR notation. The IP addresses must match the source address the Google Maps Platform servers observe. If you use network address translation (NAT), this would typically correspond to your machine's public IP address.
- API restrictions:
- Click Restrict key.
- Select Distance Matrix API from Select APIs dropdown. If the Distance Matrix API is not listed, you need to enable it.
- To finalize your changes, click Save.
 
Cloud SDK
List existing keys.
gcloud services api-keys list --project="PROJECT"
Clear existing restrictions on existing key.
gcloud services api-keys update "projects/PROJECT/keys/KEY_ID" \ --clear-restrictions
Set new restrictions on existing key.
gcloud services api-keys update projects/PROJECT/locations/global/keys/KEY_ID \ --api-target=service=distance-matrix-backend.googleapis.com --allowed-ips="IP_ADDRESS"
Read more about the Google Cloud SDK , Cloud SDK installation , and the following commands:
Adding the API key to your request
You must include an API key with every Distance Matrix API request. In the following example,
    replace YOUR_API_KEY with your API key.
  
https://maps.googleapis.com/maps/api/distancematrix/json?origins=Seattle&destinations=San+Francisco&key=YOUR_API_KEY
HTTPS is required for requests that use an API key.