GeoIp 使用与技术文档
2024-12-20 19:22:20作者:史锋燃Gardner
1. 安装指南
GeoIp 是一个 Ruby Gem,可以通过以下命令安装:
gem install geo_ip
请注意,自版本 0.6.0 起,GeoIp 仅与 Ruby 1.9.3 或更高版本兼容。如果您需要与 Ruby 1.8.7 或 1.9.2 的兼容性,可以使用 0.5.0 版本。
Rails 集成
Bundler 支持(Rails 3.x 和 2.3.x)
在 Gemfile 中添加以下内容:
gem 'geo_ip'
然后创建一个初始化文件 config/initializers/geo_ip.rb(或您想要的任何名称):
GeoIp.api_key = 'YOUR_API_KEY'
预 Bundler 支持(Rails 2.3.x 或更早版本)
在 config/environment.rb 文件中添加以下内容:
config.gem 'geo_ip'
然后创建一个初始化文件 config/initializers/geo_ip.rb(或您想要的任何名称):
GeoIp.api_key = 'YOUR_API_KEY'
2. 项目的使用说明
在使用 GeoIp 之前,您需要设置 API 密钥。可以在任何地方进行设置,但必须在执行地理定位调用之前完成:
GeoIp.api_key = 'YOUR_API_KEY'
获取地理定位
要检索 IP 地址的地理定位信息,使用以下方法:
GeoIp.geolocation(ip_address)
示例
# 209.85.227.104 = google.be (美国)
GeoIp.geolocation('209.85.227.104')
返回结果:
{
:status_code => "OK",
:status_message => "",
:ip => "209.85.227.104",
:country_code => "US",
:country_name => "UNITED STATES",
:region_name => "CALIFORNIA",
:city => "MONTEREY PARK",
:zip_code => "91754",
:latitude => "34.0505",
:longitude => "-118.13"
}
只检索国家信息
如果只检索国家信息,可以排除城市细节。这样可以加快服务的响应速度,因为需要查询的数据更少。
GeoIp.geolocation('209.85.227.104', :precision => :country)
返回结果:
{
:status_code => "OK",
:status_message => "",
:ip => "209.85.227.104",
:country_code => "US",
:country_name => "UNITED STATES"
}
时区信息
还可以选择检索可选的时区信息:
GeoIp.geolocation('209.85.227.104', :timezone => true)
返回结果:
{
:status_code => "OK",
:status_message => "",
:ip => "209.85.227.104",
:country_code => "US",
:country_name => "UNITED STATES",
:region_name => "CALIFORNIA",
:city => "MONTEREY PARK",
:zip_code => "91754",
:latitude => "34.0505",
:longitude => "-118.13",
:timezone => "-08:00"
}
请注意,无法在检索时区信息时启用国家精度。
保留 / 私有 / 本地 IPs
传递保留、私有或本地 IPs(例如 127.0.0.1)将返回 - 作为所有位置数据:
GeoIp.geolocation('127.0.0.1')
返回结果:
{
:status_code => "OK",
:status_message => "",
:ip => "127.0.0.1",
:country_code => "-",
:country_name => "-",
:region_name => "-",
:city => "-",
:zip_code => "-",
:latitude => "0",
:longitude => "0"
}
超时
可以为所有请求设置超时。默认情况下,超时时间为一秒,但您可以将不同的值轻松设置。与设置 api_key 相同,您可以设置超时:
GeoIp.timeout = 5 # 将其设置为五秒
3. 项目API使用文档
GeoIp 项目主要通过其 Ruby Gem 接口提供 API。以下是主要方法的简要说明:
GeoIp.api_key: 设置用于身份验证的 API 密钥。GeoIp.geolocation(ip_address, [options]): 根据 IP 地址检索地理定位信息。options可以包括:precision和:timezone。GeoIp.timeout: 设置请求超时时间。
4. 项目安装方式
GeoIp 可以通过 Ruby Gem 安装。运行以下命令:
gem install geo_ip
对于 Rails 项目,您可以在 Gemfile 中添加 geo_ip,然后运行 bundle install。之后,在初始化文件中设置 API 密钥。
登录后查看全文
热门项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0242
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
JoyAI-VL-Interaction-Preview京东开源首个开源、视觉驱动的实时交互模型——它能实时监控视频流,并自主决定何时发言、保持沉默或委托任务。Jinja00
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0181
kornia🐍 空间人工智能的几何计算机视觉库Python03
PaddleParallel Distributed Deep Learning: Machine Learning Framework from Industrial Practice (『飞桨』核心框架,深度学习&机器学习高性能单机、分布式训练和跨平台部署)C++02
项目优选
收起
暂无描述
Dockerfile
786
5.15 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
898
2.08 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
721
1.45 K
deepin linux kernel
C
32
16
Ascend Extension for PyTorch
Python
767
989
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
471
481
CANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。
Jupyter Notebook
483
181
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.13 K
1.17 K
昇腾LLM分布式训练框架
Python
189
240
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
157
249