0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Python SDK包的使用

科技绿洲 来源:Python实用宝典 作者:Python实用宝典 2023-10-30 15:51 次阅读

Shodan Web端非常好用,但如果我们有从 Python 搜索的需求怎么办?

没关系,Shodan 官方也提供了 Python SDK 包,下面就来讲讲这个 SDK 包的使用。

1.准备

开始之前,你要确保Python和pip已经成功安装在电脑上,如果没有,可以访问这篇文章:超详细Python安装指南 进行安装。

(可选1) 如果你用Python的目的是数据分析,可以直接安装 Anaconda:Python数据分析与挖掘好帮手—Anaconda,它内置了 Python 和 pip .

(可选2) 此外,推荐大家用VSCode编辑器,它有许多的优点:Python 编程的最好搭档—VSCode 详细指南

请选择以下任一种方式输入命令安装依赖

  1. Windows 环境 打开 Cmd (开始-运行-CMD)。
  2. MacOS 环境 打开 Terminal (command+空格输入Terminal)。
  3. 如果你用的是 VSCode编辑器 或 Pycharm,可以直接使用界面下方的Terminal.
pip install shodan

2.注册账号获取API

使用 Shodan 必须注册账号,注册网址:https://account.shodan.io/register

图片

输入完相关信息,点击 CREATE 会跳转到个人账户页:

图片

此时 API Key 会显示你的API秘钥,请记录这个秘钥,后续会使用到这个秘钥去请求接口

3.Shodan 基本调用

Shodan 本质上就是一个搜索引擎,你只需要输入搜索的关键词:

# 公众号:Python 实用宝典
# 2021-05-04
from shodan import Shodan

api = Shodan('你的API KEY')

def search_shodan(keyword):
    # 调用搜索接口
    result = api.search(keyword)

    # 显示所有IP
    for service in result['matches']:
            print(service['ip_str'])

search_shodan("Hikvision-Webs")

结果如下:

图片

可惜的是,普通API只能像这样搜索关键字,无法使用过滤条件如:** Hikvision-Webs country:"US" **搜索美国境内的所有 Hikvision 网站管理端。

如果你想要使用过滤条件,Shodan 需要你升级API权限:

图片

挺贵的,不过还好是一次性支付,永久使用。

4. Shodan 高级使用

Shodan 的用处当然不仅仅是在黑客攻防中,它还能用于统计。如果你想要了解哪些国家的使用这款摄像头的数量最多,可以使用 Facets 特性。

# 公众号:Python 实用宝典
# 2021-05-04
from shodan import Shodan

api = Shodan('你的API KEY')
def try_facets(query):
    FACETS = [
        'org',
        'domain',
        'port',
        'asn',
        ('country', 3),
    ]

    FACET_TITLES = {
        'org': 'Top 5 Organizations',
        'domain': 'Top 5 Domains',
        'port': 'Top 5 Ports',
        'asn': 'Top 5 Autonomous Systems',
        'country': 'Top 3 Countries',
    }

    try:
        # 使用 count() 方法可以不需要升级API,且比 search 方法更快。
        result = api.count(query, facets=FACETS)

        print('Shodan Summary Information')
        print('Query: %s' % query)
        print('Total Results: %sn' % result['total'])

        # 显示每个要素的摘要
        for facet in result['facets']:
            print(FACET_TITLES[facet])

            for term in result['facets'][facet]:
                print('%s: %s' % (term['value'], term['count']))

    except Exception as e:
        print('Error: %s' % e)

try_facets("Hikvision-Webs")

得到结果如下:

图片

从 Top 3 Countries 中可以看到,这款摄像头使用数量排名前三的国家分别是:美国、日本和德国。

没想到吧,Shodan 居然还能用于产品分析。同样地原理,如果你把关键词改为 ** apache ** ,你可以知道目前哪些国家使用apache服务器数量最多,最普遍被使用的版本号是什么。

简而言之,Shodan 是一个非常强大的搜索引擎,它在好人手里,能被发挥出巨大的潜能。如果 Shodan 落入坏人之手的话,那真是一个可怕的东西。

为了避免受到不必要的攻击,请大家及时检查所有联网设备的管理端的密码,如果有使用默认密码及弱口令,立即进行密码的更改,以保证服务的安全。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 编辑器
    +关注

    关注

    1

    文章

    788

    浏览量

    30187
  • 数据分析
    +关注

    关注

    2

    文章

    1352

    浏览量

    33736
  • python
    +关注

    关注

    51

    文章

    4675

    浏览量

    83467
  • SDK
    SDK
    +关注

    关注

    3

    文章

    966

    浏览量

    44696
收藏 人收藏

    评论

    相关推荐

    【Raspberry Pi 3试用体验】+ 发微博

    /default.html 取消授权回调页 同样即可代码:#coding=utf-8#! /usr/bin/python"""引入Python SDK""
    发表于 04-24 21:53

    【Rico Board试用体验】Amazon Iot物联网终端之廿五 采用AmazonIoT SDK for Python 下载和安装

    1、在新的内核中,需要引入AmazonIoT SDK,从使用来看,用SDK for Node.js最方便和灵活。 不过已经安装好了python就用python了。2、首先需要看ssl是
    发表于 12-12 16:57

    Snapdragon NPE SDK的环境配置

    /tensorflow-1.0.0-cp27-none-linux_x86_64.whl二、配置SDK这个配置主要是让Snapdragon NPE SDK通过python接口与Caffe和Tensorflow framework
    发表于 09-27 16:50

    Python的pip安装

    pip是一个安装和管理 Python 的工具,用它我们可以方便的拉一些依赖的库下来
    发表于 07-16 08:04

    TensorFlow常用Python扩展

    TensorFlow 能够实现大部分神经网络的功能。但是,这还是不够的。对于预处理任务、序列化甚至绘图任务,还需要更多的 Python 。下面列出了一些常用的 Python :Nu
    发表于 07-28 14:35

    请问有CS32L010的SDK吗?

    请问有CS32L010的SDK吗?请问有CS32L010的SDK吗?请问有CS32L010的SDK
    发表于 11-10 16:41

    什么是python、模块和库?

    早一点的 Python 版本(Python 3.3 之前)中,如果一个文件夹下有一个 __init__.py 文件,那我们就称之为,英文名 Package。在后来的 Python
    发表于 03-09 16:48

    python常规与命名空间

    python常规与命名空间1. 常规包在 Python 3.3 之前或者说 Python 2 中,一个
    发表于 03-11 15:46

    怎样使用MQTT连接到AWS MQTT Broker .fx软件并使用AWS IOT Python SDK在DragonBoard中查看消息

    所有发送到sigfox主题的消息都显示在MQTT.fx软件中,如果该主题中有规则,则数据也会发送到智能手机和电子邮件中。
    的头像 发表于 11-20 17:43 6240次阅读

    OpenVINO开发配置应必备哪些基础知识?

    在具体介绍OpenVINO开发流程与开发必备基础知识之前,我们首先需要配置好OpenVINO的开发环境,这里我们以Win10系统下OpenVINO C++/Python SDK开发与应用集成为例来完成整个
    的头像 发表于 05-18 09:10 1589次阅读
    OpenVINO开发配置应必备哪些基础知识?

    Python完成鸿蒙开发板外设控制

    设备开发的门槛。最近我又开始躁动起来,大刀阔斧的在之前工作的基础上做了 Python SDK 的设计和开发。
    的头像 发表于 09-28 09:22 1523次阅读

    阿里云物联网开发在MCU上移植开发C·SDK流程

    Android SDK;NodeJS SDK;Java SDKPython SDK;IOS SDK
    发表于 10-27 12:36 14次下载
    阿里云物联网开发在MCU上移植开发C·<b class='flag-5'>SDK</b>流程

    Ouster发布更新版Python SDK 助力用户构建机器学习应用程序

     Ouster致力于为各行业的自动化变革提供领先的环境感知能力。随着覆盖的客户范围越来越广,我们希望通过客户反馈,了解哪些功能是更具现实意义且紧迫需要的,从而让数字激光雷达更好的集成和应用到实际的项目中,这也是最新固件 2.3的出发点。
    的头像 发表于 05-06 16:33 996次阅读
    Ouster发布更新版<b class='flag-5'>Python</b> <b class='flag-5'>SDK</b> 助力用户构建机器学习应用程序

    微软推出面向美国政府机构的生成式人工智能服务

    Azure OpenAI服务可以使用REST API、Python SDK或Azure AI Studio中基于Web的Microsoft界面访问,所有Azure政府客户和合作伙伴将能够访问所有模型。
    的头像 发表于 06-09 16:49 1330次阅读

    盘古ai大模型怎么使用

    怎么使用的具体步骤如下: 首先在盘古AI官网注册并获取API Key和Secret Key。 然后下载Python SDK,并按照说明安装SDK。 最后编写Python代码,调用
    的头像 发表于 09-04 10:42 1w次阅读