python實(shí)現(xiàn)獲取Ip歸屬地等信息
如果你有一批IP地址想要獲得這些IP具體的信息,比如歸屬?lài)?guó)家,城市等,最好的辦法當(dāng)時(shí)是調(diào)用現(xiàn)有的api接口來(lái)獲取,我在之前就寫(xiě)過(guò)一篇文章,是關(guān)于我的博客被莫名攻擊的時(shí),就有獲取過(guò)一批IP,攻擊的時(shí)候當(dāng)時(shí)是恢復(fù)業(yè)務(wù)重要,IP該封的就要封,攻擊過(guò)后這個(gè)攻擊者的IP信息,自己就可以分析下都來(lái)自哪里,有沒(méi)有什么特征,幫助提示自己網(wǎng)站的安全性,今天這個(gè)腳本就是根據(jù)提供的IP獲得IP歸屬的具體信息,腳本如下:
#!/usr/bin/env python import requests import csv def getIp(file): iplist = [] fi = open(file, 'r') for ip in fi: ip = ip.strip() iplist.append(ip) return iplist def get_geolocation(ip): r = requests.get('https://freegeoip.net/json/' + ip) info = [str(r.json()['country_name']), str(r.json()['city'])] return {'ip':ip, 'country_name':info[0], 'city_name':info[1]} if __name__ == '__main__': iplist = getIp('/root/ipfile') f = open('outputinfo.csv', 'a+') fieldnames = ['ip', 'country_name', 'city_name'] dict_writer = csv.DictWriter(f, fieldnames=fieldnames) dict_writer.writerow(dict(zip(fieldnames, fieldnames))) for ip in iplist: data = get_geolocation(ip) dict_writer.writerow(data)
腳本解釋?zhuān)x了2個(gè)函數(shù),getIp()函數(shù)從文件中讀取IP信息,返回一個(gè)列表,get_geolocation()函數(shù)負(fù)責(zé)實(shí)際得到信息,返回一個(gè)字典,接著在主函數(shù)打開(kāi)一個(gè)可寫(xiě)的csv文件,通過(guò)循環(huán)將得到的信息寫(xiě)入一個(gè)CSV文件中,在寫(xiě)入csv 文件時(shí)用到了csv.DictWriter字典寫(xiě)的功能,這個(gè)還是比較實(shí)用,可以將數(shù)據(jù)結(jié)構(gòu)類(lèi)型為字典的數(shù)據(jù)直接寫(xiě)入csv文件,換句話(huà)說(shuō)就是你只要把你要寫(xiě)的數(shù)據(jù)轉(zhuǎn)換成字典的形式,就可以很方便的寫(xiě)入了,比如我這句dict(zip(fieldnames, fieldnames))其實(shí)就是這個(gè)功能,大家以后用到操作csv文件時(shí),可以自己實(shí)踐實(shí)踐。
最后附上一則網(wǎng)友的代碼
#!/usr/bin/env python # -*- coding: utf-8 -*- #查找IP地址歸屬地 #writer by keery_log #Create time:2013-10-30 #Last update:2013-10-30 #用法: python chk_ip.py www.google.com |python chk_ip.py 8.8.8.8 |python chk_ip.py ip.txt import signal import urllib import json import sys,os,re import socket if len(sys.argv) <= 1 : print "Please input ip address !" sys.exit(0) def handler(signum, frame): sys.exit(0) signal.signal(signal.SIGINT, handler) url = "http://ip.taobao.com/service/getIpInfo.php?ip=" #查找IP地址 def ip_location(ip): data = urllib.urlopen(url + ip).read() datadict=json.loads(data) for oneinfo in datadict: if "code" == oneinfo: if datadict[oneinfo] == 0: return datadict["data"]["country"] + datadict["data"]["region"] + datadict["data"]["city"] + datadict["data"]["isp"] #定義IP與域名正則 re_ipaddress = re.compile(r'^((25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$') re_domain = re.compile(r'[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(\.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+\.?') if os.path.isfile(sys.argv[1]): #如果參數(shù)是文件,迭代查找 file_path = sys.argv[1] fh = open(file_path,'r') for line in fh.readlines(): if re_ipaddress.match(line): city_address = ip_location(line) print line.strip() + ":" + city_address else: ip_address = sys.argv[1] if re_ipaddress.match(ip_address): #如果參數(shù)是單個(gè)IP地址 city_address = ip_location(ip_address) print ip_address + ":" + city_address elif(re_domain.match(ip_address)): #如果參數(shù)是域名 result = socket.getaddrinfo(ip_address, None) ip_address = result[0][4][0] city_address = ip_location(ip_address) print ip_address.strip() + ":" + city_address
相關(guān)文章
pytorch實(shí)現(xiàn)梯度下降和反向傳播圖文詳細(xì)講解
這篇文章主要介紹了pytorch實(shí)現(xiàn)梯度下降和反向傳播,反向傳播的目的是計(jì)算成本函數(shù)C對(duì)網(wǎng)絡(luò)中任意w或b的偏導(dǎo)數(shù)。一旦我們有了這些偏導(dǎo)數(shù),我們將通過(guò)一些常數(shù)α的乘積和該數(shù)量相對(duì)于成本函數(shù)的偏導(dǎo)數(shù)來(lái)更新網(wǎng)絡(luò)中的權(quán)重和偏差2023-04-04python爬蟲(chóng)爬取快手視頻多線(xiàn)程下載功能
這篇文章主要介紹了python爬蟲(chóng)爬取快手視頻多線(xiàn)程下載功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-02-02Python中利用LSTM模型進(jìn)行時(shí)間序列預(yù)測(cè)分析的實(shí)現(xiàn)
這篇文章主要介紹了Python中利用LSTM模型進(jìn)行時(shí)間序列預(yù)測(cè)分析的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07Pytorch實(shí)現(xiàn)將模型的所有參數(shù)的梯度清0
這篇文章主要介紹了Pytorch實(shí)現(xiàn)將模型的所有參數(shù)的梯度清0,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-06-06Python數(shù)據(jù)結(jié)構(gòu)之優(yōu)先級(jí)隊(duì)列queue用法詳解
queue庫(kù)提供了一個(gè)適用于多線(xiàn)程編程的先進(jìn)先出(FIFO)數(shù)據(jù)結(jié)構(gòu),可以用來(lái)在生產(chǎn)者與消費(fèi)者線(xiàn)程之間安全地傳遞消息或其他數(shù)據(jù),它會(huì)為調(diào)用者處理鎖定,使多個(gè)線(xiàn)程可以安全而更容易地處理同一個(gè)Queue實(shí)例.Queue的大小可能受限,以限制內(nèi)存使用或處理,需要的朋友可以參考下2021-05-05如何使用python的opencv實(shí)現(xiàn)人臉識(shí)別
這篇文章主要介紹了使用python的opencv實(shí)現(xiàn)人臉識(shí)別功能,本項(xiàng)目主要使用python語(yǔ)言,主要的模塊庫(kù)有os,opencv-python,opencv-contrib-python,需要的朋友可以參考下2023-12-12Python中的chr()函數(shù)與ord()函數(shù)解析
這篇文章主要介紹了Python中的chr()函數(shù)與ord()函數(shù)解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05Python ORM框架SQLAlchemy學(xué)習(xí)筆記之?dāng)?shù)據(jù)添加和事務(wù)回滾介紹
這篇文章主要介紹了Python ORM框架SQLAlchemy學(xué)習(xí)筆記之?dāng)?shù)據(jù)添加和事務(wù)回滾介紹,需要的朋友可以參考下2014-06-06Python可執(zhí)行文件反編譯教程(exe轉(zhuǎn)py)
python的便利性,使得如今許多軟件開(kāi)發(fā)者、黑客都開(kāi)始使用python打包成exe的方式進(jìn)行程序的發(fā)布,那么Python如何反編譯可執(zhí)行文件,本文就來(lái)介紹一下,感興趣的可以了解一下2021-12-12