این سند مراحل لازم برای شروع استفاده از API ژئوکدینگ را شرح میدهد.
| مطمئن شوید که پیشنیازها را رعایت میکنید. | API را در پروژه Google Cloud خود فعال کنید. | یک کلید API یا OAuth را برای ارسال یک درخواست API احراز هویت شده پیکربندی کنید. |
محصولات پلتفرم نقشههای گوگل با الزام فراخوانیهای API به شامل کردن کلید API یا توکن OAuth، از استفاده غیرمجاز ایمن میشوند.
یک توکن OAuth ایجاد کنید
API ژئوکدینگ از استفاده از OAuth 2.0 برای احراز هویت پشتیبانی میکند. گوگل از سناریوهای رایج OAuth 2.0 مانند سناریوهای مربوط به یک وب سرور پشتیبانی میکند.
این سند نحوه ارسال یک توکن OAuth به فراخوانی Geocoding API در محیط توسعه شما را شرح میدهد. برای دستورالعملهای استفاده از OAuth در یک محیط عملیاتی ، به روشهای احراز هویت در گوگل مراجعه کنید.
درباره OAuth
روشهای زیادی برای ایجاد و مدیریت توکنهای دسترسی با OAuth بر اساس محیط استقرار شما وجود دارد.
برای مثال، سیستم Google OAuth 2.0 از تعاملات سرور به سرور، مانند تعاملات بین برنامه شما و یک سرویس گوگل، پشتیبانی میکند. برای این سناریو، شما به یک حساب کاربری سرویس نیاز دارید، که حسابی است که به برنامه شما تعلق دارد نه به یک کاربر نهایی. برنامه شما APIهای گوگل را از طرف حساب کاربری سرویس فراخوانی میکند، بنابراین کاربران مستقیماً درگیر نمیشوند. برای اطلاعات بیشتر در مورد روشهای احراز هویت، به روشهای احراز هویت در گوگل مراجعه کنید.
به عنوان یک روش جایگزین، میتوانید از API ژئوکدینگ به عنوان بخشی از یک برنامه تلفن همراه اندروید یا iOS استفاده کنید. برای اطلاعات کلی در مورد استفاده از OAuth با API ژئوکدینگ، از جمله اطلاعات مربوط به مدیریت توکنهای دسترسی برای محیطهای استقرار مختلف، به بخش «استفاده از OAuth 2.0 برای دسترسی به APIهای گوگل» مراجعه کنید.
درباره دامنههای OAuth
برای استفاده از OAuth با Geocoding API، باید به توکن OAuth دامنه صحیح اختصاص داده شود. Geocoding API از دامنههای زیر پشتیبانی میکند:
-
https://www.googleapis.com/auth/maps-platform.geocode— قابل استفاده با تمام نقاط پایانی API مربوط به Geocoding. -
https://www.googleapis.com/auth/maps-platform.geocode.address— فقط باGeocodeAddressبرای ژئوکدینگ رو به جلو استفاده شود. -
https://www.googleapis.com/auth/maps-platform.geocode.location— فقط باGeocodeLocationبرای ژئوکدینگ معکوس استفاده شود. -
https://www.googleapis.com/auth/maps-platform.geocode.place— فقط باGeocodePlaceبرای ژئوکدینگ مکان استفاده شود.
همچنین، میتوانید از دامنه عمومی https://www.googleapis.com/auth/cloud-platform برای همه نقاط پایانی API ژئوکدینگ استفاده کنید. این دامنه در طول توسعه مفید است زیرا دامنه پیشفرض مورد استفاده هنگام ایجاد توکنها با استفاده از gcloud است.
مثال: فراخوانیهای REST API را در محیط توسعه محلی خود امتحان کنید
اگر میخواهید API مربوط به Geocoding را با استفاده از یک توکن OAuth امتحان کنید، اما محیطی برای تولید توکنها ندارید، میتوانید از رویه موجود در این بخش برای فراخوانی استفاده کنید.
این مثال نحوه استفاده از توکن OAuth ارائه شده توسط Application Default Credentials (ADC) را برای برقراری تماس شرح میدهد. برای اطلاعات بیشتر در مورد استفاده از ADC برای فراخوانی APIهای گوگل با استفاده از کتابخانههای کلاینت، به بخش احراز هویت با استفاده از کتابخانههای کلاینت مراجعه کنید.
پیشنیازها
قبل از اینکه بتوانید با استفاده از ADC درخواست REST ارسال کنید، از رابط خط فرمان گوگل کلود (Google Cloud CLI) برای ارائه اعتبارنامه به ADC استفاده کنید:
- رابط خط فرمان gcloud را نصب و راهاندازی کنید .
دستور
gcloudزیر را روی دستگاه محلی خود اجرا کنید تا فایل اعتبارنامه شما ایجاد شود:gcloud auth application-default login
- یک صفحه ورود نمایش داده میشود. پس از ورود، اطلاعات کاربری شما در فایل اطلاعات کاربری محلی که توسط ADC استفاده میشود، ذخیره میشود.
برای اطلاعات بیشتر، به تنظیم ADC برای یک محیط توسعه محلی مراجعه کنید.
درخواست REST ارسال کنید
در این مثال، شما دو هدر درخواست ارسال میکنید:
با استفاده از دستور زیر، توکن OAuth را در هدر
Authorizationوارد کنید تا توکن تولید شود:gcloud auth application-default print-access-tokenتوکن برگردانده شده دامنهای به آدرس
https://www.googleapis.com/auth/cloud-platform.- شناسه یا نام پروژه گوگل کلود خود را که امکان پرداخت در آن فعال است، در سربرگ
X-Goog-User-Projectوارد کنید.
مثال زیر با استفاده از یک توکن OAuth، فراخوانی به API مربوط به Geocoding انجام میدهد.
فیلد PROJECT_ID را ویرایش کنید تا شناسه پروژه Google Cloud خود را وارد کنید.
curl -X GET -H 'Content-Type: application/json' \ -H "Authorization: Bearer $(gcloud auth application-default print-access-token)" \ -H "X-Goog-User-Project: PROJECT_ID" \ "https://geocode.googleapis.com/v4beta/geocode/address/1600+Amphitheatre+Parkway,+Mountain+View,+CA"
- روی نماد کپی در نمونه کد کلیک کنید،
، برای کپی کردن دستور curl. - دستور را در یک پنجره ترمینال پیست کنید و دستور را اجرا کنید.
پاسخ یک شیء JSON است:
عیبیابی
اگر درخواست شما پیام خطایی مبنی بر عدم پشتیبانی اعتبارنامههای کاربر نهایی توسط این API نشان داد، به عیبیابی تنظیمات ADC خود مراجعه کنید.