给定域名、部分IP:
整理成C段IP,
1 | #!/usr/bin/python |
1 |
|
一步到位: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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
!/bin/bash
Desc:根据起始IP和结束IP输出IP信息
Usage:./iprange.sh IP.txt
notepad++去重: ^(.*?)$\s+?^(?=.*^\1$) 操作方法如下,快捷键Ctrl+H,在弹出的界面输入表达式,并勾选匹配新行。
换行处理否则报错 /r/n /r 全部替换为 /n
while read line0
do
echo $line1
awk -F $line1 "-" '{print $1,$2}' | while read IPA IPB
do
IPA1=`echo $IPA | awk -F '.' '{print $1}'`
IPA2=`echo $IPA | awk -F '.' '{print $2}'`
IPA3=`echo $IPA | awk -F '.' '{print $3}'`
IPA4=`echo $IPA | awk -F '.' '{print $4}'`
IPB1=`echo $IPB | awk -F '.' '{print $1}'`
IPB2=`echo $IPB | awk -F '.' '{print $2}'`
IPB3=`echo $IPB | awk -F '.' '{print $3}'`
IPB4=`echo $IPB | awk -F '.' '{print $4}'`
IP4_not_equal(){
for i in `eval echo {$IPA4..$IPB4}`
do
echo $IPA1.$IPA2.$IPA3.$i
done
}
IP3_not_equal () {
for i in `eval echo {$IPA3..$IPB3}`
do
if [[ $i = $IPA3 ]]
then
eval echo "192.168.$i.{$IPA4..255}" |xargs -n 1
elif [[ $i = $IPB3 ]]
then
eval echo "192.168.$i.{1..$IPB4}" |xargs -n 1
else
eval echo "192.168.$i.{1..255}" | xargs -n 1
fi
done
}
IP2_not_equal(){
第二段的变化范围
for n in `eval echo {$IPA2..$IPB2}`
do
#如果第二段与IPA的第二段相同
if [ $n = $IPA2 ]
then
#第三段的变化范围为IPA3到255
for m in `eval echo {$IPA3..255}`
do
#如果第三段与IPA的第三段相同
if [[ $m = $IPA3 ]]
then
eval echo "$IPA1.$IPA2.$IPA3.{$IPA4..255}" | xargs -n 1
else
eval echo "$IPA1.$IPA2.$m.{1..255}" | xargs -n 1
fi
done
#如果第三段与IPB的第三段相同
elif [ $n = $IPB2 ]
then
#第三段变化范围为0到IPB3
for x in `eval echo {0..$IPB3}`
do
#如果第三段与IPB的第三段相同
if [ $x = $IPB3 ]
then
eval echo "$IPB1.$IPB2.$IPB3.{0..$IPB4}" |xargs -n 1
else
eval echo "$IPB1.$IPB2.$x.{0..255}" |xargs -n 1
fi
done
#如果第二段与IPA和IPB的均不相同
else
#第三段变化范围
for y in {0..255}
do
echo $IPA1.$n.$y.{0..255} |xargs -n 1
done
fi
done
}
定义pass函数,啥事都不做
pass(){
echo "">/dev/null
}
IP1_not_equal(){
IP第一段的范围
for d1 in `eval echo {$IPA1..$IPB1}`
do
<1>如果第一段与IPA1相同
if [[ $d1 = $IPA1 ]]
then
#第二段IP范围为IPA2到255
for d2 in `eval echo {$IPA2..255}`
do
#<1.1>如果第二段与IPA2相同
if [[ $d2 = $IPA2 ]]
then
#第三段IP范围为IPA3到255
for d3 in `eval echo {$IPA3..255}`
do
#<1.1.1>如果第三段IP与IPA3相同
if [[ $d3 = $IPA3 ]]
then
for d4 in `eval echo {$IPA4..255}`
do
echo $d1.$d2.$d3.$d4
done
#<1.1.2>如果第三段IP与IP3不同
else
for d4 in {0..255}
do
echo $d1.$d2.$d3.$d4
done
fi
done
#<1.2>如果第二段与IPA2不同
else
for d3 in {0..255}
do
for d4 in {0..255}
do
echo $d1.$d2.$d3.$d4
done
done
fi
done
<2>如果第一段IP与IPB相同
elif [[ $d1 = $IPB1 ]]
then
#第二段IP的范围为0到IPB2
for d2 in `eval echo {0..$IPB2}`
do
#<2.1>如果第二段IP与IPB相同
if [[ $d2 = $IPB2 ]]
then
#第三段IP范围为0到IPB3
for d3 in `eval echo {0..$IPB3}`
do
#<2.1.1>如果第三段IP与IPB3相同
if [[ $d3 = $IPB3 ]]
then
for d4 in `eval echo {0..$IPB4}`
do
echo $d1.$d2.$d3.$d4
done
#<2.1.2>如果第三段IP与IPB3不同
else
for d4 in {0..255}
do
echo $d1.$d2.$d3.$d4
done
fi
done
#<2.2>如果第二段IP与IPB不相同
else
#第三段IP范围为{0..255}
for d3 in {0..255}
do
#第四段IP范围为{0.255}
for d4 in {0.255}
do
echo $d1.$d2.$d3.$d4
done
done
fi
done
<3>第一段IP与IPA1和IPB1都不相同
else
for d2 in {0..255}
do
for d3 in {0..255}
do
for d4 in {0..255}
do
echo $d1.$d2.$d3.$d4
done
done
done
fi
done
}
print_range_ip(){
<1>如果两IP第一段不同
if [ $IPA1 != $IPB1 ]
then
IP1_not_equal
<2>如果两IP第一段相同
else
<2.1> 如果第二段IP相同
if [ $IPA2 = $IPB2 ]
then
#<2.1.1>如果第三段IP不相同
if [[ $IPA3 != $IPB3 ]]
then
IP3_not_equal
#<2.2.2>如果第三段IP相同
else
IP4_not_equal
fi
<2.2> 如果第二段IP不相同
else
IP2_not_equal
fi
fi
}
print_range_ip >> allssip.txt
done
done < $1
IP整理完通过工具扫描
爆破子域名
通过已给url确定一级域名列表: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
!/usr/bin/env python
-*- coding: utf-8 -*-
exp: python *.py url.txt
shell去重命令:awk '!a[$0]++' results.txt
import sys
import shutil
import dns.name
from tld import get_tld
from tld.utils import update_tld_names
def getdomain(url):
domain = dns.name.from_text(url).split(3)[1].to_text(omit_final_dot=True)
return(domain)
def getd(url):
update_tld_names()
return(get_tld(url))
def getdomain(domain):
DomainSuffix = {'info': None, 'coop': None, 'mil': None,
'int': None, 'xxx': None, 'pro': None, 'aero': None, 'idv': None,
'biz': None, 'edu': None, 'org': None, 'net': None, 'gov': None,
'com': None, 'museum': None, 'name': None}
Result = []
domain = domain[0:domain.rfind(':')] #去除端口号// url链接不能加http://
if domain.count('.') == 1:
return domain
PointSplitResult = domain.split('.')
if len(filter(lambda x: not x.isdigit(), PointSplitResult)) == 0:
return domain
if DomainSuffix.has_key(PointSplitResult[-1].lower()):
Result = PointSplitResult[-2:]
return '.'.join(Result)
else:
if DomainSuffix.has_key(PointSplitResult[-2].lower()):
Result = PointSplitResult[-3:]
return '.'.join(Result)
else:
Result = PointSplitResult[-2:]
return '.'.join(Result)
if __name__ == '__main__':
file = open(sys.argv[1],'r')
for line in file.readlines():
line=line.strip('\n')
line = line if '://' in line else 'http://' + line
print line
try:
print getdomain(line)
except Exception as e:
print line+">>>>>>>>>"
1 | !/bin/bash |
1 | @echo off&setlocal enabledelayedexpansion |