吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 2857|回复: 1
收起左侧

[Python 转载] google搜索爬取&xray被动扫描

  [复制链接]
aydcyhr 发表于 2020-8-28 11:12

步骤

收集url至url.txt
python google.py

打开xray开始监听
python xray.py

自动化网页链接收集并打开
python scan.py

注意

1.需要安装selenium模块
2.安装chrome浏览器及chromedriver程序
3.chromedriver需要配置环境变量
4.需要添加证书至chrome
5.启动脚本前请删除或转移myscan_report.html以及url_spider.txt

启动

python main.py

运行环境

python3.7

PIP

pip install

selenium
urllib
requests
pyquery
threading

`from selenium import webdriver  # 用来驱动浏览器的
from selenium.webdriver.chrome.options import Options
from selenium.common.exceptions import TimeoutException
from selenium.webdriver.support.wait import WebDriverWait
import time
import os
from faker import Factory
import random

检查是否有残留url.txt文件

'''
if os.path.exists('url/url_0.txt'):
os.remove('url/url_0.txt')
else:
print("没有url/url_0.txt文件残留")
'''

pages = int(input("请输入扫描深度(页数):"))

with open('keyword.txt', 'r') as x:
for line in x:
word = line.replace('\n', '')
print("搜索关键词:"+word)
for page in range(0,pages):
print("正在爬取第"+str(page+1)+"页")
page = page*10

随机谷歌域名,防封

        domain=random.choice(['www.google.com'
        ,'www.google.gl'
        ,'www.google.com.sv'
        ,'www.google.hn'
        ,'www.google.co.cr'
        ,'www.google.com.jm'
        ,'www.google.ht'
        ,'www.google.com.pr'
        ,'www.google.vg'
        ,'www.google.com.ag'
        ,'www.google.dm'
        ,'www.google.com.vc'
        ,'www.google.tt'
        ,'www.google.com.ar'
        ,'www.google.com.br'
        ,'www.google.com.co'
        ,'www.google.co.ve'
        ,'www.google.com.ec'
        ,'www.google.com.uy'
        ,'www.google.no'
        ,'www.google.is'
        ,'www.google.dk'
        ,'www.google.lv'
        ,'www.google.lt'
        ,'www.google.ru'
        ,'www.google.pl'
        ,'www.google.sk'
        ,'www.google.at'
        ,'www.google.ie'
        ,'www.google.nl'
        ,'www.google.be'
        ,'www.google.fr'
        ,'www.google.it'
        ,'www.google.es'
        ,'www.google.ro'
        ,'www.google.gr'
        ,'www.google.ba'
        ,'www.google.sm'
        ,'www.google.com.au'
        ,'www.google.co.nz'
        ,'www.google.co.ck'
        ,'www.google.com.sb'
        ,'www.google.ws'
        ,'www.google.as'
        ,'www.google.to'
        ,'www.google.co.il'
        ,'www.google.com.sa'
        ,'www.google.com.eg'
        ,'www.google.ae'
        ,'www.google.com.bh'
        ,'www.google.jo'
        ,'www.google.com.ly'
        ,'www.google.co.ma'
        ,'www.google.com.et'
        ,'www.google.mu'
        ,'www.google.ci'
        ,'www.google.dj'
        ,'www.google.cd'
        ,'www.google.cg'
        ,'www.google.gm'
        ,'www.google.co.ke'
        ,'www.google.com.gi'
        ,'www.google.co.bw'
        ,'www.google.co.zm'
        ,'www.google.com.na'
        ,'www.google.co.ls'
        ,'www.google.sh'
        ,'www.google.mw'
        #,'www.google.cn'
        ,'www.google.co.kr'
        ,'www.google.mn'
        ,'www.google.co.jp'
        ,'www.google.com.hk'
        ,'www.google.com.tw'
        ,'www.google.com.vn'
        ,'www.google.com.my'
        ,'www.google.co.id'
        ,'www.google.com.pk'
        ,'www.google.com.bd'
        ,'www.google.com.np'
        ,'www.google.az'
        ,'www.google.am'
        ,'www.google.tm'
        ,'www.google.co.uz'
        ,'www.google.kg'
        ,'www.google.com.tj'])
        print('使用谷歌域名:'+domain)
        url = 'https://www.google.com.hk/search?q='+word+'&hl=zh&start='+str(page)+'&safe=images'#英文en中文zh
        #url = 'https://'+domain+'/search?q='+word+'&hl=zh&start='+str(page)+'&safe=images'#英文en中文zh
        #chromedriver打开指定url
        option=Options()
        option.add_argument("--headless")#没有窗口
        option.add_argument('–disable-javascript')
        #option.add_argument('--window-size=300,200')
        option.add_argument('--blink-settings=imagesEnabled=false')#不显示图片
        #使用随机ua,不然封ip需要人机验证
        f = Factory.create()
        ua = f.user_agent()
        print('使用UA:'+ua)
        option.add_argument('--user-agent="'+ua+'"')

        driver =webdriver.Chrome(options=option)
        driver.get(url)

        #标签分类
        nodelist = driver.find_elements_by_xpath("//a")
        for url in nodelist:
            url1=str(url.get_attribute("href"))

            if url1!='None' and url1[0:18]!='https://www.google' and url1[0:15]!='https://support' and url1[0:20]!='https://accounts.goo' and url1[0:19]!='https://maps.google' and url1[0:20]!='https://translate.go' and url1[0:23]!='https://policies.google' and url1[0:23]!='https://webcache.google'and url1[0:22]!='http://webcache.google'and url1[8:21]!=domain[0:13]:
                print(url1)
                fp=open("url/url_0.txt","a+",encoding="utf-8")
                fp.write(url1+'\n')
                fp.close()
        driver.quit()
        #time.sleep(random.randint(5,10))

print("\n\n\n\n--------------------\n------收集完成------\n--------------------\n")

def spider(url,num):
option=Options()
option.add_argument("--headless")#没有窗口
option.add_argument('–disable-javascript')

option.add_argument('--window-size=300,200')

option.add_argument('–no-sandbox')
#option.add_argument('--blink-settings=imagesEnabled=false')#不显示图片
option.add_argument('--proxy-server=http://127.0.0.1:23333')
#使用随机ua,不然封ip需要人机验证
f = Factory.create()
ua = f.user_agent()
print('使用UA:'+ua)
option.add_argument('--user-agent="'+ua+'"')
driver =webdriver.Chrome(options=option)
driver.get(url)
#标签分类
nodelist = driver.find_elements_by_tag_name('a') + driver.find_elements_by_tag_name('script') + driver.find_elements_by_tag_name('img') + driver.find_elements_by_tag_name('link') + driver.find_elements_by_tag_name('iframe')
for url in nodelist:
    print(url)
    if url.get_attribute("src"):
        url1 = url.get_attribute("src")
        if str(url1)[0:4]=='http':
            print(str(url1))
            file = 'url/url_'+str(num)+'.txt'
            fp=open(file,"a+",encoding="utf-8")
            fp.write(url1+'\n')
            fp.close()
    if url.get_attribute("href"):
        url2 = url.get_attribute("href")
        if str(url2)[0:4]=='http':
            print(str(url2))
            file = 'url/url_'+str(num)+'.txt'
            fp=open(file,"a+",encoding="utf-8")
            fp.write(str(url2)+'\n')
            fp.close()
driver.quit()

number = int(input("请输入扫描迭代次数:"))
num = 1
while num <= number:
txt = 'url/url_'+str(num-1)+'.txt'
print(txt)
with open(txt, 'r') as x:
for line in x:
if line and line[0:4]=='http':
print(line)
spider(line,num)
time.sleep(10)
num = num+1`




--------------------------------------------------------------
附github地址
https://github.com/aydcyhr/google-xray

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-28 02:14

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表