forked from james-see/python-examples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmask-search-example.py
71 lines (63 loc) · 2.99 KB
/
mask-search-example.py
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
#!/usr/bin/python3
# mask-search-example
# what: this example searches up to different random terms plus the term you actually want to mask what you are searching for
# author: James Campbell
# date: 2015-05-29
# Note: MUST USE PYTHON 3 from terminal, e.g. python3 mask-search-example.py
import json
import urllib.request, urllib.parse
import random
def searchG(searchfor):
searchlist.append(searchfor)
for terms in searchlist:
randomuseragent = singlerando(useragents) # select a random user agent from list
headers = { 'User-Agent' : randomuseragent } # get random header from above
if terms != searchfor: # if the search term is not the one you care about, let the user know
print ('This is a mask term: %s This is mask header: %s' % (terms,headers['User-Agent']))
query = urllib.parse.urlencode({'q': terms})
url = 'http://ajax.googleapis.com/ajax/services/search/web?v=1.0&%s' % query # GOOGLE ajax API string
search_response_pre = urllib.request.Request(url,None,headers) # key to get the random headers to work
search_response = urllib.request.urlopen(search_response_pre)
search_results = search_response.read().decode("utf8")
results = json.loads(search_results)
data = results['responseData']
if terms == searchfor:
print('Total results: %s' % data['cursor']['estimatedResultCount'])
hits = data['results']
if terms == searchfor:
print('Top %d hits:' % len(hits))
for h in hits: print(' ', h['url'])
print('For more results, see %s' % data['cursor']['moreResultsUrl'])
# global dictionary list of terms - do not change
diction = []
subset = []
lengthmin = 6
searchlist = [] # the list of terms that will be generated in the rando function
# randomly select the user agent for each search, make the useragents list as long as yout want ;)
useragents = ['Mozilla/5.0','Bandicout Broadway 2.4','Carls Crawler Critter 1.0','Dirty Dungeon Diksearch 69','Internet Explorer but better']
fname = 'assets/dictionary-list.html'
with open(fname) as f:
diction = f.readlines()
for term in diction:
if len(term) > lengthmin:
subset.append(term.strip('\n'))
# function to get a random term or terms from the minlength dictionary in subset list
def rando(listofterms,num):
i = 0
while i < num:
randomed = random.choice(listofterms)
#print randomed
searchlist.append(randomed)
i = i + 1
return # returning back searchlist appended with more results
# function that returns one random value from a list only
def singlerando(listofterms):
randomed = random.choice(listofterms)
return randomed
numterms = int(input('Hello, how many terms to hide in addition to actual search term? (max 5) ?: '))
rando(subset,numterms) # get total list of terms based on numterms set in the globals section above
real_search = input('set search term: ') # set the search term
if real_search == '':
print('Since search input blank, example running as James Campbell awesome developer')
real_search = 'James Campbell awesome developer'
searchG(real_search)