imjonos/laravel-dadata-api 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

imjonos/laravel-dadata-api

最新稳定版本:1.0

Composer 安装命令:

composer require imjonos/laravel-dadata-api

包简介

Laravel package for Dadata API - address suggestions, cleaning, company and bank data lookup

README 文档

README

Laravel package for working with Dadata API - address suggestions, data cleaning, company and bank information lookup.

Features

  • Address suggestions with FIAS support
  • Address cleaning and standardization
  • Phone number cleaning
  • Company search by INN
  • Bank search by BIC/SWIFT
  • Delivery point IDs (CDEK, Boxberry, DPD)
  • Full DTO support for type-safe data handling

Requirements

Installation

composer require imjonos/laravel-dadata-api

Configuration

Publish the configuration file:

php artisan vendor:publish --tag=dadataapi.config

Add your Dadata credentials to .env:

DADATA_TOKEN=your_api_token
DADATA_SECRET=your_secret_key

You can find your credentials in your Dadata profile.

Usage

Address Suggestions

use Nos\DadataApi\Facades\DadataApi;

// Get city suggestions
$collection = DadataApi::suggestCity('Москва');
foreach ($collection as $suggestion) {
    echo $suggestion->value;
    echo $suggestion->data->fiasId;
}

// Filter by country
$collection = DadataApi::suggestCity('London', ['GB']);

// Street suggestions (requires city FIAS ID)
$collection = DadataApi::suggestStreet('Ленина', $cityFiasId);

// House suggestions (requires street FIAS ID)
$collection = DadataApi::suggestHouse('10', $streetFiasId);

Company Search

use Nos\DadataApi\Facades\DadataApi;

// Search company by INN
$collection = DadataApi::suggestCompany('7707083893');
$company = $collection->first();

echo $company->value; // Company name
echo $company->data->inn;
echo $company->data->ogrn;

Bank Search

use Nos\DadataApi\Facades\DadataApi;

$collection = DadataApi::suggestBank('Сбербанк');
$bank = $collection->first();

echo $bank->value;
echo $bank->data->bic;
echo $bank->data->swift;

Address Cleaning

use Nos\DadataApi\Facades\DadataApi;

$address = DadataApi::cleanAddress('москва сухонская 11/-89');

echo $address->result; // г Москва, ул Сухонская, д 11, кв 89
echo $address->postalCode; // 127642
echo $address->geoLat; // 55.8783089
echo $address->geoLon; // 37.6537862

Phone Cleaning

use Nos\DadataApi\Facades\DadataApi;

$phone = DadataApi::cleanPhone('8(495)123-45-67');

echo $phone->phone; // +7 495 123-45-67
echo $phone->countryCode; // +7
echo $phone->timezone; // UTC+3

Delivery Points

use Nos\DadataApi\Facades\DadataApi;

// Get CDEK, Boxberry, DPD IDs by KLADR ID
$collection = DadataApi::suggestDeliveryId('3100400100000');
$delivery = $collection->first();

echo $delivery->data->cdekId;
echo $delivery->data->boxberryId;
echo $delivery->data->dpdId;

Available Methods

All suggestion methods return SuggestionCollection:

Method Parameters Description
suggestCity $query, $countryCodeISO, $count City suggestions
suggestStreet $query, $fiasId, $count Street suggestions
suggestHouse $query, $streetFiasId, $count House suggestions
suggestCountry $query, $count Country suggestions
suggestAddress $query, $fiasId? General address search
suggestBank $query Bank search
suggestCompany $inn Company by INN
suggestDeliveryId $kladrId Delivery point IDs
suggestAddressById $fiasId Address by FIAS ID

Clean methods return DTO objects:

Method Parameters Returns
cleanAddress $address AddressDTO
cleanPhone $phone PhoneDTO

DTO Classes

AddressDTO

Represents cleaned address with all details:

$address->result; // Formatted address
$address->postalCode;
$address->region;
$address->city;
$address->street;
$address->house;
$address->flat;
$address->geoLat;
$address->geoLon;
$address->fiasId;
$address->qc; // Quality code

PhoneDTO

Represents cleaned phone number:

$phone->phone; // Formatted phone
$phone->countryCode;
$phone->cityCode;
$phone->provider;
$phone->timezone;
$phone->qc; // Quality code

SuggestionDTO

Represents suggestion from search methods:

$suggestion->value; // Display value
$suggestion->unrestrictedValue; // Full value
$suggestion->data; // SuggestionDataDTO

SuggestionCollection

Collection of suggestions with utility methods:

$collection->count();
$collection->first();
$collection->map(fn($item) => ...);
$collection->filter(fn($item) => ...);
$collection->each(fn($item) => ...);

License

MIT License. See license.md for more information.

统计信息

  • 总下载量: 2
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 7
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-21

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固