在爬虫过程中有些网站可以识别出你是通过浏览器访问还是爬虫程序访问网站,如果识别出使用的不是浏览器,则会禁止访问或者禁止该用户在网站上的其他行为,比如不允许登录等,这时我们需要继续获取数据就需要使用浏览器伪装技术。我们可以学习一些简单的浏览器防伪装技术,如设置 Header 信息中的 User-Agent 字段,伪装成浏览器来访问。
有一些网站为了避免爬虫的恶意访问,会设置一些反爬虫机制,比如以下这些:
(1) 通过用户请求的 Header 信息进行反爬虫,常见的有 User-Agent 、Referer 字段
(2) 通过检测用户行为进行反爬虫,比如判断同一个IP在短时间内是否频繁访问,我们可以通过设置代理解决
(3) 通过动态页面增加爬虫爬取的难度,达到反爬虫的目的,我们可以利用 Selenium 等工具解决。
我们接下来就学习下如何使用Selenium无头浏览器加上代理访问目标网站,我们以百度会示例,代码示例如下:
from selenium import webdriver import string import zipfile # 代理服务器(产品官网 www.16yun.cn) proxyHost = "t.16yun.cn" proxyPort = "3111" # 代理验证信息 proxyUser = "username" proxyPass = "password" def create_proxy_auth_extension(proxy_host, proxy_port, proxy_username, proxy_password, scheme='http', plugin_path=None): if plugin_path is None: plugin_path = r'/tmp/{}_{}@t.16yun.zip'.format(proxy_username, proxy_password) manifest_json = """ { "version": "1.0.0", "manifest_version": 2, "name": "16YUN Proxy", "permissions": [ "proxy", "tabs", "unlimitedStorage", "storage", "<all_urls>", "webRequest", "webRequestBlocking" ], "background": { "scripts": ["background.js"] }, "minimum_chrome_version":"22.0.0" } """ background_js = string.Template( """ var config = { mode: "fixed_servers", rules: { singleProxy: { scheme: "${scheme}", host: "${host}", port: parseInt(${port}) }, bypassList: ["localhost"] } }; chrome.proxy.settings.set({value: config, scope: "regular"}, function() {}); function callbackFn(details) { return { authCredentials: { username: "${username}", password: "${password}" } }; } chrome.webRequest.onAuthRequired.addListener( callbackFn, {urls: ["<all_urls>"]}, ['blocking'] ); """ ).substitute( host=proxy_host, port=proxy_port, username=proxy_username, password=proxy_password, scheme=scheme, ) print(background_js) with zipfile.ZipFile(plugin_path, 'w') as zp: zp.writestr("manifest.json", manifest_json) zp.writestr("background.js", background_js) return plugin_path proxy_auth_plugin_path = create_proxy_auth_extension( proxy_host=proxyHost, proxy_port=proxyPort, proxy_username=proxyUser, proxy_password=proxyPass) option = webdriver.ChromeOptions() option.add_argument("--start-maximized") # 如报错 chrome-extensions # option.add_argument("--disable-extensions") option.add_extension(proxy_auth_plugin_path) # 关闭webdriver的一些标志 # option.add_experimental_option('excludeSwitches', ['enable-automation']) driver = webdriver.Chrome( chrome_options=option, executable_path="./chromdriver" ) # 修改webdriver get属性 # script = ''' # Object.defineProperty(navigator, 'webdriver', { # get: () => undefined # }) # ''' # driver.execute_cdp_cmd("Page.addScriptToEvaluateOnNewDocument", {"source": script}) driver.get("https://httpbin.org/ip")
在使用Selenium过程中我们要注意浏览器的版本是否是最新的,里面的参数配置能不能对的上。这样才能顺利的访问目标网站,关于代理的使用,这里给大家推介这家https://www.16yun.cn/,因为使用比较久,更方面的效果都很好才推介给有需要的小伙伴的。
若有收获,就点个赞吧