yebto/laravel-geoip-api 问题修复 & 功能扩展

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

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

yebto/laravel-geoip-api

最新稳定版本:v1.0.0

Composer 安装命令:

composer require yebto/laravel-geoip-api

包简介

Laravel SDK wrapper for the YEB GeoIP API. Fetch City, country or ASN information from any IP, with emoji flags.

README 文档

README

Latest Version on Packagist Total Downloads

Official Laravel SDK for the YEB GeoIP API by NETOX Ltd. — a lightweight wrapper for fast and accurate IP geolocation (City, Country, ASN) in Laravel applications.

Table of Contents

Installation

Install the package using Composer:

composer require yebto/laravel-geoip-api

Publish the configuration file:

php artisan vendor:publish --tag=geoipapi-config

Add your API key to your .env file:

YEB_KEY_ID=your_api_key_here

Usage

Import the facade and start making API calls:

use GeoIPAPI;

Examples

1) City Lookup

$city = GeoIPAPI::city('21.85.7.138');

// Sample shape:
// $city['data'] => [
//   'ip', 'hostname', 'city', 'region', 'country', 'loc', 'org', 'postal', 'timezone', ...
// ]

2) Country Lookup

$country = GeoIPAPI::country('85.85.7.138');

// Sample shape:
// $country['data'] => [
//   'ip', 'country', 'country_name', 'isEU', 'country_flag',
//   'continent' => ['code', 'name'],
// ]

3) ASN Lookup

$asn = GeoIPAPI::asn('55.85.7.138');

// Sample shape:
// $asn['data'] => [ 'ip', 'org', 'asn', 'network' ]

4) Generic Query

$response = GeoIPAPI::query('city', '77.85.7.138');
// Supported databases: 'city', 'country', 'asn'

💡 If the IP is omitted (e.g. GeoIPAPI::city();), the backend uses the requester's IP automatically via Request::ip().

5) Error Handling

try {
    $city = GeoIPAPI::city('67.85.7.138');
} catch (\RuntimeException $e) {
    // Log or handle the error
    \Log::error($e->getMessage());
}

Available Methods

  • GeoIPAPI::city(?string $ip = null)API Docs
  • GeoIPAPI::country(?string $ip = null)API Docs
  • GeoIPAPI::asn(?string $ip = null)API Docs
  • GeoIPAPI::query(string $db, ?string $ip = null)API Docs

Parameters Reference

Helper Required Optional
city ip (when not auto-detected)
country ip (when not auto-detected)
asn ip (when not auto-detected)
query db (city | country | asn) ip (when not auto-detected)

💡 All methods accept additional parameters supported by the API, which will be forwarded transparently.

Configuration

The SDK uses a single environment variable:

YEB_KEY_ID=your_api_key_here

You may customize other configuration settings via config/geoipapi.php after publishing:

return [
    'base_url' => 'https://api.yeb.to/v1/', // default
    'key'      => env('YEB_KEY_ID'),
    'curl'     => [
        CURLOPT_TIMEOUT   => 3,
        CURLOPT_USERAGENT => 'Laravel-GeoIP-Client',
        // Add more cURL options as needed
    ],
];

Features

  • Simple, expressive API via a Laravel Facade
  • City, Country, and ASN lookups
  • Auto-detects the requester IP when omitted
  • Small footprint — no local databases to maintain
  • Customizable cURL options (timeouts, user agent, etc.)
  • Clean error handling with RuntimeException on failed requests
  • Built for Laravel; zero-config auto-discovery

Free Tier Access

🎁 Get 1,000+ free API requests by registering on yeb.to using your Google account.

Steps:

  1. Visit https://yeb.to
  2. Click Login with Google
  3. Retrieve your API key and add it to .env as YEB_KEY_ID

No credit card required!

Troubleshooting

  • Ensure your API key is correct and active (YEB_KEY_ID)
  • Double-check that the config file is published (php artisan vendor:publish --tag=geoipapi-config)
  • Validate parameters against the API reference
  • Check for typos in method names or required fields
  • Consider adjusting CURLOPT_TIMEOUT in config/geoipapi.php for slower networks
  • Inspect your application/network firewall rules if requests time out

Support

License

© NETOX Ltd. Licensed under a proprietary or custom license unless stated otherwise in the repository.

💬 Have a feature request or improvement idea? Reach out at support@yeb.to — we’d love to hear from you!

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-08-17