IPTools for .NET:快速查询全球IP信息

news/2025/2/26 6:09:53

IPTools for .NET:快速查询全球IP信息

IPTools 是一个用于快速查询全球 IP 地址信息的库,支持国内和国际 IP 查询,提供详细的地理位置信息(如国家、省份、城市)以及经纬度等数据。

1. IPTools.China

IPTools.China 专注于快速查询中国 IP 地址信息,包括国家、省份、城市和网络运营商。对于非中国 IP,仅支持查询国家信息。

1.1 安装

Install-Package IPTools.China

1.2 下载数据库文件

从 GitHub 下载数据库文件,并将其放置在项目根目录(与 .csproj 文件同级),设置为“复制到输出目录”。

https://github.com/stulzq/IPTools/raw/master/db/ip2region.db

注意:1.2.0 版本开始取消了将数据库文件嵌入程序集,以方便更新并减少程序集大小。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

1.3 使用

var ipinfo = IpTool.Search("171.210.12.163");
Console.WriteLine(ipinfo.Country); // 中国
Console.WriteLine(ipinfo.Province); // 四川省
Console.WriteLine(ipinfo.City); // 成都市
Console.WriteLine(ipinfo.NetworkOperator); // 电信

1.4 性能测试

单线程双重 for 循环查询 65,025 个 IP 地址,花费约 170 毫秒。

1.5 自定义 IP 数据库文件

IpToolSettings.ChinaDbPath = "path/to/your/ip2region.db";

2. IPTools.International

IPTools.International 支持全球 IP 地址查询,提供多语言支持,地理信息包括国家、省份、城市、邮政编码、纬度和经度。

2.1 安装

Install-Package IPTools.International

2.2 下载数据库文件

从 GitHub 下载数据库文件,并将其放置在项目根目录(与 .csproj 文件同级),设置为“复制到输出目录”。

https://github.com/stulzq/IPTools/raw/master/db/GeoLite2-City.mmdb

注意:1.2.0 版本开始取消了将数据库文件嵌入程序集,以方便更新并减少程序集大小。

2.3 使用

var ipinfo = IpTool.SearchWithI18N("171.210.12.163");
Console.WriteLine(ipinfo.Country); // China
Console.WriteLine(ipinfo.CountryCode); // CN
Console.WriteLine(ipinfo.Province); // Sichuan
Console.WriteLine(ipinfo.ProvinceCode); // SC
Console.WriteLine(ipinfo.City); // Chengdu
Console.WriteLine(ipinfo.Latitude); // 30.6667
Console.WriteLine(ipinfo.Longitude); // 104.6667
Console.WriteLine(ipinfo.AccuracyRadius); // 50

2.4 国际化

默认语言为中文,可以通过以下代码设置其他语言(例如英文):

IpToolSettings.DefaultLanguage = "en";

示例:

var ipinfo = IpTool.SearchWithI18N("171.210.12.163", "en");
Console.WriteLine(ipinfo.Country); // China
Console.WriteLine(ipinfo.CountryCode); // CN
Console.WriteLine(ipinfo.Province); // Sichuan
Console.WriteLine(ipinfo.ProvinceCode); // SC
Console.WriteLine(ipinfo.City); // Chengdu
Console.WriteLine(ipinfo.Latitude); // 30.6667
Console.WriteLine(ipinfo.Longitude); // 104.6667
Console.WriteLine(ipinfo.AccuracyRadius); // 50

2.5 提升查询速度

通过将数据库文件加载到内存中,可以显著提升查询速度(大约提升一倍),但会增加 60-70MB 内存占用。

IpToolSettings.LoadInternationalDbToMemory = true;

版本要求:>= 1.2.0

2.6 性能测试

单线程双重 for 循环查询 65,025 个 IP 地址,花费约 1500 毫秒(内存模式)。

2.7 自定义 IP 数据库文件

IpToolSettings.InternationalDbPath = "path/to/your/GeoLite2-City.mmdb";

3. ASP.NET Core 支持

IPTools 提供了对 HttpContext 对象的扩展方法,便于在 ASP.NET Core 应用中获取远程 IP 信息。

var ipInfo = HttpContext.GetRemoteIpInfo();
// 或者从请求头获取 IP 地址信息(适用于 Nginx、HAProxy 等代理)
var ipInfoFromHeader = HttpContext.GetRemoteIpInfo("X-Forwarded-For");

4. 同时使用 IPTools.China 和 IPTools.International

IPTools.ChinaIPTools.International 都实现了 IIpSearcher 接口,IpTool 类在加载时会根据已安装的程序包进行初始化。

  • DefaultSearcher:默认使用的 IP 搜索器。
  • IpChinaSearcher:对应 IPTools.China 实现的搜索器。
  • IpAllSearcher:对应 IPTools.International 实现的搜索器。

如果你只安装了 IPTools.China,那么 DefaultSearcher 将是 IpChinaSearcherIpAllSearchernull

如果你只安装了 IPTools.International,那么 DefaultSearcher 将是 IpAllSearcherIpChinaSearchernull

如果你同时安装了两个组件,默认情况下 DefaultSearcher 将是 IpChinaSearcherIpChinaSearcherIpAllSearcher 都不会为 null

可以通过以下代码更改默认的搜索器:

IpToolSettings.DefalutSearcherType = IpSearcherType.China;
IpToolSettings.DefalutSearcherType = IpSearcherType.International;


http://www.niftyadmin.cn/n/5868151.html

相关文章

Vue 中动态实现进度条

在 Vue 中动态实现进度条,基本上有两种常见的方法:直接通过 Vue 数据绑定控制样式,或者利用外部库来实现更复杂的功能。我们会深入探讨这两种方式,并且详细说明每种方法的实现步骤、优缺点以及使用场景。 1. 使用 Vue 数据绑定来…

SQL*PLUS命令

SQL*Plus概述 SQL*Plus工具是随Oracle 数据库服务器或客户端的安装而自动进行安装的管理与开发工具,Oracle数据库中所有的管理操作都可以通过SQL*Plus工具完成,同时开发人员利用SQL*Plus可以测试、运行SQL语句和PL/SQL程序。 运行方式: 命令…

国科大——数据挖掘(0812课程)——课后作业

前沿: 此文章记录了2024年度秋季学期数据挖掘课程的三次课后作业,答案仅供参考。 第一次作业 1 假定数据仓库中包含4个维:date, product, vendor, location;和两个度量:sales_volume和sales_cost。 1)画…

金属热变形分析创新案例:红外相机与DIC技术耦合应用的深度研究与应用

一、方案背景 在航空航天、汽车制造、能源装备等领域,金属材料需要在高温和复杂应力条件下工作,热变形分析是确保材料可靠性和安全性的重要手段。 金属材料塑性变形阶段,大部分塑性功转化为热能,导致变形过程中温升,…

FFmpeg使用H.266/H.264/H.265编解码视频教程

以下是使用 FFmpeg 压缩视频的完整操作步骤,涵盖常用场景和参数优化: 1. 安装 FFmpeg 确保已安装最新版 FFmpeg(若已按此前步骤编译支持 H.266,可直接使用): bash 复制 sudo apt install ffmpeg # Ubuntu/…

【初阶数据结构】星河中的光影 “排” 象:排序(下)

文章目录 4.交换排序4.1 冒泡排序(BubbleSort)4.2 快速排序(QuickSort)4.2.1 hoare版本4.2.2 挖坑法4.2.3 前后指针法4.2.4 非递归实现 5.归并排序(MergeSort)5.1 递归实现5.2 非递归实现5.2.1 一次性全部拷…

算法与数据结构(格雷编码)

题目 思路 首先我们先看一下格雷编码的一些情况,为了一会方便理解,我们看它的二进制情况。 当n1时,输出[0,1] 当n2时,输出[00,01,11,10] 当n3时,输出[000, 001, 011, 010, 110, 111, 101, 100] 我们可…

栅格地图路径规划:基于雪橇犬优化算法(Sled Dog Optimizer,SDO)的移动机器人路径规划(提供MATLAB代码)

一、雪橇犬优化算法 雪橇犬优化算法(Sled Dog Optimizer,SDO)是一种于2024年10月发表在JCR1区、中科院1区SCI期刊《Advanced Engineering Informatics》的仿生元启发式算法。它受雪橇犬行为模式启发,通过模拟狗拉雪橇、训练和退役…