Skip to content

基于纯真IP数据库(qqwry.dat)的ip地址归属地查询程序

Notifications You must be signed in to change notification settings

miraclesu/IPLocator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

基于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文件内改相应的配置)
  1. 调QQWryFile里的storageToPg方法,把ip库存进pg数据里
  2. 查询: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文件内改相应的配置)
  1. 调QQWryFile里的storageToMongDB方法,把ip库存进mongo数据里
  2. 先把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数据库下载,里面的说明文件里说明了更新的方法。

About

基于纯真IP数据库(qqwry.dat)的ip地址归属地查询程序

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages