# 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数据库下载,里面的说明文件里说明了更新的方法。