php版netcat,python 实现 netcat

import sys

import socket

import getopt

import threading

import subprocess

listen = False

command = False

upload = False

execute = ""

target = ""

upload_destination = ""

port = 0

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 uponreceiving a connection"

print "-c --command - initialize a command shell"

print "-u --upload=destination - upon receiveing 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 "echo 'ABCDEFGHI' | ./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","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,"unhanded Option"

if not listen and len(target) and port > 0:

buffer = sys.stdin.read()

client_sender(buffer)

if listen:

server_loop()

main()

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 

break

print response,

buffer = raw_input("")

buffer += "\n"

client.send(buffer)

except:

print "[*] Exception! Exiting."

client.close()

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 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_soket):

global upload

global execute

global command

if len(upload_destination):

file_buffer = ""

while True:

data = client_soket.recv(4096)

if not data:

break

else:

file_buffer += data

try:

file_description = open(upload_destination,"wb")

file_description.write(file_buffer)

file_description.close()

client_soket.send("Successfully saved file to %s\r\n" % upload_destination)

except:

client_soket.send("Failed to save file to %s\r\n" % upload_destination)

if len(execute):

output = run_command(execute)

client_soket.send(output)

if command:

while True:

client_soket("")

cmd_buffer = ""

while "\n" not in cmd_buffer:

cmd_buffer += client_soket.recv(1024)

response = run_command(cmd_buffer)

client_soket.send(response)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值