05.10.2021
Полигон: API Адрес — инструмент, который обеспечивает доступ к базе адресов государственного адресного реестра (ГАР БД ФИАС). API предлагает уникальный метод по работе с адресами в формате муниципального и административного деления.
API автоматически подгружает адрес по первым буквам, разбирает адрес на составные части: от региона до квартиры, выводит структурированный адрес – в правильном порядке и без опечаток.
Когда адрес разложен «по полочкам»:
1. Правильный порядок адреса
2. Дополнительная информация (код ГАР ФИАС, ОКАТО, КЛАДР, ОКТМО, почтовый индекс и др.)
До недавнего времени на рынке присутствовали API, которые предоставляли доступ только к адресам административно-территориального деления. А вот обработки адресов по муниципальному делению не было – до реализации API: Сервис для ввода адресов в котором присутствует подобная возможность.
Также в API можно получить список нижестоящих частей адресов по уровням: например, если нужно узнать городские районы в городе Москва, или получить список домов в определенном регионе городы Москвы.
Кроме того, до реализации сервиса, на рынке было затруднительно получить идентификатор адресообразующего элемента по полному адресу вплоть до квартиры. С внедрением API такая возможность появилась.
В остальном API: Сервис для ввода адресов выполняет функции, как и у других подобных сервисов. C полным списком возможностей API можно ознакомиться в технической документации →
Доступ к БД осуществляется двумя HTTP-запросами: POST и GET. Выбор зависит от того, как Вам будет удобно использовать. Структура ответа похожа, но есть небольшие отличия:
Метод POST разрабатывался специально для тех, у кого уже внедрена работа с адресами другого API, то есть для быстрого перехода.
Метод же GET возвращает больше параметров, тем самым решая, например, проблему с адресным идентификатором до квартиры.
Самый распространенный способ применения API – помощь пользователю при вводе адреса в текстовом поле. Иными словами – полнотекстовый поиск, который будет происходить как в виде административного деления, так и муниципального.
Пример подобного GET-запроса на получение вариантов полного адреса объекта по указанному тексту:
https: //data.pbprog.ru/api/address/full-address/parse?token=123abcde123abcde123adcde123abcde123abcde&addressText=Киров,%20Ленина,%20113
Где:
token - токен для доступа к API;
addressText - непосредственно описание адреса.
Помимо обязательных параметров есть и дополнительные, например: режим поиска, количество ответов. В ответ получим массив элементов следующей структуры:
[
В данном примере присутствуют следующие элементы:
value - непосредственно адрес;
addressParts - массив с детальной информацией по элементам адреса, в который входят:
GUID объекта;
Наименование;
Сокращенное и полное название типа элемента;
Уровень вложенности;
Код КЛАДР, ОКАТО, ОКТО;
Почтовый индекс;
Признак активности.
Реальный пример описанной реализации ввода адресов Вы можете посмотреть по ссылке →
После получения ответа необходимо разложить адрес в нужном Вам формате и виде.
Например:
Но есть и другой способ использования API – расширенный поиск адреса. Например в форме, представленной на официальном сайте ФИАС.
Если для решения ваших задач необходим расширенный поиск адреса, воспользуйтесь – API: Сервис для ввода адресов.
Вам необходимо:
1. Сформировать запрос на получение регионов РФ.
Пример запроса:
https: //data.pbprog.ru/api/address/regions?token=123abcde123abcde123adcde123abcde123abcde&activeOnly=false
В ответ получим массив элементов вида:
{
"regionCode":"01",
"objectGuid":"d8327a56-80de-4df2-815c-4f6ab1224c50",
"name":"Адыгея",
"typeName":"Респ",
"fullTypeName":"Республика",
"kladr":"0100000000000",
"okato":"79000000000",
"oktmo":"79000000",
"postIndex":"385000"
}
где:
regionCode - код региона;
objectGuid - GUID ФИАС региона;
name - название региона;
typeName - сокращенное название типа региона;
fullTypeName - полное название типа региона;
kladr - код КЛАДР;
okato - код ОКАТО;
oktmo - код ОКТМО;
postIndex - почтовый индекс.
Из полученного массива элементов необходимо заполнить первое поле со списком.
2. Все остальная работа контролов зависит от выбранного родительского элемента.
То есть, выбрав регион, Вы получите GUID объекта. Далее по этому GUID Вы получаете список, например, муниципальных районов.
Пример запроса для получения районов Кировской области:
https: //data.pbprog.ru/api/address/childs/0b940b96-103f-4248-850c-26b6c7296728?token={123abcde123abcde123adcde123abcde123abcde}&hierarchyMode=adm
В ответ получим массив элементов вида:
{
"objectGuid": "c33ab87d-1f10-4eb9-a628-ab06a9fdf08b",
"name": "67",
"typeName": "д",
"fullTypeName": "дом",
"level": 10,
"okato": "79230559000",
"oktmo": "79630159051",
"postIndex": "385140",
"isActive": true,
"sublevels": [
{
"name": "1",
"typeName": "к",
"fullTypeName": "корпус"
},
{
"name": "67",
"typeName": "стр",
"fullTypeName": "строение"
}
]
}
где:
objectGuid - GUID ФИАС элемента.
name - название элемента.
typeName - сокращенное название типа элемента.
fullTypeName - полное название типа элемента.
level - уровень типа элемента.
okato - код ОКАТО.
oktmo - код ОКТМО.
postIndex - почтовый индекс.
isActive - признак активности.
sublevels - доп. уровни адреса (применимо только к домам, максимум до 2-х доп. уровней).
и далее до нужного уровня.
Важно! У каждого контрола необходимо определить свой уровень и при разборе ответа заполнить соответствующие элементы. Сами уровни представлены ниже.
level |
name |
1 |
Субъект РФ |
2 |
Административный район |
3 |
Муниципальный район |
4 |
Сельское/городское поселение |
5 |
Город |
6 |
Населенный пункт |
7 |
Элемент планировочной структуры |
8 |
Элемент улично-дорожной сети |
9 |
Земельный участок |
10 |
Здание (сооружение) |
11 |
Помещение |
12 |
Помещения в пределах помещения |
13 |
Уровень автономного округа (устаревшее) |
14 |
Уровень внутригородской территории (устаревшее) |
15 |
Уровень дополнительных территорий (устаревшее) |
16 |
Уровень объектов на дополнительных территориях (устаревшее) |
17 |
Машино-место |
С остальными примерами методов можно ознакомиться в технической документации →
Нейросети в работе педагога: экономия 80% времени на подготовку к занятиям
13.12.2024
Итоги вебинара «Медицинский контроль в ДОО: нормы, требования, документация»
13.12.2024
Итоги вебинара «Топ-20 часто задаваемых вопросов пользователей за 2024 год»
12.12.2024
Новая версия программы «Экспресс-расписание ВУЗ» от 11.12.2024 г.
11.12.2024
Новая версия программы «Экспресс-расписание: Колледж» от 10.12.2024 г.
11.12.2024
Онлайн-разбор «Топ-20 часто задаваемых вопросов пользователей за 2024 год»
09.12.2024