python + seleinum +phantomjs 设置headers和proxy代理

 
 

最近因为工作需要使用selenium+phantomjs无头浏览器,其中遇到了一些坑,记录一下,尤其是关于phantomjs设置代理的问题。

基本使用

首先在python中导入使用的包,其中webdriver是要创建无头浏览器对象的模块,DesiredCapabilites这个类是浏览器对象的一些选项设置。

  1.  
    from selenium import webdriver
  2.  
    from selenium.webdriver.common.desired_capabilities import DesiredCapabilities
  3.  
     
  4.  
    # 初始化浏览器对象
  5.  
    desired_cap = DesiredCapabilities.PHANTOMJS.copy()
  6.  
    driver = webdriver.PhantomJS(desired_capabilities=desired_cap)

修改请求头

在使用爬虫的过程中我们需要修改请求投中的user-agent防止被反爬,修改过程如下

  1.  
    desired_cap = DesiredCapabilities.PHANTOMJS.copy()
  2.  
    # 修改请求头中的UA
  3.  
    desired_cap['phantomjs.page.settings.userAgent'] = 'xxxxxx'
  4.  
    # 设置其他请求投信息,其中key为要修改的请求投键名
  5.  
    desired_cap['phantomjs.page.customHeaders.{}'.format(key)] = 'xxxx'
  6.  
    driver = webdriver.PhantomJS(desired_capabilities=desired_cap)

设置代理

在使用爬虫过程中,经常需要使用代理ip,网上关于这方面资料较少,我也是搜集了好久,记录一下

ip代理有静态ip代理和动态ip代理,先说静态ip,静态ip就是134.119.184.92:1080这样的代理,不需要使用验证信息,使用方法如下:

  1.  
    # 配置代理信息
  2.  
    proxy = [
  3.  
    '--proxy=%s' % "218.60.8.83:3129", # 设置的代理ip
  4.  
    '--proxy-type=http', # 代理类型
  5.  
    '--ignore-ssl-errors=true', # 忽略https错误
  6.  
    ]
  7.  
     
  8.  
    # 在初始化浏览器对象的时候可以接收一个service_args的参数,使用这个参数设置代理
  9.  
    drive = webdriver.PhantomJS(service_args=proxy)
  10.  
     
  11.  
    # 设置页面加载和js加载超时时间,超时立即报错,如下设置超时时间为10秒
  12.  
    drive.set_page_load_timeout(10)
  13.  
    drive.set_script_timeout(10)
  14.  
     
  15.  
    # 这样代理就设置成功了,可以向百度发送请求验证ip是否可用
  16.  
    drive.get('http://www.baidu.com')

以上是静态代理设置方法,但是我们时候使用的是动态代理,设置方法有所变化,需要在参数里加上验证使用的用户名和密码,代码如下:

  1.  
    # 代理设置如下:
  2.  
    proxy = [
  3.  
    '--proxy=%s:%s' % (proxyHost, proxyPort), # 代理服务器的域名
  4.  
    '--proxy-type=http', # 代理类型
  5.  
    '--proxy-auth=%s:%s' % (proxyUser, proxyPass), # 代理验证所需的用户名和密码
  6.  
    '--ignore-ssl-errors=true', # 忽略https错误
  7.  
    ]
  8.  
     
  9.  
    # 在初始化浏览器对象的时候可以接收一个service_args的参数,使用这个参数设置代理
  10.  
    drive = webdriver.PhantomJS(service_args=proxy)
  11.  
     
  12.  
    # 设置页面加载和js加载超时时间,超时立即报错,如下设置超时时间为10秒
  13.  
    drive.set_page_load_timeout(10)
  14.  
    drive.set_script_timeout(10)
  15.  
     
  16.  
    # 这样代理就设置成功了,可以向百度发送请求验证ip是否可用
  17.  
    drive.get('http://www.baidu.com')

以上就是使用selenium + phantomjs无头浏览器设置headers和代理的方法。

python + seleinum +phantomjs 设置headers和proxy代理的更多相关文章

  1. Python爬虫连载10-Requests模块、Proxy代理

    一.Request模块 1.HTTP for Humans,更简洁更友好 2.继承了urllib所有的特征 3.底层使用的是urllib3 4.​开源地址:https://github.com/req ...

  2. python爬虫scrapy之downloader_middleware设置proxy代理

    一.背景: 小编在爬虫的时候肯定会遇到被封杀的情况,昨天爬了一个网站,刚开始是可以了,在settings的设置DEFAULT_REQUEST_HEADERS伪装自己是chrome浏览器,刚开始是可以的 ...

  3. selenium phantomjs 设置代理ip方法

    最近遇到phantomjs动态更换ip的功能,在知乎上看到一篇不错的文章,顺手记下来以备后用 phantomjs selenium 如何动态修改代理? 可以这样做(Python代码): # 不使用代理 ...

  4. Python爬虫设置Headers

    Python设置Headers import urllib import urllib2 url = 'http://www.server.com/login' user_agent = 'Mozil ...

  5. C# 使用 Proxy 代理请求资源

    C# 使用 Proxy 请求资源,基于 HttpWebRequest 类 前言 这是上周在开发 C# 中使用 Proxy 代理时开发的一些思考和实践.主要需求是这样的,用户可以配置每次请求是否需要代理 ...

  6. ES6新特性:Proxy代理器

    ES6新特性:Proxy: 要使用的话, 直接在浏览器中执行即可, node和babel目前还没有Proxy的polyfill;,要使用的话,直接在浏览器中运行就好了, 浏览器的兼容性为:chrome ...

  7. Proxy 代理模式

    简介 代理模式是用一个简单的对象来代替一个复杂的或者创建耗时的对象. java.lang.reflect.Proxy RMI 代理模式是对象的结构模式.代理模式给某一个对象提供一个代理对象,并由代理对 ...

  8. 豌豆夹Redis解决方式Codis源代码剖析:Proxy代理

    豌豆夹Redis解决方式Codis源代码剖析:Proxy代理 1.预备知识 1.1 Codis Codis就不详细说了,摘抄一下GitHub上的一些项目描写叙述: Codis is a proxy b ...

  9. 豌豆夹Redis解决方案Codis源码剖析:Proxy代理

    豌豆夹Redis解决方案Codis源码剖析:Proxy代理 1.预备知识 1.1 Codis Codis就不详细说了,摘抄一下GitHub上的一些项目描述: Codis is a proxy base ...

随机推荐

  1. python魔法函数之__getattr__与__getattribute__

    getattr 在访问对象的属性不存在时,调用__getattr__,如果没有定义该魔法函数会报错 class Test: def __init__(self, name, age): self.na ...

  2. ionic3 调用摄像头 当键盘弹出时候 出现摄像头 背景

    iOS 端毫无 bug,Android 端却出现了问题.当软键盘弹出后,Android 端的 tabs 移到了软键盘的上面,再仔细一看,整个界面都被压扁了,输入框也不知道去哪儿了. 于是去翻 Ioni ...

  3. hdu4276 依赖背包

    网上题解都是用spfa求1-n路径的,但其实dfs一次就可以了.. #include <iostream> #include <cstdio> #include <str ...

  4. noip 2018.10.14 模拟赛 砍树

    数学问题... 根据题意,有: 移项,整理,得: 记 于是 那么 可以看到,最多只会有2*个取值(显而易见) 于是对应的,可能产生效果的d也只会有个,于是我们把他们找出来,扔进一个数组里然后排序,去重 ...

  5. git 小乌龟安装教程

    一.windows系统安装git 首先下载git for windows客户端http://msysgit.github.io/ 安装过程没什么特别的,不停next就ok了     图太多就不继续了~ ...

  6. RFC2119:RFC协议动词含义

    协议地址:http://www.ietf.org/rfc/rfc2119.txt MUST 必须的.通过它描述的对象,是强制要求的.它与REQUIRED和SHALL含义相同. MUST NOT 不允许 ...

  7. 2019-3-9,Servlet转跳链接详解

    //以下代码,可以传递request和response对象及其属性和变量至指定页面 request.getRequestDispatcher("showAttribut.jsp") ...

  8. python datetime.datetime is not JSON serializable

    1.主要是python  list转换成json时对时间报错:datetime.datetime(2014, 5, 23, 9, 33, 3) is not JSON serializable. 2. ...

  9. github.com加速节点

    github.com加速节点 192.30.253.118 github.com192.30.253.119 github.com93.46.8.89 github.com

  10. .NetCore 下开发独立的(RPL)含有界面的组件包 (三)构建界面

    .NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作 .NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服 务 .NetCore 下开发独立的(RPL)含 ...