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:
- 在pg数据库里新建数据名为 ipsdb 的数据库(如需其他名字,在PostgreSQL.java文件内改相应的配置)
- 调QQWryFile里的storageToPg方法,把ip库存进pg数据里
- 查询:
select * from ips where ip_start <= inet '202.108.22.5' and ip_end >= inet '202.108.22.5';
3. mongodb:
- 在pg数据库里新建数据名为 ipsdb 的数据库(如需其他名字,在PostgreSQL.java文件内改相应的配置)
- 调QQWryFile里的storageToMongDB方法,把ip库存进mongo数据里
- 先把ip按Utils文件里的ipToLong变成长整型,然后再去查:
db.ips.find({ip_start : {$lte : NumberLong(3396077979)}, ip_end : {$gte : NumberLong(3396077979)}})
- 纯真IP数据库格式详解: http://lumaqq.linuxsir.org/article/qqwry_format_detail.html
- ruby程序的实现: https://github.com/hide2/ruby-qqwry
- java程序的实现: http://www.ehelper.com.cn/blog/post/java05.html
- 纯真IP数据库qqwry.dat更新: http://www.cz88.net/ 右上角有个IP数据库下载,里面的说明文件里说明了更新的方法。