python 实现全球IP归属地查询工具


Posted in Python onDecember 18, 2020
# 写在前面,这篇文章的原创作者是Charles我只是在他这个程序的基础上边进行加工,另外有一些自己的改造
# 并都附上了注释和我自己的理解,这也是我一个学习的过程。
# 附上大佬的GitHub地址:https://github.com/CharlesPikachu/Tools

'''
Function:
  根据IP地址查其对应的地理信息
Author:
  Charles
微信公众号:
  Charles的皮卡丘
'''
import IPy
import time
import random
import hashlib
import argparse
import requests


headers = {
  'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.88 Safari/537.36'
}



def getaliIP(ip):
  # 这里使用ali的IP地址查询功能。
  # https://market.aliyun.com/products/?keywords=ip%E5%BD%92%E5%B1%9E%E5%9C%B0
  # 需要自己去这个网址注册账号,然后进行调用。
  # 这里我们先进行定义url
  host = 'https://ips.market.alicloudapi.com'
  path = '/iplocaltion'
  method = "GET"
  appcode = '填写你自己的xxx'
  url = host + path + '?ip=' + ip
  # 定义头部。
  headers = {"Authorization": 'APPCODE ' + appcode}
  try:
   # 进行获取调用结果。
   rep = requests.get(url, headers=headers)
  except:
   return 'url参数错误'
  # 判断是否调用成功。如果调用成功就接着进行下边的动作。
  httpStatusCode = rep.status_code
  if httpStatusCode == 200:
   # 转换成json格式
   data = rep.json()
   # 然后获取其中的参数。
   ''''
   # 是以下边这种格式进行返回的。
   {
     "code": 100,
     "message": "success",
     "ip": "110.188.234.66",
     "result": {
          "en_short": "CN", // 英文简称
     "en_name": "China", // 归属国家英文名称
   "nation": "中国", // 归属国家
   "province": "四川省", // 归属省份
   "city": "绵阳市", // 归属城市
   "district": "涪城区", // 归属县区
   "adcode": 510703, // 归属地编码
   "lat": 31.45498, // 经度
   "lng": 104.75708 // 维度
   }
   }'''
   result1 = data.get('result')
   city = result1['city']
   province = result1['province']
   nation = result1['nation']
   district = result1['district']
   latitude = result1['lat']
   longitude = result1['lng']
   # 返回我们需要的结果。
   result = '-' * 50 + '\n' + \
       '''[ali.com查询结果-IP]: %s\n经纬度: (%s, %s)\n国家: %s\n地区: %s\n城市: %s\n''' % (
       ip, longitude, latitude, nation, province, city) \
       + '-' * 50
  else:
   httpReason = rep.headers['X-Ca-Error-Message']
   if (httpStatusCode == 400 and httpReason == 'Invalid Param Location'):
     return "参数错误"
   elif (httpStatusCode == 400 and httpReason == 'Invalid AppCode'):
     return "AppCode错误"
   elif (httpStatusCode == 400 and httpReason == 'Invalid Url'):
     return "请求的 Method、Path 或者环境错误"
   elif (httpStatusCode == 403 and httpReason == 'Unauthorized'):
     return "服务未被授权(或URL和Path不正确)"
   elif (httpStatusCode == 403 and httpReason == 'Quota Exhausted'):
     return "套餐包次数用完"
   elif (httpStatusCode == 500):
     return "API网关错误"
   else:
     return "参数名错误 或 其他错误" + httpStatusCode + httpReason

  return result

'''淘宝API'''
def getTaobaoIP(ip):
  # 请求淘宝获取IP位置的API接口,但是现在有些不是很好用了。查不出来了。
  # 看了看接口需要进行传入秘钥
  url = 'http(s)://ips.market.alicloudapi.com/iplocaltion'
  # 使用get方法进行请求。
  res = requests.get(url+ip, headers=headers)
  # 然后进行解析参数。
  data = res.json().get('data')
  print(res.json)
  if data is None:
   return '[淘宝API查询结果-IP]: %s\n无效IP' % ip
  result = '-'*50 + '\n' + \
  '''[淘宝API查询结果-IP]: %s\n国家: %s\n地区: %s\n城市: %s\n''' % (ip, data.get('country'), data.get('region'), data.get('city')) \
  + '-'*50
  return result


'''ip-api.com(很不准)'''
def getIpapiIP(ip):
  url = 'http://ip-api.com/json/'
  res = requests.get(url+ip, headers=headers)
  data = res.json()
  yd = youdao()
  city = yd.translate(data.get('city'))[0][0]['tgt']
  country = yd.translate(data.get('country'))[0][0]['tgt']
  region_name = yd.translate(data.get('regionName'))[0][0]['tgt']
  latitude = data.get('lat')
  longitude = data.get('lon')
  result = '-'*50 + '\n' + \
  '''[ip-api.com查询结果-IP]: %s\n经纬度: (%s, %s)\n国家: %s\n地区: %s\n城市: %s\n''' % (ip, longitude, latitude, country, region_name, city) \
  + '-'*50
  return result


'''ipstack.com'''
def getIpstackIP(ip):
  # 定义url
  url = 'http://api.ipstack.com/{}?access_key=1bdea4d0bf1c3bf35c4ba9456a357ce3'
  res = requests.get(url.format(ip), headers=headers)
  data = res.json()
  # 实例化一个有道翻译的类。
  yd = youdao()
  # 调用翻译函数。获取翻译的值。
  continent_name = yd.translate(data.get('continent_name'))[0][0]['tgt']
  country_name = yd.translate(data.get('country_name'))[0][0]['tgt']
  region_name = yd.translate(data.get('region_name'))[0][0]['tgt']
  city = yd.translate(data.get('city'))[0][0]['tgt']
  # 获取经纬度。
  latitude = data.get('latitude')
  longitude = data.get('longitude')
  result = '-'*50 + '\n' + \
  '''[ipstack.com查询结果-IP]: %s\n经纬度: (%s, %s)\n板块: %s\n国家: %s\n地区: %s\n城市: %s\n''' % (ip, longitude, latitude, continent_name, country_name, region_name, city) \
  + '-'*50
  return result


'''IP地址有效性验证'''
def isIP(ip):
  try:
   IPy.IP(ip)
   return True
  except:
   return False


'''
Function:
  有道翻译类,进行翻译上边我们查询结果的返回值。
'''
class youdao():
  def __init__(self):
   # 这里我们需要使用post方法进行调用接口。
   self.headers = {
     'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.88 Safari/537.36'
   }

   self.data = {
        'i': 'hello',
        'action': 'FY_BY_CLICKBUTTION',
        'bv': 'e2a78ed30c66e16a857c5b6486a1d326',
        'client': 'fanyideskweb',
        'doctype': 'json',
        'from': 'AUTO',
        'keyfrom': 'fanyi.web',
        'salt': '15532627491296',
        'sign': 'ee5b85b35c221d9be7437297600c66df',
        'smartresult': 'dict',
        'to': 'AUTO',
        'ts': '1553262749129',
        'typoResult': 'false',
        'version': '2.1'
        }
   # 有道翻译调用接口的url
   self.url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule'
   # http: // fanyi.youdao.com / translate?smartresult = dict & smartresult = rule & sessionFrom =
  # 进行翻译。
  def translate(self, word):
   # 先判断单词是否为空。
   if word is None:
     return [word]
   # 随机生成一个时间。
   t = str(time.time()*1000 + random.randint(1,10))
   t = str(time.time()*1000 + random.randint(1, 10))
   # 传入我们需要翻译的单词和其他参数。
   self.data['i'] = word
   self.data['salt'] = t
   sign = 'fanyideskweb' + word + t + '6x(ZHw]mwzX#u0V7@yfwK'
   # 这里需要哈希一下。
   self.data['sign'] = hashlib.md5(sign.encode('utf-8')).hexdigest()
   # 进行post方法调用接口,并获取我们需要的参数。
   res = requests.post(self.url, headers=self.headers, data=self.data)
   # 返回翻译的结果。
   return res.json()['translateResult']


'''主函数'''
def main(ip):
  separator = '*' * 30 + 'IPLocQuery' + '*' * 30
  # 首先判断IP地址是否合法。
  if isIP(ip):
   # 然后分别调用几个接口进行查询。
   print(separator)
   print(getaliIP(ip))
   print(getIpstackIP(ip))
   print(getIpapiIP(ip))
   print('*' * len(separator))
  else:
   print(separator + '\n[Error]: %s --> 无效IP地址...\n' % ip + '*' * len(separator))
  

if __name__ == '__main__':
  # 获取终端输入的入参。
  parser = argparse.ArgumentParser(description="Query geographic information based on IP address.")
  # 可选参数,代表着文件的名字,里边存放着IP之地。
  parser.add_argument('-f', dest='filename', help='File to be queried with one ip address per line')
  # 可选参数,代表着我们需要查询的IP地址。
  parser.add_argument('-ip', dest='ipaddress', help='Single ip address to be queried')
  args = parser.parse_args()
  # 获取终端输入的参数。
  ip = args.ipaddress
  filename = args.filename
  # 判断终端是否有进行输入参数。
  if ip:
   main(ip)
  if filename:
   with open(filename) as f:
     # 获取文件中的所有IP地址,存放成一个列表的形式。
     ips = [ip.strip('\n') for ip in f.readlines()]
   for ip in ips:
     main(ip)

以上就是python 实现全球IP归属地查询工具的详细内容,更多关于python ip归属地查询的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
使用Python的Django框架实现事务交易管理的教程
Apr 20 Python
Python中正则表达式详解
May 17 Python
python中pylint使用方法(pylint代码检查)
Apr 06 Python
使用Python读取二进制文件的实例讲解
Jul 09 Python
Python中常用的8种字符串操作方法
May 06 Python
详解Python在使用JSON时需要注意的编码问题
Dec 06 Python
NumPy统计函数的实现方法
Jan 21 Python
如何使用python传入不确定个数参数
Feb 18 Python
Python Django中的STATIC_URL 设置和使用方式
Mar 27 Python
Python requests模块session代码实例
Apr 14 Python
jupyter notebook oepncv 显示一张图像的实现
Apr 24 Python
如何把python项目部署到linux服务器
Aug 26 Python
MoviePy简介及Python视频剪辑自动化
Dec 18 #Python
Python非单向递归函数如何返回全部结果
Dec 18 #Python
python复合条件下的字典排序
Dec 18 #Python
python 监控服务器是否有人远程登录(详细思路+代码)
Dec 18 #Python
细说NumPy数组的四种乘法的使用
Dec 18 #Python
如何通过python检查文件是否被占用
Dec 18 #Python
python 实现端口扫描工具
Dec 18 #Python
You might like
PHP投票系统防刷票判断流程分析
2012/02/04 PHP
php导出生成word的方法
2015/12/25 PHP
Yii2框架引用bootstrap中日期插件yii2-date-picker的方法
2016/01/09 PHP
Ajax实现对静态页面的文章访问统计功能示例
2016/10/10 PHP
thinkPHP自动验证、自动添加及表单错误问题分析
2016/10/17 PHP
详解PHP素材图片上传、下载功能
2019/04/12 PHP
PHP7数组的底层实现示例
2019/08/25 PHP
JavaScript入门教程(12) js对象化编程
2009/01/31 Javascript
实现png图片和png背景透明(支持多浏览器)的方法
2009/09/08 Javascript
js中document.getElementByid、document.all和document.layers区分介绍
2011/12/08 Javascript
将json对象转换为字符串的方法
2014/02/20 Javascript
把文本中的URL地址转换为可点击链接的JavaScript、PHP自定义函数
2014/07/29 Javascript
让html页面不缓存js的实现方法
2014/10/31 Javascript
扒一扒JavaScript 预解释
2015/01/28 Javascript
javascript实现自动输出文本(打字特效)
2015/08/27 Javascript
jquery实现的伪分页效果代码
2015/10/29 Javascript
全面了解javascript三元运算符
2016/06/27 Javascript
jQuery EasyUI基础教程之EasyUI常用组件(推荐)
2016/07/15 Javascript
AngularJs自定义服务之实现签名和加密
2016/08/02 Javascript
angularjs 实现带查找筛选功能的select下拉框实例
2017/01/11 Javascript
基于JavaScript实现滑动门效果
2017/03/16 Javascript
Angular+Node生成随机数的方法
2017/06/16 Javascript
高性能的javascript之加载顺序与执行原理篇
2018/01/14 Javascript
jQuery模拟html下拉多选框的原生实现方法示例
2019/05/30 jQuery
vue请求数据的三种方式
2020/03/04 Javascript
python实现字符串加密 生成唯一固定长度字符串
2019/03/22 Python
python实现可变变量名方法详解
2019/07/01 Python
pytorch 可视化feature map的示例代码
2019/08/20 Python
Python关于拓扑排序知识点讲解
2021/01/04 Python
CSS3制作文字半透明倒影效果的两种实现方式
2014/08/08 HTML / CSS
HTML5实现无刷新修改URL的方法
2019/11/14 HTML / CSS
日本非常有名的内衣丝袜品牌:GUNZE
2017/01/06 全球购物
艺术应用与设计个人的自我评价
2013/11/23 职场文书
质检部部长职责
2013/12/16 职场文书
聘任书模板
2014/03/29 职场文书
《家世》读后感:看家训的力量
2019/12/30 职场文书