در حال بارگذاری

پرش به مطلب اصلی

سرویس جستجوی مکان‌مبنا (Search API)

وب‌سرویس جستجوی مکان‌مبنا، با توجه به یک نقطه‌ مرجع (مختصات جغرافیایی)، بهترین نتایج ممکن را برای جستجوی نام خیابان‌ها، اماکن و کسب‌وکارها در اختیار شما قرار می‌دهد. این سرویس یکی از کامل‌ترین سرویس‌های جستجوی موقعیت‌محور در ایران است که با پشتیبانی کامل از زبان فارسی، نتایج را بر اساس فاصله از نقطه مرجع مرتب کرده و در هر درخواست، حداکثر ۳۰ نتیجه مرتبط را باز می‌گرداند.

نکته

نقطه‌ مرجع می‌تواند موقعیت فعلی کاربر یا مرکز نقشه‌ای باشد که در حال مشاهده آن است. ارسال این پارامتر به بهبود کیفیت نتایج کمک شایانی می‌کند.

اطلاع
  1. ۱

    اولین قدم ثبت‌نام و دریافت API KEY برای اپلیکیشنی است که قصد دارید در آن از Map Api نشان استفاده کنید. کافیست در لینک فوق فرم مربوطه را تکمیل کنید تا بلافاصله API KEY را دریافت نمایید.

  2. ۲

    Api Key دریافتی از پنل توسعه‌دهندگان نشان را به صورتی که در ادامه مشاهده می‌کنید از طریق کلید Api-Key در header درخواست سرویس بگنجانید.

  3. ۳

    درخواست خود را با توجه به پارامترهایی که مربوط به سرویس موردنظرتان است با متد GET فراخوانی کنید.

  4. ۴

    چنانچه درخواست شما با موفقیت پردازش و پاسخ داده شود، خروجی با فرمت JSON دریافت خواهید کرد و چنانچه به هر دلیل خطایی رخ دهد، کد خطا بصورت HTTP Status Code و نوع آن با فرمت JSON ارسال می‌گردد. کدهای خطای احتمالی نیز در ادامه به صورت کامل توضیح داده شده‌اند.

شیوه‌ فراخوانی

برای استفاده از این سرویس، یک درخواست GET به اندپوینت زیر ارسال کنید:

https://api.neshan.org/v1/search?term=YOUR_SEARCH_TERM&lat=LATITUDE&lng=LONGITUDE

هدرهای درخواست (Headers)

Api-Key: YOUR_API_KEY

پارامترهای ورودی

پارامترتوضیحاتنوع پارامتر
termعبارت مورد نظر برای جستجو.اجباری
latعرض جغرافیایی (Latitude) نقطه مرجع برای مرکز جستجو.اجباری
lngطول جغرافیایی (Longitude) نقطه مرجع برای مرکز جستجو.اجباری

نمونه درخواست

curl --location 'https://api.neshan.org/v1/search?term=YOUR_SEARCH_TERM&lat=LATITUDE&lng=LONGITUDE' \
--header 'Api-Key: YOUR_API_KEY'

فرمت پاسخ

پاسخ سرویس در قالب یک آبجکت JSON بازگردانده می‌شود.

{
"count": 25,
"items": [
{
"title": "میدان آزادی",
"address": "تهران، میدان آزادی",
"neighbourhood": "استاد معین",
"region": "تهران، استان تهران",
"type": "میدان",
"category": "municipal",
"location": {
"x": 51.352,
"y": 35.700
}
}
]
}

اجزای پاسخ

پارامترتوضیحات
countتعداد کل نتایج یافت‌شده.
itemsآرایه‌ای از نتایج یافت‌شده.

آبجکت item

پارامترتوضیحات
titleعنوان نتیجه یافت‌شده.
addressآدرس کامل مکان یا معبر.
neighbourhoodنام محله (در صورت وجود).
regionنام شهر و استان.
typeنوع رکورد یافت‌شده (مثلاً: مسجد، خیابان، بزرگراه، میدان).
categoryدسته‌بندی اصلی رکورد که یکی از مقادیر زیر است: place (مکان)، municipal (معبر شهری)، region (شهر، روستا، استان).
locationیک آبجکت شامل مختصات جغرافیایی نتیجه.

آبجکت location

پارامترتوضیحات
xطول جغرافیایی (Longitude).
yعرض جغرافیایی (Latitude).

کد خطاهای سرویس

HTTP CodeStatusDescription
404NOT_FOUNDکد پستی با این مشخصات یافت نشده است
400INVALID_ARGUMENTخطا در پارامتر های ورودی
470CoordinateParseErrorچنانچه مختصات جغرافیایی ارسالی معتبر نباشد رخ خواهد داد.
480KeyNotFoundدر صورتی که در فراخوانی وب‌سرویس از یک Api Key نامعتبر استفاده کنید یا Api Key خود را در header ارسال نکنید رخ خواهد داد.
481LimitExceededدر صورتی که تعداد فراخوانی وب‌سرویس‌ها از میزان مجازی که برای شما تعیین شده‌است عبور کند رخ خواهد داد.
482RateExceededچنانچه تعداد درخواست وب‌سرویس در دقیقه از حد مجاز عبور کند رخ خواهد داد.
483ApiKeyTypeErrorکلید دسترسی استفاده شده با سرویس فراخوانی شده همخوانی ندارد. بایستی از کلید دسترسی مرتبط با سرویس مورد نظر استفاده کنید.
484ApiWhiteListErrorبا توجه به اسکوپ تعریف‌شده برای این کلید، شما مجاز به استفاده نیستید.
485ApiServiceListErrorسرویس فراخوانی شده با سرویس‌های تعریف‌شده برای این کلید دسترسی همخوانی ندارد.
500GenericErrorوقوع خطای ناشناخته