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

GeoLite2-City.mmdb下载

因为比较简单,直接上代码,代码展示获取ip地址的国家和城市信息

csharp 复制代码
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;
                    }
                    else
                        iPInfo.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; }

    }
}

视图:

csharp 复制代码
@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>
}

效果:

相关推荐
程序员卷卷狗1 小时前
MySQL 高可用方案:主从 + MHA + ProxySQL + PXC 的实战应用与架构思考
数据库·mysql·架构
千千寰宇1 小时前
[数据库/数据结构] LSM-Tree :结构化的日志合并树——NewSQL数据库的基石
数据库
韩立学长2 小时前
基于Springboot的研学旅游服务系统5u416w14(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·旅游
isNotNullX3 小时前
怎么理解ETL增量抽取?
数据库·数据仓库·etl·企业数字化
谅望者3 小时前
数据分析笔记14:Python文件操作
大数据·数据库·笔记·python·数据挖掘·数据分析
l1t3 小时前
调用python函数的不同方法效率对比测试
开发语言·数据库·python·sql·duckdb
honortech3 小时前
MySQL 8 连接报错:Public Key Retrieval is not allowed
数据库·mysql
q***82913 小时前
MySQL--》如何通过选择合适的存储引擎提高查询效率?
数据库·mysql·adb
q***96583 小时前
MySql-9.1.0安装详细教程(保姆级)
数据库·mysql
IUGEI3 小时前
深入解析HTTP长连接原理
java·网络·后端·网络协议·tcp/ip·http·https