【Python练习】094. 编写一个函数,实现简单的安全扫描工具

094. 编写一个函数,实现简单的安全扫描工具

编写一个简单的安全扫描工具可以帮助检测一些常见的安全问题,例如弱密码、未打补丁的软件版本、开放的危险端口等。以下是一个简单的 Python 安全扫描工具的实现,它包括以下功能:

  1. 端口扫描:检测目标主机上开放的端口。
  2. 弱密码检测:尝试使用常见的弱密码登录某些服务(如 SSH、FTP)。
  3. 检查常见漏洞:检测目标主机是否运行了已知存在漏洞的服务。

示例代码

import socket
import paramiko
import ftplib
import requests
import concurrent.futures

# 端口扫描
def scan_port(host, port):
    try:
        sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        sock.settimeout(2)
        result = sock.connect_ex((host, port))
        if result == 0:
            print(f"[+] Port {
     
     port} on {
     
     host} is open.")
            return True
        else:
            return False
    except Exception as e:
        print(f"Error scanning port {
     
     port}: {
     
     e}")
        return False
    finally:
        sock.close()

# 弱密码检测(SSH)
def check_ssh_weak_password(host, port=22, username="root", password_list=None):
    if password_list is None:
        password_list = ["password", "123456", "root", "admin"]
    try:
        for password in password_list:
            client = paramiko.SSHClient()
            client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
            try:
                client.connect(host, port=port, username=username, password=password, timeout=5)
                print(f"[+] Weak password found for SSH: {
     
     username}:{
     
     password}")
                retu
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值