# IPLocator **Repository Path**: kavcc/IPLocator ## Basic Information - **Project Name**: IPLocator - **Description**: 基于纯真IP数据库(qqwry.dat)的ip地址归属地查询程序 - **Primary Language**: Java - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 1 - **Forks**: 1 - **Created**: 2020-11-09 - **Last Updated**: 2025-01-06 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # 基于qqwry.dat查找ip归属地的java程序 ## 使用: __1. 直接调用(推荐,效率最高):__ String ip = "202.108.22.5"; QQWryFile qqWryFile = QQWryFile.getInstance(); RandomAccessFile ipFile = qqWryFile.getIpFile(); QQWryRecord record = qqWryFile.find(ip, ipFile); System.out.println(Utils.ipToStr(record.getBeginIP())); System.out.println(Utils.ipToStr(record.getEndIP())); System.out.println(record.getCountry()); System.out.println(record.getArea()); __结果:__
> 202.108.22.0
202.108.23.255
北京市
百度公司
__2. PostgreSQL:__
> 1. 在pg数据库里新建数据名为 *ipsdb* 的数据库(如需其他名字,在PostgreSQL.java文件内改相应的配置)
2. 调QQWryFile里的storageToPg方法,把ip库存进pg数据里
3. 查询:`select * from ips where ip_start <= inet '202.108.22.5' and ip_end >= inet '202.108.22.5';`
__3. mongodb:__ > 1. 在pg数据库里新建数据名为 *ipsdb* 的数据库(如需其他名字,在PostgreSQL.java文件内改相应的配置)
2. 调QQWryFile里的storageToMongDB方法,把ip库存进mongo数据里
3. 先把ip按Utils文件里的ipToLong变成长整型,然后再去查:
`db.ips.find({ip_start : {$lte : NumberLong(3396077979)}, ip_end : {$gte : NumberLong(3396077979)}})`
## 参考资料: 1. 纯真IP数据库格式详解: http://lumaqq.linuxsir.org/article/qqwry_format_detail.html 2. ruby程序的实现: https://github.com/hide2/ruby-qqwry 3. java程序的实现: http://www.ehelper.com.cn/blog/post/java05.html 4. 纯真IP数据库qqwry.dat更新: http://www.cz88.net/ 右上角有个IP数据库下载,里面的说明文件里说明了更新的方法。