zhuzhichao/ip-location-zh

使用中文获取 IP 的位置信息

v2.4.5 2023-08-29 01:18 UTC

README

Scrutinizer Code Quality Build Status Total Downloads Latest Stable Version License

数据最后更新时间为 2019-7-3,更新时间:不定期。数据源于: http://www.ipip.net

IPIP典型客户 ipip客户

这是一个可以通过 IP 获取该 IP 所在位置的包,例如通过 ip:171.12.10.156 可以获得是 中国河南郑州,以及中国行政区划代码(支持到市级),同样能获得国外的地址,但是没有国内详细。

注意:该免费数据库不提供经纬度、运营商、行政区等更详细的内容,如果您有更多需求可以考虑使用他们的收费服务。本包的目的是提供给需求简单,手里没钱的程序员或者老板不舍得掏钱来获取定时更新的 IP 信息。

国家码和邮编不是该包负责的内容,需要自行构建相关的程序。

特点

  1. 不配置和使用数据库,妈妈再也不用担心配置问题了
  2. 使用简单,功能专一
  3. 使用 composer 进行安装管理,国际标准,方便快捷,即安即用,随时更新数据库

安装

这里不详细介绍安装 composer 了,大家根据 链接 自行安装吧!

composer require "zhuzhichao/ip-location-zh"

用法

常用

可以这样来用

require 'vendor/autoload.php';


use Zhuzhichao\IpLocationZh\Ip;


var_dump(Ip::find('171.12.10.156'));
// 返回结果
array (size=4)
  0 => string '中国' (length=6)
  1 => string '河南' (length=6)
  2 => string '郑州' (length=6)
  3 => string '' (length=0)
  4 => string '410100' (length=6)

Laravel

对于laravel可以这样优雅的用

1.安装该插件

2.在 config/app.php(Laravel 5.0 - 5.4)添加下面的代码,如果是 Laravel 5.5+ ,已经支持扩展包发现,不需要添加下面的代码

// Laravel 5.5 不需要添加
'aliases' => [
    'Ip'  => 'Zhuzhichao\IpLocationZh\Ip',

],

3.然后开始在你的项目里面使用了 Ip::find('171.12.10.156')Ip::find(Request::getClientIp())

对,很简单,只用一个方法,那就是 find

贡献

有什么新的想法和建议,欢迎提交 issue 或者 Pull Requests

许可证

MIT