首页 > 其他 > 详细

selenium被识别的解决方法

时间:2020-10-23 12:01:28      阅读:134      评论:0      收藏:0      [点我收藏+]

遇到问题:

selenium做爬虫能解决很多反爬问题,但是selenium也有很多特征可以被识别,比如用selenium驱动浏览器后window.navigator.webdriver值是true,而正常运行浏览器该值是未定义的(undefined)

3步解决方案,实测有效

第一步,使用chrome开发者模式

options = webdriver.ChromeOptions()
options.add_experimental_option(‘excludeSwitches‘, [‘enable-automation‘])
  • 1
  • 2

第二步,禁用启用Blink运行时的功能

options.add_argument("--disable-blink-features=AutomationControlled")
  • 1

第三步,Selenium执行cdp命令

再次覆盖window.navigator.webdriver的值

driver = webdriver.Chrome(options=options)
    driver.execute_cdp_cmd("Page.addScriptToEvaluateOnNewDocument", {
        "source": """
                    Object.defineProperty(navigator, ‘webdriver‘, {
                      get: () => undefined
                    })
                  """
    })
 

 

 

selenium被识别的解决方法

原文:https://www.cnblogs.com/php-no-2/p/13862640.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!