基于Go语言开发一个 IP 归属地查询接口工具

 更新时间:2025年09月22日 08:25:28   作者:程序员爱钓鱼  
在日常开发中,IP 地址归属地查询是一个常见需求,本文将带大家使用 Go 语言快速开发一个 IP 归属地查询接口服务,有需要的小伙伴可以了解下

在日常开发中,IP 地址归属地查询是一个常见需求:比如记录用户访问日志时展示用户的地理位置,或在安全防护系统中分析异常登录来源。本文将带你用 Go 语言快速开发一个 IP 归属地查询接口服务

功能目标

提供一个 HTTP 接口,输入 IP 地址返回归属地信息

支持查询单个 IP,也可扩展成批量查询

数据源可选择:

  • 本地离线 IP 数据库(如 ip2region
  • 第三方 API(如 ip-api、ipinfo 等)

结果返回 JSON 格式

技术栈

Go 标准库net/httpencoding/json

第三方库

github.com/lionsoul2014/ip2region/binding/golang/xdb —— 离线 IP 数据库解析

存储方式:使用本地 ip2region.xdb 文件

项目结构

ip-lookup/
├── main.go
├── ip2region.xdb   # 离线数据库文件
├── go.mod

核心代码(main.go)

package main

import (
	"encoding/json"
	"log"
	"net"
	"net/http"

	"github.com/lionsoul2014/ip2region/binding/golang/xdb"
)

// 响应结构
type IPInfo struct {
	IP      string `json:"ip"`
	Region  string `json:"region"`
	Error   string `json:"error,omitempty"`
}

var searcher *xdb.Searcher

func main() {
	// 加载 ip2region 数据库
	var err error
	searcher, err = xdb.NewWithFileOnly("ip2region.xdb")
	if err != nil {
		log.Fatalf("❌ 加载 ip2region.xdb 失败: %v", err)
	}

	http.HandleFunc("/ip", queryIP)

	log.Println("✅ IP 归属地查询服务已启动: http://localhost:8080/ip?addr=1.1.1.1")
	http.ListenAndServe(":8080", nil)
}

func queryIP(w http.ResponseWriter, r *http.Request) {
	addr := r.URL.Query().Get("addr")
	if addr == "" {
		writeJSON(w, IPInfo{Error: "缺少参数 addr"})
		return
	}

	if net.ParseIP(addr) == nil {
		writeJSON(w, IPInfo{IP: addr, Error: "无效的 IP 地址"})
		return
	}

	region, err := searcher.SearchByStr(addr)
	if err != nil {
		writeJSON(w, IPInfo{IP: addr, Error: err.Error()})
		return
	}

	writeJSON(w, IPInfo{IP: addr, Region: region})
}

func writeJSON(w http.ResponseWriter, data IPInfo) {
	w.Header().Set("Content-Type", "application/json")
	json.NewEncoder(w).Encode(data)
}

使用方法

1.初始化项目并安装依赖

go mod init ip-lookup
go get github.com/lionsoul2014/ip2region/binding/golang/xdb

2.下载 ip2region.xdb 数据库文件,放到项目根目录

3.运行

go run main.go

4.请求示例

curl "http://localhost:8080/ip?addr=8.8.8.8"

返回结果示例:

{
  "ip": "8.8.8.8",
  "region": "美国|0|加利福尼亚|圣克拉拉|谷歌"
}

扩展功能

  • 批量查询:支持上传 IP 列表文件,返回批量结果
  • 缓存机制:对高频 IP 查询做缓存,提升性能
  • 前端展示:结合简单前端页面展示查询结果
  • 多数据源支持:同时支持 ip2region 和第三方 API,作为备份

总结

通过本案例,我们实现了一个 IP 归属地查询接口,使用 ip2region 离线库做到快速查询,性能高效且无需依赖外部服务。这个小工具既能单独运行,也能嵌入到日志分析、Web 服务或安全监控系统中使用,是 Go 项目开发中的一个实用模块。

到此这篇关于基于Go语言开发一个 IP 归属地查询接口工具的文章就介绍到这了,更多相关Go查询IP归属地内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Golang使用bcrypt实现密码加密和校验的操作代码

    Golang使用bcrypt实现密码加密和校验的操作代码

    bcrypt可以用于数据库中的用户密码保存,相比md5而言更加的安全可靠,这篇文章主要介绍了Golang使用bcrypt实现密码加密和校验的操作代码,需要的朋友可以参考下
    2024-05-05
  • golang简单获取上传文件大小的实现代码

    golang简单获取上传文件大小的实现代码

    这篇文章主要介绍了golang简单获取上传文件大小的方法,涉及Go语言文件传输及文件属性操作的相关技巧,需要的朋友可以参考下
    2016-07-07
  • Golang errgroup 设计及实现原理解析

    Golang errgroup 设计及实现原理解析

    这篇文章主要为大家介绍了Golang errgroup 设计及实现原理解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • go-python 库使用应用案例

    go-python 库使用应用案例

    本文深入探讨了如何使用Go-Python库进行跨语言编程,以及在实际应用中的各种技巧和应用案例,在结语中,我们将对Go-Python库的使用方法与技巧进行总结,并展望Go与Python混合编程的未来发展
    2024-03-03
  • 使用client-go工具调用kubernetes API接口的教程详解(v1.17版本)

    使用client-go工具调用kubernetes API接口的教程详解(v1.17版本)

    这篇文章主要介绍了使用client-go工具调kubernetes API接口(v1.17版本),本文通过图文实例相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-08-08
  • Go strconv包实现字符串与数值转换的深度解析

    Go strconv包实现字符串与数值转换的深度解析

    在 Go 语言开发中,字符串与基本数据类型之间的转换非常常见,Go 标准库中的 strconv 包正是为这些场景设计的,下面小编就和大家详细介绍一下它的具体应用吧
    2026-03-03
  • golang程序对接prometheus过程

    golang程序对接prometheus过程

    文章介绍了如何在Golang项目中集成Prometheus进行监控,包括安装客户端库、定义和注册指标、暴露指标端点、更新指标值、配置标签和注册表,以及生产环境的建议配置
    2025-10-10
  • Go语言实现配置热加载的方法分享

    Go语言实现配置热加载的方法分享

    web项目,经常需要热启动各种各样的配置信息,一旦这些服务发生变更,我们需要重新启动web server,以使配置生效,实现配置热加载,本文为大家整理了几个方法实现这个需求,需要的可以参考下
    2023-05-05
  • Go实现分布式唯一ID的生成之雪花算法

    Go实现分布式唯一ID的生成之雪花算法

    本文主要介绍了Go实现分布式唯一ID的生成之雪花算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • Go语言切片扩容原理和过程

    Go语言切片扩容原理和过程

    切片(Slice)在 Go 语言中,有一个很常用的数据结构,切片是一个拥有相同类型元素的可变长度的序列,它是基于数组类型做的一层封装,它非常灵活,支持自动扩容,并发不安全,本文给大家介绍了Go 语言切片如何扩容,需要的朋友可以参考下
    2025-02-02

最新评论