如何通过 C# 判断某个 IP 所属的地区?

咨询区

  • RC1140

如何通过 C# 判断某个 IP 所属的地区?这样我就可以方便统计。

回答区

  • Jaimes

可以借助第三方API接口,参考网址:https://ipapi.co/8.8.8.8/country/ , C# 代码如下:

using System;
using System.Net;
using System.IO;
using System.Text;public class Program
{public static void Main(){ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;HttpWebRequest request   = (HttpWebRequest)WebRequest.Create("https://ipapi.co/8.8.8.8/country/");HttpWebResponse response = (HttpWebResponse)request.GetResponse();var reader = new System.IO.StreamReader(response.GetResponseStream(), ASCIIEncoding.ASCII);Console.WriteLine(reader.ReadToEnd());}
}
  • Vlam

有一个离线的 IP地区库,可以实现完全的离线查询,下载链接:https://lite.ip2location.com/database/ip-country

  1. 创建表并导入

CREATE DATABASE ip2location
GOUSE ip2location
GOCREATE TABLE [ip2location].[dbo].[ip2location_db1]([ip_from] float NOT NULL,[ip_to] float NOT NULL,[country_code] nvarchar(2) NOT NULL,[country_name] nvarchar(64) NOT NULL,
) ON [PRIMARY]
GOCREATE INDEX [ip_from] ON [ip2location].[dbo].[ip2location_db1]([ip_from]) ON [PRIMARY]
GOCREATE INDEX [ip_to] ON [ip2location].[dbo].[ip2location_db1]([ip_to]) ON [PRIMARY]
GOBULK INSERT [ip2location].[dbo].[ip2location_db1]FROM 'C:\[path to your CSV file]\IP2LOCATION-LITE-DB1.CSV'WITH(FORMATFILE = 'C:\[path to your DB1.FMT file]\DB1.FMT')
GO
  1. 代码查询

数据库有了,接下来就可以用 C# 查询了。

public class Form1 {private void Form1_Load(object sender, System.EventArgs e) {string ip = "8.8.8.8";this.IP2Location(ip);}private void IP2Location(string myip) {IPAddress address = null;if (IPAddress.TryParse(myip, address)) {byte[] addrBytes = address.GetAddressBytes();this.LittleEndian(addrBytes);UInt32 ipno = 0;ipno = BitConverter.ToUInt32(addrBytes, 0);string sql = "SELECT TOP 1 * FROM ip2location_db1 WHERE ip_to >= \'" + ipno.ToString() + "\'";object conn = new SqlConnection("Server=yourserver;Database=yourdatabase;User Id=youruserid;Password=yourpassword;");object comm = new SqlCommand(sql, conn);SqlDataReader reader;comm.Connection.Open();reader = comm.ExecuteReader(CommandBehavior.CloseConnection);int x = 0;object sb = new StringBuilder(250);if (reader.HasRows) {if (reader.Read()) {for (x = 0; (x <= (reader.FieldCount() - 1)); x++) {sb.Append((reader.GetName(x) + (": " + (reader.GetValue(x) + "\r\n"))));}}}reader.Close();MsgBox(sb.ToString());}}private void LittleEndian(ref byte[] byteArr) {if (BitConverter.IsLittleEndian) {List<byte> byteList = new List<byte>(byteArr);byteList.Reverse();byteArr = byteList.ToArray();}}
}

点评区

没想到还有离线版本的 IP地址库,这个不错,学习了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/291511.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

4月12日 webform基本控件

服务器基本控件&#xff1a; button: text属性 linkbutton:text属性&#xff0c;它是一个超链接模样的普通button hyperlink: navigateurl:链接地址&#xff0c;相当于<a>标签 imagebutton:imageurl:指定图片路径&#xff0c;这也是一个按钮&#xff0c;执行click事件 im…

C/C++之函数返回值为指针或者是引用时常见错误总结

1、说明 函数如果是指针或则引用的返回,一般全局变量、局部静态变量、局部动态分配内存的变量可以使用作为函数的返回值,局部变量不行,因为局部变量函数调用完会自动销毁内存,这个时候返回的指针或则引用就有问题了。 2、展示代码 #include <iostream> #include <…

我做了一个 Istio Workshop,这是第一讲介绍

我是 Jimmy Song[1]&#xff0c;Tetrate 布道师&#xff0c;云原生社区创始人。你可以能想到为什么在这个时候创建一个 Istio 教程&#xff0c;因为市面上已经林林总总有不少关于 Istio 的书籍和教程了&#xff0c;但是我们都知道 Istio 是一个新兴技术&#xff0c;发展十分迅速…

Swoole入门指南:PHP7安装Swoole详细教程(一)

好久未更新了&#xff0c;不是懒呃&#xff0c;是太忙啦&#xff01;终于偷得浮生几日闲。这一段时间准备为大家带来swoole的入门教程&#xff0c;感受一下php的nodeJs强悍之处。 所有的示例代码均放在了github上&#xff1a;learn-swoole 环境 这里不在使用apache做为web serv…

mysql如何快速插入一千万条数据_如何快速安全的插入千万条数据?

最近有个需求解析一个订单文件&#xff0c;并且说明文件可达到千万条数据&#xff0c;每条数据大概在20个字段左右&#xff0c;每个字段使用逗号分隔&#xff0c;需要尽量在半小时内入库。思路1.估算文件大小因为告诉文件有千万条&#xff0c;同时每条记录大概在20个字段左右&a…

解决 同时安装 python3,python2环境时,用pip安装 python3 包

应用场景 默认mac上已经安装了 python2; 而我又安装了 python3&#xff0c;并使用 python3; 安装了 pip 默认&#xff0c;pip安装的包安装在了 python2上了&#xff1b; 但是我想用 pip把安装的包安装在 python3上 &#xff0c;所以如下解决方式&#xff1b; 1&#xff1a;在ma…

C/C++之#ifdef、#if、#if defined的区别

1、看代码 2、运行结果 3、分析 #fi&#xff1a;后面接的表达式&#xff0c;如果为1就编译包含里面的内容 #ifdef&#xff1a;后面接的是一个宏&#xff0c;只要定义这个宏就行 #if defined(x)&#xff1a;和#ifdef效果一样 #if !defined(x)&#xff1a;和#ifndef效果一样

如何下载EP的各个版本?

到teamCity上面去下载 http://adc00cbv.us.oracle.com:8090/ 这里面刚进去是什么都没有的&#xff0c;要点击 Configure visible projects 配置一下才会显示 EP的各个版本是在V6.1.1.X中去下载的&#xff0c;也即EP和prodika是在一起出release 版本的。 转载于:https://www.cnb…

mysql丢失链接_MySQL远程连接丢失问题解决方法

最近远程连接mysql总是提示Lost connection to MySQL server at ‘reading initial communication packet’, system error: 0很明显这是连接初始化阶段就丢失了连接的错误其实问题很简单&#xff0c;都是MySQL的配置文件默认没有为远程连接配置好&#xff0c;只需要更改下MySQ…

.Net Core 读取文件时中文乱码问题的解决方法

背景今天在使用core web api上传txt文档的时候本来很顺利的&#xff0c;但是一测试发现读取的中文内容是乱码的&#xff0c;很是纳闷。出于经验&#xff0c;立马把代码的Encoding.Default改成 Encoding.uft8, 发现还是不行。后面索性把上传的文件另存为下&#xff0c;特地选择带…

mysql表空间被占用,同名表无法创建或导入

删除mysql表&#xff08;用的是innodb&#xff09;时没有用drop table命令&#xff0c;只是简单删除表目录&#xff0c;这导致表空间还存在&#xff0c;这样就不可以加同名表进去。当要重新导入新的同名表或者创建新的同名表时&#xff0c;会提示错误Error : Tablespace for ta…

C++编译代码的时候提示‘getInstance’ is not a member of ‘A’ A a = A::getInstance();解决办法

今天搞C类模板的时候&#xff0c;写个实例&#xff0c;发现提示下面的错误 ‘getInstance’ is not a member of ‘A’A& a A::getInstance();代码&#xff1a; class A {public:static T& Getinstance() {//}};//调用的时候写成了A::getinstance(); 解决办法&#…

关于使用indexedDB的本地存储(2)

我又回来了~这几天估计没喝茶&#xff0c;每天头都晕晕的&#xff0c;昨晚上和室友看了素鸡7&#xff0c;伤心啊&#xff0c;自己一直都喜欢这个系列&#xff0c;感觉童年真的是渐行渐远了…… 上一篇说到了哪些内容我这里罗列一下 建立和打开数据库、删除数据库、判断objectSt…

mysql数据库时间突然是12小时制_为什么存入mysql数据库中的timestamp,晚了13或14个小时...

# 为什么存入mysql数据库中的timestamp&#xff0c;晚了13个小时## 查看数据库时区show variables like %time_zone%;select global.system_time_zone;select global.time_zone;可以得到默认数据库时区&#xff1a;system_time_zone | CST |time_zone | SYSTEM|## CST时区&…

BCVP开发者社区2022专属周边第一弹

BCVP TeamBCVP开发者社区是博主老张的哲学发起&#xff0c;鼓励每个人都可参与的一个分享社区&#xff0c;目前已经有12个参与者&#xff0c;19个开源项目。欢迎加入BCVP&#xff0c;获取专属周边礼品&#xff08;文末有介绍&#xff09;。官方博客还在筹建中&#xff0c;预计2…

转 php include

http://www.w3school.com.cn/php/php_includes.asp PHP include 实例 例子 1 假设我们有一个名为 "footer.php" 的标准的页脚文件&#xff0c;就像这样&#xff1a; <?php echo "<p>Copyright © 2006-" . date("Y") . " W3S…

在C++中调用DLL中的函数(2)

本文转自&#xff1a;http://blog.sina.com.cn/s/blog_53004b4901009h3b.html 应用程序使用DLL可以采用两种方式&#xff1a;一种是隐式链接&#xff0c;另一种是显式链接。在使用DLL之前首先要知道DLL中函数的结构信息。Visual C6.0在VC\bin目录下提供了一个名为Dumpbin.exe的…

C++之类模板最简单的使用

1、说明类模板 1) 声明类模板时要增加一行 template <class 类型参数名> template意思是“模板”,是声明类模板时必须写的关键字。在template后面的尖括号内的内容为模板的参数表列,关键字class表示其后面的是类型参数 2、写代码理解 3、运行结果 4、总结 上…

win7将 esc与 capslock 互换

一天手软&#xff0c;于是买了一个机械键盘。cherry g80-3494 红轴各方面都不错就是有一个问题我经常用vim&#xff0c;其中esc。及F键区离主键盘区实在是太远了。 习惯于vim模式的人都有一种懒症&#xff0c;就是手指非常的不喜欢就离开了主键盘区。 于是就寻思着怎么样解决这…

mysql 5.5主从同步_MySQL5.5+配置主从同步并结合ThinkPHP5设置分布式数据库

This browser does not support music or audio playback. Please play it in WeChat or another browser.前言&#xff1a;本文章是在同处局域网内的两台windows电脑&#xff0c;且MySQL是5.5以上版本下进行的一主多从同步配置&#xff0c;并且使用的是集成环境工具PHPStudy为…