要确认一个 IP 地址所在的城市及行政区,需要使用 IP 数据库,可以从第三方提供商购买或下载。
以下以纯真IP数据库为例,假设已将纯真IP数据库的文件 qqwry.dat
放置到 Fastadmin 根目录下的 public\plugins\ip2region
目录中,可以创建一个名为 ip2region.php
的控制器(Controller)用于查询 IP 地址所在的城市及行政区。
首先需要使用 ip2region
扩展类库,可以在控制器的 __construct()
方法中初始化:
// 引入 ip2region 扩展类库
require_once VENDOR_PATH . 'ip2region/ip2region.class.php';
class Ip2region extends Controller
{
private $ip2region;
public function __construct()
{
$this->ip2region = new \Ip2Region();
// 设置 ip2region 数据库文件路径
$this->ip2region->create(DOC_ROOT . 'public/plugins/ip2region/qqwry.dat');
}
...
然后在控制器中创建一个名为 search()
的方法,用于查询 IP 地址所在的城市及行政区:
public function search($ip)
{
if (empty($ip)) {
return ['code' => 0, 'msg' => '请输入IP地址'];
}
if (!$this->ip2region) {
return ['code' => 0, 'msg' => '无法查询IP地址'];
}
// 查询 IP 地址信息
$result = $this->ip2region->btreeSearch($ip);
if (!empty($result['region'])) {
// 解析 IP 地址信息
$pos = strrpos($result['region'], '|');
$city = ($pos === false) ? $result['region'] : substr($result['region'], $pos + 1);
$pos = strrpos($result['region'], '|', strlen($result['region']) - strlen($city) - 2);
$province = ($pos === false) ? '' : substr($result['region'], 0, $pos);
return ['code' => 1, 'data' => ['province' => $province, 'city' => $city]];
} else {
return ['code' => 0, 'msg' => '无法查询IP地址'];
}
}
最后,在路由文件中创建对应的路由规则,例如:
Route::rule('ip2region/search/:ip', 'ip2region/search');
然后在浏览器中访问 http://yourdomain.com/index.php?s=/ip2region/search/121.175.101.9
即可查询 IP 地址 121.175.101.9
所在的城市及行政区。其中 yourdomain.com
需要替换为实际的网站域名或 IP 地址。
需要注意的是,纯真IP数据库中的 IP 地址信息并不是百分之百准确的,有时会有误差或缺失。另外,为了防止恶意访问或 SQL 注入等安全问题,需要对用户输入的 IP 地址进行验证和过滤。