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 小时前
某马来西亚游戏公司如何从 SQL Server 迁移至 OceanBase?
数据库
程序设计实验室2 小时前
C# 扩展方法只会写 this 吗?C# 14 新语法直接把扩展方法玩出了花
c#
小瓦码J码3 小时前
PostgreSQL表名超长踩坑记
数据库·postgresql
yhyyht3 小时前
InfluxDB入门记录(三)flux-dsl
数据库·后端
唐青枫4 小时前
C#.NET SignalR 深入解析:实时通信、Hub 与连接管理实战
c#·.net
唐宋元明清218810 小时前
.NET Win32磁盘动态卷/跨区卷触发“函数不正确”问题排查
windows·c#·存储
hez201011 小时前
Satori GC:同时做到高吞吐、低延时和低内存占用
c#·.net·.net core·gc·clr
IvorySQL20 小时前
PostgreSQL 技术日报 (3月9日)|EXPLAIN ANALYZE 计时优化与复制语法讨论
数据库·postgresql·开源
stark张宇1 天前
MySQL 核心内幕:从索引原理、字段选型到日志机制与外键约束,一篇打通数据库任督二脉
数据库·mysql·架构
倔强的石头_1 天前
融合数据库架构实践:关系型、JSON与全文检索的“一库多能”深度解析
数据库