C#使用MaxMind.GeoIP2数据库查询当前ip地址

2023-11-21 17:28

本文主要是介绍C#使用MaxMind.GeoIP2数据库查询当前ip地址,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

GeoLite2-City.mmdb下载
因为比较简单,直接上代码,代码展示获取ip地址的国家和城市信息

using MaxMind.GeoIP2;
using MaxMind.GeoIP2.Model;
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Web;
using System.Web.Mvc;namespace IP.Demo.API.Controllers
{public class HomeController : Controller  C#有偿Q群:927860652{List<string> ipList = new List<string>();public ActionResult Index(){InitIplist();var ips =  GetIPInfos();return View(ips);}private void InitIplist(){// 获取客户端请求的IP地址var ipAddress = Request.UserHostAddress;//湖南var hn = "175.6.68.41";//台湾var tw = "210.61.221.0";//香港var hk = "58.176.0.0";//伦敦var ld = "165.3.120.76";ipList.Add(hn);ipList.Add(ipAddress);ipList.Add(tw);ipList.Add(hk);ipList.Add(ld);}private List<IPInfo> GetIPInfos() {List < IPInfo > ips = new List<IPInfo>();var reader = new DatabaseReader("D:\\C#\\IP.Demo.API\\IP.Demo.API\\bin\\GeoLite2-City.mmdb");foreach (var ipAddress in ipList){try{// 解析IP地址var ipAddressObj = IPAddress.Parse(ipAddress);var response = reader.City(ipAddressObj);IPInfo iPInfo = new IPInfo();iPInfo.ip = ipAddress;iPInfo.Country = response.Country.Names["zh-CN"];try{iPInfo.City = response.City.Names["zh-CN"];}catch{iPInfo.City = response.MostSpecificSubdivision.Names["zh-CN"];}if (iPInfo.Country.Equals("中国")){if (iPInfo.City.Equals("台湾") || iPInfo.City.Equals("香港")) iPInfo.IsDomestic = false;else iPInfo.IsDomestic = true;}elseiPInfo.IsDomestic = false;if (iPInfo.Country.Equals("中华民国")) { iPInfo.Country = "中国"; iPInfo.City ="台湾"; }if (iPInfo.Country.Equals("香港")) { iPInfo.Country = "中国"; iPInfo.City = "香港"; }ips.Add(iPInfo);}catch {//处理本地127.0.0.1的请求IPInfo iPInfo = new IPInfo();iPInfo.ip = ipAddress;iPInfo.Country = "未知";iPInfo.City = "未知";iPInfo.IsDomestic = false;ips.Add(iPInfo);}}reader.Dispose();return ips;}}public class IPInfo {public string ip { get; set; }public string Country { get; set; }public string City { get; set; }public bool IsDomestic { get; set; }}
}

视图:

@using IP.Demo.API.Controllers;
@model List<IPInfo>@foreach (var IPInfo in Model)
{<div><p>IP: @IPInfo.ip</p><p>国家: @IPInfo.Country</p><p>城市: @IPInfo.City</p>@if (IPInfo.IsDomestic){<p>国内:</p>}else {<p>国内:</p>}</div>
}

效果:
在这里插入图片描述

这篇关于C#使用MaxMind.GeoIP2数据库查询当前ip地址的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/403887

相关文章

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

如何使用Lombok进行spring 注入

《如何使用Lombok进行spring注入》本文介绍如何用Lombok简化Spring注入,推荐优先使用setter注入,通过注解自动生成getter/setter及构造器,减少冗余代码,提升开发效... Lombok为了开发环境简化代码,好处不用多说。spring 注入方式为2种,构造器注入和setter

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

Python 字典 (Dictionary)使用详解

《Python字典(Dictionary)使用详解》字典是python中最重要,最常用的数据结构之一,它提供了高效的键值对存储和查找能力,:本文主要介绍Python字典(Dictionary)... 目录字典1.基本特性2.创建字典3.访问元素4.修改字典5.删除元素6.字典遍历7.字典的高级特性默认字典

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口