Layanan web Google Maps Platform adalah kumpulan antarmuka HTTP ke layanan Google yang menyediakan data geografis untuk aplikasi peta Anda.
Panduan ini menjelaskan beberapa praktik umum yang berguna untuk menyiapkan permintaan layanan web dan memproses respons layanan. Lihat panduan developer untuk dokumentasi lengkap Geolocation API.
Apa yang dimaksud dengan layanan web?
Layanan web Google Maps Platform adalah antarmuka untuk meminta data Maps API dari layanan eksternal dan menggunakan data dalam aplikasi Maps Anda. Layanan ini dirancang untuk digunakan bersama dengan peta, sesuai dengan Pembatasan Lisensi dalam Persyaratan Layanan Google Maps Platform.
Layanan web Maps API menggunakan permintaan HTTP(S) ke URL tertentu, yang meneruskan parameter URL dan/atau data POST berformat JSON sebagai argumen ke layanan. Umumnya, layanan ini menampilkan data dalam isi respons sebagai JSON untuk penguraian dan/atau pemrosesan oleh aplikasi Anda.
Permintaan geolokasi dikirim menggunakan POST ke URL berikut:
https://www.googleapis.com/geolocation/v1/geolocate?key=YOUR_API_KEY
Catatan: Semua aplikasi Geolocation API memerlukan autentikasi. Dapatkan informasi selengkapnya tentang kredensial autentikasi.
Akses SSL/TLS
HTTPS diperlukan untuk semua permintaan Google Maps Platform yang menggunakan kunci API atau berisi data pengguna. Permintaan yang dilakukan melalui HTTP yang berisi data sensitif dapat ditolak.
Penggunaan Moderat Google API
Klien API yang didesain dengan buruk dapat menempatkan beban lebih dari yang diperlukan di Internet dan server Google. Bagian ini berisi beberapa praktik terbaik untuk klien API. Dengan mengikuti praktik terbaik ini, Anda dapat menghindari pemblokiran aplikasi karena penyalahgunaan API yang tidak disengaja.
Backoff Eksponensial
Dalam kasus yang jarang terjadi, mungkin terjadi masalah saat menayangkan permintaan Anda; Anda mungkin menerima kode respons HTTP 4XX atau 5XX, atau koneksi TCP mungkin gagal di antara klien dan server Google. Sering kali, sebaiknya coba lagi permintaan karena permintaan tindak lanjut mungkin berhasil jika permintaan asli gagal. Namun, penting untuk tidak sekadar membuat loop berulang kali yang membuat permintaan ke server Google. Perilaku looping ini dapat membebani jaringan antara klien Anda dan Google, sehingga menyebabkan masalah bagi banyak pihak.
Pendekatan terbaik adalah mencoba ulang dengan meningkatkan waktu tunda antar percobaan. Biasanya, penundaan ditingkatkan dengan faktor perkalian pada setiap upaya, pendekatan yang dikenal sebagai Backoff Eksponensial.
Misalnya, pertimbangkan aplikasi yang ingin membuat permintaan ini ke Time Zone API:
https://maps.googleapis.com/maps/api/timezone/json?location=39.6034810,-119.6822510×tamp=1331161200&key=YOUR_API_KEY
Contoh Python berikut menampilkan cara membuat permintaan dengan backoff eksponensial:
import json import time import urllib.error import urllib.parse import urllib.request # The maps_key defined below isn't a valid Google Maps API key. # You need to get your own API key. # See https://developers.google.com/maps/documentation/timezone/get-api-key API_KEY = "YOUR_KEY_HERE" TIMEZONE_BASE_URL = "https://maps.googleapis.com/maps/api/timezone/json" def timezone(lat, lng, timestamp): # Join the parts of the URL together into one string. params = urllib.parse.urlencode( {"location": f"{lat},{lng}", "timestamp": timestamp, "key": API_KEY,} ) url = f"{TIMEZONE_BASE_URL}?{params}" current_delay = 0.1 # Set the initial retry delay to 100ms. max_delay = 5 # Set the maximum retry delay to 5 seconds. while True: try: # Get the API response. response = urllib.request.urlopen(url) except urllib.error.URLError: pass # Fall through to the retry loop. else: # If we didn't get an IOError then parse the result. result = json.load(response) if result["status"] == "OK": return result["timeZoneId"] elif result["status"] != "UNKNOWN_ERROR": # Many API errors cannot be fixed by a retry, e.g. INVALID_REQUEST or # ZERO_RESULTS. There is no point retrying these requests. raise Exception(result["error_message"]) if current_delay > max_delay: raise Exception("Too many retry attempts.") print("Waiting", current_delay, "seconds before retrying.") time.sleep(current_delay) current_delay *= 2 # Increase the delay each time we retry. if __name__ == "__main__": tz = timezone(39.6034810, -119.6822510, 1331161200) print(f"Timezone: {tz}")
Anda juga harus berhati-hati agar tidak ada kode percobaan ulang yang lebih tinggi dalam rantai panggilan aplikasi yang menyebabkan permintaan berulang secara berurutan.
Permintaan yang Disinkronkan
Permintaan sinkron dalam jumlah besar ke API Google dapat terlihat seperti serangan Distributed Denial of Service (DDoS) pada infrastruktur Google, dan akan diperlakukan sebagaimana mestinya. Untuk menghindari hal ini, Anda harus memastikan bahwa permintaan API tidak disinkronkan di antara klien.
Misalnya, pertimbangkan aplikasi yang menampilkan waktu dalam zona waktu saat ini. Aplikasi ini mungkin akan menyetel alarm di sistem operasi klien yang membangunkannya pada awal menit sehingga waktu yang ditampilkan dapat diperbarui. Aplikasi harus tidak melakukan panggilan API apa pun sebagai bagian dari pemrosesan yang terkait dengan alarm tersebut.
Melakukan panggilan API sebagai respons terhadap alarm tetap tidak baik karena menyebabkan panggilan API disinkronkan ke awal menit, bahkan di antara perangkat yang berbeda, bukan didistribusikan secara merata dari waktu ke waktu. Aplikasi yang didesain dengan buruk yang melakukan hal ini akan menghasilkan lonjakan traffic enam puluh kali lipat dari tingkat normal di awal setiap menit.
Sebagai gantinya, satu rancangan yang mungkin baik adalah menyetel alarm kedua ke waktu terpilih yang acak. Saat alarm kedua ini diaktifkan, aplikasi akan memanggil API yang diperlukan dan menyimpan hasilnya. Saat ingin memperbarui tampilannya di awal menit, aplikasi akan menggunakan hasil yang disimpan sebelumnya, bukan memanggil API lagi. Dengan pendekatan ini, panggilan API tersebar secara merata dari waktu ke waktu. Selain itu, panggilan API tidak menunda rendering saat tampilan diperbarui.
Selain awal menit, waktu sinkronisasi umum lainnya yang harus Anda waspadai agar tidak menargetkan adalah awal jam, dan awal setiap hari pada tengah malam.
Memproses Respons
Bagian ini membahas cara mengekstrak nilai-nilai ini secara dinamis dari respons layanan web.
Layanan web Google Maps memberikan respons yang mudah dipahami, tetapi tidak terlalu mudah digunakan. Saat menjalankan kueri, Anda mungkin ingin mengekstrak beberapa nilai tertentu, bukan menampilkan kumpulan data. Secara umum, Anda akan ingin mengurai respons dari layanan web dan hanya mengekstrak nilai yang Anda minati.
Skema penguraian yang Anda gunakan bergantung pada apakah Anda menampilkan output dalam JSON. Respons JSON, yang sudah dalam bentuk objek JavaScript, dapat diproses dalam JavaScript itu sendiri di klien.