Python调用Zoomeye搜索接口的实现
作者:lyshark 发布时间:2021-08-26 03:59:24
钟馗之眼是一个强大的搜索引擎,不同于百度谷歌,它主要收集网络中的主机,服务等信息,国内互联网安全厂商知道创宇开放了他们的海量数据库,对之前沉淀的数据进行了整合、整理,打造了一个名符其实的网络空间搜索引擎ZoomEye,运用Python接口可以灵活的实现数据采集。
钟馗之眼的常用搜索关键字如下所示。
app:组件名称
ver:组件版本
搜索 apache组件 版本2.4 --> app:apache ver:2.4
port:端口号 ---> 例如:搜索开放了SSH端口的主机 port:22
指定搜索的操作系统 OS:操作系统名称 ---> OS:Linux
指定搜索的服务 service:服务名称 ---> 例如,搜素SSH服务 Service:SSH
指定搜索的地理位置范 --> country:国家 city:城市名 country:China --> city:Beijing
搜索指定的CIDR网段 例如: CIDR:192.168.158.12/24
搜索指定的网站域名 ---> site:www.baidu.com
搜索指定的主机名 ---> hostname:zwl.cuit.edu.cn
搜索指定的设备名 --> device:router
搜索具有特定首页关键词的主机 ---> keyword:technology
提供的搜索脚本如下。
import os,json,requests
import argparse
def login():
url_login="https://api.zoomeye.org/user/login"
data={
"username": "1098395580@qq.com",
"password": "xiaohua@1998"
}
data=json.dumps(data)
r=requests.post(url=url_login,data=data)
return json.loads(r.content)['access_token']
def GetResidual(token):
url="https://api.zoomeye.org/resources-info"
headers={'Authorization':'JWT ' + token}
r=requests.get(url=url,headers=headers)
datas=json.loads(r.content)
print("剩余搜索次数: {}".format(datas['resources']['search']))
def Search(token,search,files,page):
url="https://api.zoomeye.org/web/search?query={}&page={}".format(search,page)
headers={'Authorization':'JWT ' + token}
r=requests.get(url=url,headers=headers)
data = json.loads(r.content)['matches']
with open(files,'w',encoding='utf-8') as f:
json.dump(data,f,ensure_ascii=False)
print("[+] 保存文件: {} 长度: {} 页码: {} 查询语法: {}".format(files,len(data),page,search))
def Get_System(files):
try:
with open(files,'r',encoding='utf8') as fp:
json_data = json.load(fp)
json_len = len(json_data)
for item in range(0,json_len):
print("IP地址: %15s |" %(json_data[item]['ip'][0]),end="")
print("地区: %1s %3s "%(json_data[item]['geoinfo']['continent']['names']['zh-CN'],
json_data[item]['geoinfo']['subdivisions']['names']['zh-CN']))
except Exception:
pass
def Banner():
print(" _ ____ _ _ ")
print(" | | _ _/ ___|| |__ __ _ _ __| | __")
print(" | | | | | \___ \| '_ \ / _` | '__| |/ /")
print(" | |__| |_| |___) | | | | (_| | | | < ")
print(" |_____\__, |____/|_| |_|\__,_|_| |_|\_\\")
print(" |___/ \n")
print("E-Mail: me@lyshark.com")
if __name__== "__main__":
Banner()
parser = argparse.ArgumentParser()
parser.add_argument("-s","--search",dest="search",help="根据传入语法搜索指定内容")
parser.add_argument("-f","--file",dest="file",help="保存文件的名字 *.json")
parser.add_argument("-p","--page",dest="page",help="需要检索第几页的数据")
parser.add_argument("-q","--query" ,dest="query",help="单独使用,可用于查询剩余次数")
parser.add_argument("-g","--get" ,dest="get",help="提取本地json文件并解析出关键数据")
args = parser.parse_args()
if args.search and args.file and args.page:
token = login()
Search(token,args.search,args.file,args.page)
elif args.query and args.search == None:
token = login()
GetResidual(token)
elif args.get:
Get_System(args.get)
else:
parser.print_help()
查询使用次数: 默认情况下,钟馗之眼每月给与10000条左右的查询次数,可以使用 -q 参数实现次数的查询。
**搜索功能的使用:**通过-s
选项指定你需要搜索的关键字,可以结合钟馗之眼搜索语法使用-p
就是搜索的页码数-f
保存为json文件。
在JSON中解析IP地址: 在本地JSON文件中解析IP地址,提取出关键数据。
来源:https://blog.51cto.com/lyshark/5989486


猜你喜欢
- 1、目前来看,百付宝仅仅只是C2C的一个支付后台。他的内容只集中于“钱和订单”两个环节,没有其他干扰信息。2、百付宝的界面表现很简单。因为简
- 两个并发事务同时访问数据库表相同的行时,可能存在以下三个问题:1、幻想读:事务T1读取一条指定where条件的语句,返回结果集。此时事务T2
- 本文实例讲述了Python读取sqlite数据库文件的方法。分享给大家供大家参考,具体如下:import sqlite3这是Python内置
- 在使用django的modelform的时候,修改表单,图片在form表单显示的是一个链接。显示缩略图如下第一步:from django.f
- 一般用 createProcessingInstruction 方法创建处理指令指定参数为 "xml","ve
- 获取操作系统的当前运行状态和负载情况,是一个系统管理员的基本技能,因为这对我们日常排查故障,定位问题有着非常紧密的联系,比如查看当前系统的基
- JavaScript 学习 - 提高篇一. JavaScript中的对象.JavaScript中的Object是一组数据的key-value
- 由于工作需要,在做最优分箱的时候,始终写不出来高效的代码,所以就找到了R语言中的最优分箱的包,这个时候考虑到了在python中调用R语言,完
- 首先先定义一个list,将其转存为csv文件,看将会报什么错误list=[[1,2,3],[4,5,6],[7,9,9]]list.to_c
- 定义变量什么是变量?在程序运行过程中,其值可以改变的量变量的定义?在 python 中,每个变量在使用前都必须赋值,变量赋值以后该变量才会被
- 本文主要分享的是一则关于Tornado高并发处理方法的实例,具体如下:#!/bin/env python# -*- coding:utf-8
- 有时我们需要在一个页面上使用多个Fck的实例,首先需要按照id获取fck的实例。例如: <FCKeditorV2:FCKeditor
- 数据加载、存储与文件格式pandas提供了一些用于将表格型数据读取为DataFrame对象的函数。其中read_csv和read_talbe
- 由于Oracle自身比较复杂,在Linux环境下安装要涉及很多方面的因素。本文分两个方面介绍在Linux RedHat 6.0环境下Orac
- 相信大家都遇到过这种情况,下载文件的时候遇到压缩包又没有密码,或者说自己设置的加密密码,但是忘记了,就很难受~但是~在Python程序员面前
- 举例说明: 在Windows环境下:原本在php4.3.0中运行正常的程序,在4.3.1中为何多处报错,大体提示为:Notice:Undef
- 用tensorflow构建简单的线性回归模型是tensorflow的一个基础样例,但是原有的样例存在一些问题,我在实际调试的过程中做了一点自
- 首先:确认自己安装有python(没有安装的同学可自行安装,这里我们不过多赘述)确认安装有python之后,win+r打开cmd窗口,输入p
- python常见的错误有1.NameError变量名错误2.IndentationError代码缩进错误3.AttributeError对象
- Paramiko是一个用于执行SSH命令的Python第三方库,使用该库可实现自动化运维的所有任务,如下是一些常用代码的封装方式,多数代码为