通过IP地址获取相应的城市

通过IP地址获取相应的城市

使用GeoLite2 City库

GeoLite2 City下载地址:http://dev.maxmind.com/geoip/geoip2/geolite2/
在这里插入图片描述
下载完后解压,保存目录路径
在这里插入图片描述
在maven项目中的pom.xml配置文件添加依赖

<dependency>
     <groupId>com.maxmind.geoip2</groupId>
     <artifactId>geoip2</artifactId>
     <version>2.8.1</version>
</dependency>

通过GeoLite2查询得到省份、城市

public static void main(String[] args) throws IOException {
        // 创建 GeoLite2 数据库
        File database = new File("C:/Users/12059/Desktop/GeoLite2-City_20190326/GeoLite2-City.mmdb");
        // 读取数据库内容
        DatabaseReader reader = new DatabaseReader.Builder(database).build();
        InetAddress ipAddress = InetAddress.getByName("219.136.134.157");

        // 获取查询结果
        CityResponse response = null;
        try {
            response = reader.city(ipAddress);

            // 获取国家信息
            Country country = response.getCountry();
            System.out.println(country.getIsoCode());               // 'CN'
            System.out.println(country.getName());                  // 'China'
            System.out.println(country.getNames().get("zh-CN"));    // '中国'

            // 获取省份
            Subdivision subdivision = response.getMostSpecificSubdivision();
            System.out.println(subdivision.getName());   // 'Guangdong'
            System.out.println(subdivision.getIsoCode()); // 'GD'
            System.out.println(subdivision.getNames().get("zh-CN")); // '广东'

            // 获取城市
            City city = response.getCity();
            System.out.println(city.getName()); // 'Guangzhou'
            Postal postal = response.getPostal();
            System.out.println(postal.getCode()); // 'null'
            System.out.println(city.getNames().get("zh-CN")); // '广州'
            Location location = response.getLocation();
            System.out.println(location.getLatitude());  // 23.1167
            System.out.println(location.getLongitude()); // 113.25
        } catch (GeoIp2Exception e) {
            e.printStackTrace();
        }
 }

此处注意,该路径换成存放GeoLite2-City.mmdb的路径

File database = new File("C:/Users/12059/Desktop/GeoLite2-City_20190326/GeoLite2-City.mmdb");

运行结果:
在这里插入图片描述

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值