Selenium之PhantomJS相关设置

设置PhantomJS请求头

默认情况下:

from selenium import webdriver
import time

driver = webdriver.PhantomJS()
driver.get('http://httpbin.org/user-agent')
print(driver.page_source)
driver.close()
image

设置User-Agent

from selenium import webdriver
from selenium.webdriver.common.desired_capabilities import DesiredCapabilities
import time

user_agent = "Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.3 Safari/537.36"

dcap = dict(DesiredCapabilities.PHANTOMJS)
dcap["phantomjs.page.settings.userAgent"] = user_agent
dcap["phantomjs.page.customHeaders.User-Agent"] = user_agent

driver = webdriver.PhantomJS(desired_capabilities=dcap)
driver.get('http://httpbin.org/user-agent')
print(driver.page_source)
driver.close()
image

User-Agent已经变成指定的内容

设置PhantomJS不加载图片

from selenium import webdriver
from selenium.webdriver.common.desired_capabilities import DesiredCapabilities
import time

SERVICE_ARGS = ['--load-images=false', '--disk-cache=true','--ignore-ssl-errors=true']

driver = webdriver.PhantomJS(service_args=SERVICE_ARGS)
driver.get('https://www.baidu.com')
driver.save_screenshot('baidu.png')
driver.close()
image

SERVICE_ARGS 常用的参数

--cookies-file=/path/to/cookies.txt       # 指定cookies文件
--disk-cache=[true|false]                 # 是否应用磁盘缓存
--ignore-ssl-errors=[true|false]          # 是否忽略ssl证书错误
--load-images=[true|false]                # 是否加载图片
--output-encoding=encoding                # 指定输出编码 默认是utf8
--proxy=address:port                      # 指定代理服务器,格式是--proxy=192.168.1.42:8080
--proxy-type=[http|socks5|none]           # 指定代理服务器协议类型
--proxy-auth                              # 代理服务器认证,格式是--proxy-auth=username:password

更多设置可以参考官网
参数设置

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,083评论 19 139
  • //Clojure入门教程: Clojure – Functional Programming for the J...
    葡萄喃喃呓语阅读 9,247评论 0 7
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,111评论 25 709
  • 难得有两天完完全全属于自己的时光。不用上班不用陪孩子,一个人在家。本来打算,这两天时间除了吃喝拉撒睡以外,通通都用...
    米勒Li阅读 1,882评论 4 0
  • 一、写生的目的和作用 1.从创作的角度来说,是一种搜集素材的方式(但现已被照相机取代)。 2.是学习绘画的重要训练...
    大龙看世界阅读 2,732评论 0 0

友情链接更多精彩内容