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 <target host> -p <target port>'</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>