天天看點

00-掃描-TCP全連接配接掃描

Python 2.7.12+ (default, Sep  1 2016, 20:27:38) 

[GCC 6.2.0 20160822] on linux2

Type "help", "copyright", "credits" or "license" for more information.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

<code>#!/usr/bin/python</code>

<code># -*- coding: utf-8 -*-</code>

<code>import</code> <code>optparse</code>

<code>from</code> <code>socket </code><code>import</code> <code>*</code>

<code>from</code> <code>threading </code><code>import</code> <code>*</code>

<code>screenLock </code><code>=</code> <code>Semaphore(value</code><code>=</code><code>1</code><code>)</code>

<code>def</code> <code>connScan(tgtHost, tgtPort):</code>

<code>    </code><code>try</code><code>:</code>

<code>        </code><code>connSkt </code><code>=</code> <code>socket(AF_INET, SOCK_STREAM)</code>

<code>        </code><code>connSkt.connect((tgtHost, tgtPort))</code>

<code>        </code><code>connSkt.send(</code><code>'ViolentPython\r\n'</code><code>)</code>

<code>        </code><code>results </code><code>=</code> <code>connSkt.recv(</code><code>100</code><code>)</code>

<code>        </code><code>screenLock.acquire()</code>

<code>        </code><code>print</code> <code>'[+] %d/tcp open'</code> <code>%</code> <code>tgtPort</code>

<code>        </code><code>print</code> <code>'[+] '</code> <code>+</code> <code>str</code><code>(results)</code>

<code>    </code><code>except</code><code>:</code>

<code>        </code><code>print</code> <code>'[-] %d/tcp closed'</code> <code>%</code> <code>tgtPort</code>

<code>    </code><code>finally</code><code>:</code>

<code>    </code><code>screenLock.release()</code>

<code>    </code><code>connSkt.close()</code>

<code>def</code> <code>portScan(tgtHost, tgtPorts):</code>

<code>        </code><code>tgtIP </code><code>=</code> <code>gethostbyname(tgtHost)</code>

<code>        </code><code>print</code> <code>"[-] Cannot resolve '%s': Unknown host"</code> <code>%</code><code>tgtHost</code>

<code>        </code><code>return</code>

<code>        </code><code>tgtName </code><code>=</code> <code>gethostbyaddr(tgtIP)</code>

<code>        </code><code>print</code> <code>'\n[+] Scan Results for: '</code> <code>+</code> <code>tgtName[</code><code>0</code><code>]</code>

<code>        </code><code>print</code> <code>'\n[+] Scan Results for: '</code> <code>+</code> <code>tgtIP</code>

<code>    </code><code>setdefaulttimeout(</code><code>1</code><code>)</code>

<code>    </code><code>for</code> <code>tgtPort </code><code>in</code> <code>tgtPorts:</code>

<code>        </code><code>t </code><code>=</code> <code>Thread(target</code><code>=</code><code>connScan,args</code><code>=</code><code>(tgtHost,</code><code>int</code><code>(tgtPort)))</code>

<code>        </code><code>t.start()</code>

<code>def</code> <code>main():</code>

<code>    </code><code>parser </code><code>=</code> <code>optparse.OptionParser(</code><code>'usage %prog '</code><code>+</code><code>\</code>

<code>      </code><code>'-H &lt;target host&gt; -p &lt;target port&gt;'</code><code>)</code>

<code>    </code><code>parser.add_option(</code><code>'-H'</code><code>, dest</code><code>=</code><code>'tgtHost'</code><code>, </code><code>type</code><code>=</code><code>'string'</code><code>,\</code>

<code>      </code><code>help</code><code>=</code><code>'specify target host'</code><code>)</code>

<code>    </code><code>parser.add_option(</code><code>'-p'</code><code>, dest</code><code>=</code><code>'tgtPort'</code><code>, </code><code>type</code><code>=</code><code>'string'</code><code>,\</code>

<code>      </code><code>help</code><code>=</code><code>'specify target port[s] separated by comma'</code><code>)</code>

<code>    </code><code>(options, args) </code><code>=</code> <code>parser.parse_args()</code>

<code>    </code><code>tgtHost </code><code>=</code> <code>options.tgtHost</code>

<code>    </code><code>tgtPorts </code><code>=</code> <code>str</code><code>(options.tgtPort).split(</code><code>','</code><code>)</code>

<code>    </code><code>if</code> <code>(tgtHost </code><code>=</code><code>=</code> <code>None</code><code>) | (tgtPorts[</code><code>0</code><code>] </code><code>=</code><code>=</code> <code>None</code><code>):</code>

<code>    </code><code>print</code> <code>parser.usage</code>

<code>        </code><code>exit(</code><code>0</code><code>)</code>

<code>    </code><code>portScan(tgtHost, tgtPorts)</code>

<code>if</code> <code>__name__ </code><code>=</code><code>=</code> <code>'__main__'</code><code>:</code>

<code>    </code><code>main()</code>

<code>本文轉自文東會部落格51CTO部落格,原文連結http://blog.51cto.com/hackerwang/1906747如需轉載請自行聯系原作者                                                                                   謝文東666</code>

繼續閱讀