Event接口的 isTrusted 属性是一个只读属性,它是一个布尔值(Boolean)。当事件是由用户行为生成的时候,这个属性的值为 true ,而当事件是由脚本创建、修改、通过 EventTarget.dispatchEvent() 派发的时候,这个属性的值为 false 。那么selenium爬虫如何绕开js的isTrusted验证?
网友回复
在使用 Selenium 进行爬虫时,有些网站可能会使用 JavaScript 的事件机制来实现用户行为的模拟,例如模拟鼠标点击、键盘输入等操作,同时使用 isTrusted 属性来验证事件对象是否来自真实的用户操作。如果 isTrusted 属性为 false,则说明事件对象是由 JavaScript 代码生成的,而不是来自真实的用户操作,这可能会导致爬虫被识别并被阻止访问网站。
要绕过这种 isTrusted 验证,有几种方法可供尝试: 使用 headless 模式:Selenium 支持 headless 模式,即在无头浏览器中运行测试,这样可以绕过大部分 JavaScript 的验证机制。例如,可以使用 Chrome 浏览器的 headless 模式启动 Selenium:from selenium import webdriver # 创建 Chrome 浏览器实例 options = webdriver.ChromeOptions() options.add_argument('--headless') driver = webdriver.Chrome(options=options)修改事件属性:可以使用 JavaScript 修改事件对象的 is...
点击查看剩余70%