使用selenium实现cookies免密登录

一直想用selenium实现个小功能,比如发微博之类的,但是有的网站在登录会有验证码,没想到太好的方法解决,于是想到利用cookies来登录网站。

获取一个可用的cookies

获取的cookies会保存为一个json格式的文件。不过在打开网站后,登录操作需要自己手动进行一下,代码中有注释,大家可以注意一下,

代码如下:

#!/usr/bin/python
#coding=utf-8
   
from selenium import webdriver
import time
import json
   
def get_cookies(test_url):
    #保存cookies的文件
    file = 'cookies.json'
    #打开需要获取cookies的网站
    driver = webdriver.Firefox()
    driver.implicitly_wait(5)
    driver.get(test_url)
    driver.maximize_window()
    #网站打开后,在时间内手动执行登录操作
    time.sleep(60)
    #登录成功后,获取cookies并保存为json格式
    cookies = driver.get_cookies()
    fp = open(file,'w')
    json.dump(cookies,fp)
    fp.close()
    #关闭浏览器
    driver.close()
   
if __name__ == "__main__":
    url = raw_input('please input url:')
    get_cookies(url)

利用cookies登录网站

先打开要登录的网站,然后将cookies从之前保存的json文件读取出来,然后添加到浏览器,刷新界面,即可实现登录,然后便可以进行发微博的操作,具体元素定位,请大家百度selenium的一些基本用法,此处不再赘述。代码中也给出了不打开浏览器的方式来实现功能。

代码如下:

   #!/usr/bin/python
   #coding=utf-8
   
   from selenium import webdriver
   import json
   import time
   
   file = 'cookies.json'
   #打开浏览器,若不想打开浏览器运行脚本,可以使用下面注释掉的方法
   driver = webdriver.Firefox()
   
   #以headless模式运行脚本,可以实现不打开浏览器对网站进行操作
   #option = webdriver.FirefoxOptions()
   #option.add_argument(argument='-headless')
   #driver = webdriver.Firefox(firefox_options=option)
   
   #打开网址
   def open_url(url):
       driver.get(url)
       driver.implicitly_wait(5)
       driver.maximize_window()
   
   #向浏览器添加保存的cookies
   def add_cookies():
       fp = open(file,'r')
       cookies = json.load(fp)
       fp.close()
       for cookie in cookies:
           driver.add_cookie(cookie)  
   
   if __name__ == "__main__":
       #输入要打开的网站并打开
       test_url = raw_input('please input url:')
       open_url(test_url)
       time.sleep(5)
       #添加cookies后刷新界面,实现免密登录
       add_cookies()
       driver.refresh()
       # 发送微博
       #定位到微博输入框,点击输入框
       driver.find_element_by_xpath("//textarea[@class='W_input']").click()
       time.sleep(2)
       #输入需要发送的内容
       driver.find_element_by_xpath("//textarea[@class='W_input']").send_keys('Test message')
       time.sleep(3)
       #点击发送按钮
       driver.find_element

原创文章,作者:晴川运维,如若转载,请注明出处:https://baike.qcidc.com/8887.html

(0)
晴川运维晴川运维
上一篇 2025年6月13日
下一篇 2025年6月13日

相关推荐

  • 详解Linux /etc/shadow文件

    linux的root密码存在于“/etc/shadow”这个文件中,不过要有root权限才能在linux下看到“/etc/shadow”这个文件,本篇文章重点为大家讲解一下Linu…

    Linux系统 2025年6月4日
  • Linux中与用户账号相关的重要文件

    完成用户管理的工作有许多种方法,但是每一种方法实际上都是对有关的系统文件进行修改。 与用户和用户组相关的信息都存放在一些系统文件中,这些文件包括/etc/passwd, /etc/…

    Linux系统 2025年6月9日
  • Linux内核增加HDF驱动子系统

    HDF驱动子系统是OpenHarmony重要的特色功能之一,其主要的功能是实现驱动程序在多内核多平台的物联网环境,实现一次驱动开发,多端部署。之前移植OHOS3.0使用了传统的li…

    Linux系统 2025年6月8日
  • Linux下安装LDAP

    LDAP是一个得到关于人或者资源的集中、静态数据的快速方式。LDAP是一个用来发布目录信息到许多不同资源的协议。通常它都作为一个集中的地址被使用,不过根据组织者的需要,它可以做得更…

    Linux系统 2025年6月8日
  • 以源码的方式讲解一下Rarp协议

    rarp是通过mac地址查询ip的协议,主要用于有mac的主机,但是没有ip的情况。 rarp协议的格式和arp协议是一样的,他们都是通过一种地址查询另外一种地址。操作系统内维护了…

    Linux系统 2025年10月19日
  • Linux中清除APT缓存具体方法

    Linux中如何清除APT缓存?本篇文章重点为大家讲解一下Linux中清除APT缓存具体方法,有需要的小伙伴可以参考一下。 如何清除 APT 缓存?你只需使用这个 apt-get …

    Linux系统 2025年6月8日
  • 简单介绍一下HTTP X-Forwarded-For

    X-Forwarded-For 是一个 HTTP 扩展头部。HTTP/1.1(RFC 2616)协议并没有对它的定义,它最开始是由 Squid 这个缓存代理软件引入,用来表示 HT…

    Linux系统 2025年6月30日
  • 详解Linux tar 命令

    linux下最常用的打包程序就是tar了,使用tar程序打出来的包我们常称为tar包,tar包文件的命令通常都是以.tar结尾的。生成tar包后,就可以用其它的程序来进行压缩。 语…

    Linux系统 2025年7月11日
  • 详解Sass 变量

    Sass(Syntactically Awesome StyleSheets)是css的一个扩展开发工具,它允许你使用变量、条件语句等,使开发更简单可维护。 变量用于存储一些信息,…

    Linux系统 2025年6月10日
  • Linux groupadd命令:添加用户组

    添加用户组的命令是 groupadd,命令格式如下: [root@localhost ~]# groupadd [选项] 组名 选项: -g GID:指定组 ID; -r:创建系统…

    Linux系统 2025年10月27日

发表回复

登录后才能评论