찾다

在 python 中有一个 telnetlib,它的作用就是建立一个通到主机的 telnet连线实体, 然后向主机传送命令 (就像用键盘输入一样 )并从该连线接收数据。利用它, 我们可以把示范 1的所有内容从 "人 -机 '交流变成'机 -机 '交流,这样也可以做到处理 pop3 邮箱的工作。不过既然我们已经试过了 pop3,这一次可以试用真的 telnet 埠 23 做些好玩的东西。

 

 以下是代码片段:   1 # telnetdo.py     2 #!/usr/bin/env python     3      4 def telnetdo(HOST=None, USER=None, PASS=None, COMMAND=None):  #定义一个函数, 这将要用它会很容易      5   import telnetlib, sys     6      7   if   not   HOST:                           #如果没有给出所要的资料,则要求用户输入                      8      try:     9         HOST   = sys.argv[1]                 #记得吧, 序列是从 0开始数的,而sys.argv[0]会是你程式的名字     10         USER   = sys.argv[2]    11         PASS   = sys.argv[3]    12         COMMAND   = sys.argv[4]    13      except:    14         print   "Usage: telnetdo.py host user pass 'command'"    15         return    16     17   msg   = ['Debug   mesages:\n']             #这个用来存起所有从主机传回的讯息, 作除错时很有用     18     19   tn   = telnetlib.Telnet()                  #准备一个 telnet 连线的实体     20   try:    21      tn.open(HOST)                           #连接端绑定到主机 HOST  去     22   except:    23      print   "Cannot open host"    24      return    25     26   msg.append(tn.expect(['login:'],5))        #等待主机传回含有 'login:'字符的讯息,等候时限为 5秒     27   tn.write(USER+'\n')                        #向主机送出字串 USER   + '\n',如 USER  是    28                                              # 'pcheung' 则等于 'pcheung\n'    29   if   PASS:                                 #就像是在键盘打入一样。     30      msg.append(tn.expect(['Password:'],5))  #如果有 password  要打的话就送出密码字串,     31      tn.write(PASS+'\n')                     #但首先要等主机传回含有 'Password:'字样的讯息     32     33   msg.append(tn.expect([USER],5))            #因为通常登入后主机会显示出登入者名称,我们在主机回应中找这     34                                              #样的字符,如有的话则代表登入成功了     35   tn.write(COMMAND+'\n')                     #向主机发出指令     36   msg.append(tn.expect(['%'],5))             #等 5秒,如果程式完成了一般我们会收到     37                                              # shell prompt  吧,假设为 '%'    38   tn.close()                                 #关闭连线     39   del   tn    40   return   msg[len(msg)-1][2]                #把收到的讯息通通传回去。     41                                              #(注意 msg  中第 2个元素才是真的讯息,     42                                              #其他是附加资讯。     43     44 if __name__   == '__main__'                  #这是 python  常用的技巧:如果 telnetdo.py 程式    45                                              #是从 command prompt    46                                              #引发的话则 __name__  的内容为 __main__,相反    47                                              #如果是从别的程式用 import telnetdo  的话则    48                                              # __name__  会变成 'telnetdo'    49   print   telnetdo()                         #这样写的好处是从此 telnetdo  会成为你的扩展    50                                              #模组,你可以在别的程式中     51                                               #用telnetdo.telnetdo(HOST,USER,PASS,COMMAND)来调用它!
这个程式用法如下:

 

以下是代码片段:> chmod +x telnetdo.py  > telnetdo.py 'somehost' 'glace' 'xxxxxx' 'ls   -lF'    (0, , '\015\012\015\012Linux  (somehost)\015\012\015\015\012\015login: ')  (0, , 'Password:')  (0, , '\015\012Yup Release 2.6   somehost\015\012Last login: Wed   Mar    6 18:21:01 GMT 2002 by  UNKNOWN@xxx.xxx.xxx.xxxyou have   mail\015\012somehost:glace%')    total 320  -rw-r--r--    1 glace    user        139788 Feb    8 17:54 PQR2.1.txt  drwxr-xr-x    3 glace    user          4096 Feb   10 16:45 mytts/  drwxr-xr-x    3 glace    user          4096 Jan   29 19:03 sample/  drwxr-xr-x    2 glace    user          4096 Jan    6 16:38 tex/  drwxr-xr-x    2 glace    user          4096 Sep    5  2001 tmp/  drwxr-xr-x    2 glace    user            29 Feb   23  2001 tools/  drwxr-xr-x    2 glace    user            26 Feb    6 18:43 trash/  somehost:glace%  可以看到执行的结果和一些附加的资讯。这就是远端执行程式了。就算没有 rsh,照用可也。 哈,很方便吧。不过你应该留意到了程式执行时只等候了 5秒,就是说如果你要向主机发出像 'find . -name xxx   -print' 这样的命令应该等不到执行完这个 telnet session 就会被关闭了。不过仔细想一下,这要紧吗?我们现在所能做到的和真正人手 telnet 的差别并不大,想一想你会怎样解决长时间执行的问题?没错,就是 'nohup'和背景作业了。 就是说只要把程式呼叫改成:  telnetdo.py 'apocal' 'pcheung' 'xxxxxx' 'nohup   myprogram_or_script&'  就行了。如此一来,就算对方主机的 shell prompt 是 '>'或是 '>>>'都没有关系了。

(注意安全性并非是这类范例程式的着重点, 因此并不建议在实际工作中用它.) 

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Python vs. C : 응용 및 사용 사례가 비교되었습니다Python vs. C : 응용 및 사용 사례가 비교되었습니다Apr 12, 2025 am 12:01 AM

Python은 데이터 과학, 웹 개발 및 자동화 작업에 적합한 반면 C는 시스템 프로그래밍, 게임 개발 및 임베디드 시스템에 적합합니다. Python은 단순성과 강력한 생태계로 유명하며 C는 고성능 및 기본 제어 기능으로 유명합니다.

2 시간의 파이썬 계획 : 현실적인 접근2 시간의 파이썬 계획 : 현실적인 접근Apr 11, 2025 am 12:04 AM

2 시간 이내에 Python의 기본 프로그래밍 개념과 기술을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우기, 2. 마스터 제어 흐름 (조건부 명세서 및 루프), 3. 기능의 정의 및 사용을 이해하십시오. 4. 간단한 예제 및 코드 스 니펫을 통해 Python 프로그래밍을 신속하게 시작하십시오.

파이썬 : 기본 응용 프로그램 탐색파이썬 : 기본 응용 프로그램 탐색Apr 10, 2025 am 09:41 AM

Python은 웹 개발, 데이터 과학, 기계 학습, 자동화 및 스크립팅 분야에서 널리 사용됩니다. 1) 웹 개발에서 Django 및 Flask 프레임 워크는 개발 프로세스를 단순화합니다. 2) 데이터 과학 및 기계 학습 분야에서 Numpy, Pandas, Scikit-Learn 및 Tensorflow 라이브러리는 강력한 지원을 제공합니다. 3) 자동화 및 스크립팅 측면에서 Python은 자동화 된 테스트 및 시스템 관리와 ​​같은 작업에 적합합니다.

2 시간 안에 얼마나 많은 파이썬을 배울 수 있습니까?2 시간 안에 얼마나 많은 파이썬을 배울 수 있습니까?Apr 09, 2025 pm 04:33 PM

2 시간 이내에 파이썬의 기본 사항을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우십시오. 이를 통해 간단한 파이썬 프로그램 작성을 시작하는 데 도움이됩니다.

10 시간 이내에 프로젝트 및 문제 중심 방법에서 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법?10 시간 이내에 프로젝트 및 문제 중심 방법에서 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법?Apr 02, 2025 am 07:18 AM

10 시간 이내에 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법은 무엇입니까? 컴퓨터 초보자에게 프로그래밍 지식을 가르치는 데 10 시간 밖에 걸리지 않는다면 무엇을 가르치기로 선택 하시겠습니까?

중간 독서를 위해 Fiddler를 사용할 때 브라우저에서 감지되는 것을 피하는 방법은 무엇입니까?중간 독서를 위해 Fiddler를 사용할 때 브라우저에서 감지되는 것을 피하는 방법은 무엇입니까?Apr 02, 2025 am 07:15 AM

Fiddlerevery Where를 사용할 때 Man-in-the-Middle Reading에 Fiddlereverywhere를 사용할 때 감지되는 방법 ...

Python 3.6에 피클 파일을로드 할 때 '__builtin__'모듈을 찾을 수없는 경우 어떻게해야합니까?Python 3.6에 피클 파일을로드 할 때 '__builtin__'모듈을 찾을 수없는 경우 어떻게해야합니까?Apr 02, 2025 am 07:12 AM

Python 3.6에 피클 파일로드 3.6 환경 보고서 오류 : modulenotfounderror : nomodulename ...

경치 좋은 스팟 코멘트 분석에서 Jieba Word 세분화의 정확성을 향상시키는 방법은 무엇입니까?경치 좋은 스팟 코멘트 분석에서 Jieba Word 세분화의 정확성을 향상시키는 방법은 무엇입니까?Apr 02, 2025 am 07:09 AM

경치 좋은 스팟 댓글 분석에서 Jieba Word 세분화 문제를 해결하는 방법은 무엇입니까? 경치가 좋은 스팟 댓글 및 분석을 수행 할 때 종종 Jieba Word 세분화 도구를 사용하여 텍스트를 처리합니다 ...

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음