ip2region 在nodejs中的使用

ip2region 在nodejs中的使用

ip2region v2.0 - 是一个离线IP地址定位库和IP定位数据管理框架,10微秒级别的查询效率,提供了众多主流编程语言的 xdb 数据生成和查询客户端实现。

在项目中使用

1.下载ip2region模块导入到项目中

不使用这个:

npm i ip2region --save

npm命令安装的ip2region模块似乎是基于typescript语法,使用import导入包。而nodejs采用的是CommonJS的模块化规范,不支持import语句,安装其他支持插件又更加繁琐,因此本文迁移ip2region在gitee上的仓库项目,gitee仓库里的项目和示例代码都是基于JS和CommonJS的模块化规范的。

copy ip2region仓库项目,gitee url:https://gitee.com/lionsoul/ip2region

精简后的项目目录:

在这里插入图片描述

从上至下依次为:

index.js ==> 导入包文件

ReadMe.md ==> 示例代码(客户端三种查询方式实现)

/data/ip2region.xdb ==> ip2region数据文件

2.使用README.md中的示例代码

// 导入包
const Searcher = require('.')
// 指定ip2region数据文件路径
const dbPath = 'ip2region.xdb file path'

try {
  // 创建searcher对象
  const searcher = Searcher.newWithFileOnly(dbPath)
  // 查询
  const data = await searcher.search('218.4.167.70')
  // data: {region: '中国|0|江苏省|苏州市|电信', ioCount: 3, took: 1.342389}
} catch(e) {
  console.log(e)
}

官方提供的示例代码如上,包和数据文件的路径需要补充,值得注意的是ip2region的查询语句使用的是await异步方法,因此try catch外层还因有async函数包裹。完整代码如下:

// 导入包
const Searcher = require('./ip2region-master/binding/nodejs/index')
// 指定ip2region数据文件路径
const dbPath = './ip2region-master/data/ip2region.xdb'
async function test(ip){
    try {
        // 同步读取vectorIndex
        const vectorIndex = Searcher.loadVectorIndexFromFile(dbPath)
        // 创建searcher对象
        const searcher = Searcher.newWithVectorIndex(dbPath, vectorIndex)
        // 查询 await 或 promise均可
        const data = await searcher.search(ip)
        console.log(data)
        // data: {region: '中国|0|江苏省|苏州市|电信', ioCount: 2, took: 0.402874}
      } catch(e) {
        console.log(e)
      }
}
let ip = '218.4.167.70'
test(ip)

3.成功获取

在node项目中运行该脚本文件,成功获取数据。

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ip2region是一个准确率99.9%的离线IP地址定位库,0.0x毫秒级查询,ip2region.db数据库只有数MB,提供了java,php,c,python,nodejs,golang,c#等查询绑定和Binary,B树,内存三种查询算法。 Ip2region特性: 一、99.9%准确率 数据聚合了一些知名ip到地名查询提供商的数据,这些是他们官方的的准确率,经测试着实比经典的纯真IP定位准确一些。 二、标准化的数据格式 每条ip数据段都固定了格式: _城市Id|国家|区域|省份|城市|ISP_ 只有国的数据精确到了城市,其他国家有部分数据只能定位到国家,后前的选项全部是0,已经包含了全部你能查到的大大小小的国家(请忽略前面的城市Id,个人项目需求)。 三、体积小 包含了全部的IP,生成的数据库文件ip2region.db只有几MB,最小的版本只有1.5MB,随着数据的详细度增加数据库的大小也慢慢增大,目前还没超过8MB。 四、查询速度快 全部的查询客户端单次查询都在0.x毫秒级别,内置了三种查询算法: 1.memory算法:整个数据库全部载入内存,单次查询都在0.1x毫秒内,C语言的客户端单次查询在0.00x毫秒级别。 2.binary算法:基于二分查找,基于ip2region.db文件,不需要载入内存,单次查询在0.x毫秒级别。 3.b-tree算法:基于btree算法,基于ip2region.db文件,不需要载入内存,单词查询在0.x毫秒级别,比binary算法更快。 任何客户端b-tree都比binary算法快,当然memory算法固然是最快的! 五、多查询客户端的支持 已经集成的客户端有:java、C#、php、c、python、nodejs、php扩展(php5和php7)、golang、rust、lua、lua_c,nginx。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值