解决selenium授权auth弹窗登录问题

删除线格式 背景:模拟弹窗类型授权网站登录,然后输入关键词进行查询的交互操作

  • 如图:
    在这里插入图片描述

  • 原因:

    • 弹窗不方便确认element代码元素位置,难以获取相关元素进行操作。
  • 解决办法01

    • 核心代码:
    browser.get("http://username:password@rpc-admin.middleware.k2.test.xxxxx.info/")
    
    • 说明:将登陆的用户名和密码按照上面的路径进行放置,就可以正常访问该页面。
    • 详细代码:
    • 此处是根据关键词获取dubbo接口的ip和port信息代码(仅供参考 用户名和密码均为admin)
    	# 调用谷歌浏览器驱动并创建对象
        browser = webdriver.Chrome(executable_path="/Users/mac/projectsfiles/driver/chromedriver")
        # 打开浏览器 模拟浏览器请求页面
        browser.get("http://admin:admin@rpc-admin.middleware.k2.test.xxxxx.info/")
        # 睡眠0.5秒
        sleep(0.5)
        # 获取页面的标题
        print(browser.title)
        # 获取页面的源码信息
        # print(browser.page_source)
        # 保存页面快照
        browser.save_screenshot('images/admin-index.png')
        # 找到输入框并输入自定义关键词(interface)
        browser.find_element_by_xpath('//*[@id="searchContent"]').send_keys(interface)
        # 找到查询按钮并模拟点击事件
        browser.find_element_by_xpath('//*[@id="con_one_1"]/div[2]/a/img').click()
        # print(browser.page_source)
        browser.save_screenshot('images/admin-result.png')
        # 找到ip和port
        address = browser.find_element_by_xpath('//*[@id="table_o"]/tbody/tr[2]/td[2]/a').text
        print(address)
        if address == None:
            return "project or branch has been switched!"
        else:
            list = address.split(":")
            print("the ip and port are:" + list[0], list[1])
            return list
    
  • 解决办法02

    • 一般这种类型的登录成功后都会生成一个Authorization字段的授权码,如图:
      在这里插入图片描述
    • 如果账号、密码以及生成的Authorization字段不变的情况下,可以将这关键信息放到headers里面,然后通过requests.get(url, headers=headers)进行请求即可,也可以实现上述功能。
    • 详细代码(不做详细解释):
url = "http://rpc-admin.middleware.k2.test.xxxxx.info/governance/services/%s/providers"%interface
    headers = {
        'Authorization': "Basic Z3Vlc3Q6Z3Vlc3Q=",
        'Accept': "*/*",
        'Accept-Language': "zh-CN,zh;q=0.9",
        'Cache-Control': "max-age=0",
        'User-Agent': "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.132 Safari/537.36",
        # 'Connection': "Keep-Alive",  #Connection:close  请求完自动断开
        # 'Keep-Alive': "timeout=20", # 30s后自动关闭
        'Connection': 'close',
        'Cookies': "currentCellId=center",
        'Postman-Token': "0b2ab32e-a921-4641-95bb-65775d50b95c,6ae56e9c-d9fc-4be7-87f4-a2701613d8e3",
        'Host': "rpc-admin.middleware.k2.test.xxxxx.info",
        'Accept-Encoding': "gzip, deflate",
        'Cookie': 'currentCellId=center',
        'cache-control': "no-cache"
    }
    html = requests.get(url, headers=headers)
    print(html)
    Soup = BeautifulSoup(html, 'lxml')  # file本身是一个HTTPResponse类型的对象,通过调用它的read属性返回网页内容
    content = Soup.select('#table_o a')  # 定位class
    res = ''
    try:
        print(content[0].text)
        address = (content[0].text)  #如果使用unicode直接split会有u''格式
        list = address.split(':')
        print(content[0].text, list[0], list[1])
        return {"list": list, "code": 0}

~如果有参考价值 记得给好评哦~

  • 1
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: Python Selenium可以使用以下步骤处理div弹窗: 1. 使用Selenium打开网页并定位到需要处理的元素。 2. 使用Selenium的`find_element_by_xpath`方法定位到弹窗元素。 3. 使用Selenium的`switch_to.frame`方法切换到弹窗的iframe中。 4. 在弹窗中执行需要的操作。 5. 使用Selenium的`switch_to.default_content`方法切换回主页面。 需要注意的是,如果弹窗是动态生成的,需要使用Selenium的`WebDriverWait`方法等待弹窗出现。另外,如果弹窗中有多个iframe,需要使用`switch_to.frame`方法切换到正确的iframe中。 ### 回答2: 在自动化测试中,我们经常需要处理弹窗,其中div弹窗也是很常见的一种。Python中的selenium库提供了可以处理各种弹窗的功能,下面就来介绍一下如何使用Python selenium来处理div弹窗。 1. 定位弹窗元素 首先要做的就是定位div弹窗中的元素,在selenium中有多种方式可以定位元素,其中id、name、class name、xpath和css selector是常用的方式。在定位元素时,我们需要使用selenium的find_element_by_xxx()方法,其中xxx是要使用的定位方式。 例如,下面的代码可以通过ID定位弹窗中的元素: ```Python popup = browser.find_element_by_id('popup') ``` 2. 关闭弹窗 定位到弹窗元素之后,我们就可以对弹窗进行操作了。在处理div弹窗时,一般会有“关闭”按钮或者“确定”按钮。我们可以通过点击这些按钮来关闭弹窗。 例如,下面的代码可以通过class name定位弹窗中的关闭按钮并点击: ```Python close_btn = browser.find_element_by_class_name('close-button') close_btn.click() ``` 3. 处理弹窗内容 有时候我们需要在弹窗中输入一些内容或者选择一些选项。可以通过selenium的send_keys()方法或者click()方法来模拟用户输入和点击。 例如,在一个弹窗中有一个“确认”按钮和一个文本框,我们要输入“hello world”并点击“确认”按钮,可以使用下面的代码: ```Python confirm_btn = browser.find_element_by_id('confirm-button') text_box = browser.find_element_by_id('input-box') text_box.send_keys('hello world') confirm_btn.click() ``` 总之,在Python中使用selenium处理div弹窗主要需要定位弹窗元素,关闭弹窗和处理弹窗内容。弹窗的具体操作取决于弹窗的具体情况,需要根据不同的需求进行相应的处理。 ### 回答3: Python Selenium 是一个功能强大的自动化测试工具,它可以模拟用户在浏览器中进行的各种行为,例如点击链接、填写表单、处理弹窗等。对于页面中的div弹窗Python Selenium 提供了多种解决方案,我们可以根据具体情况选择不同的方法来处理。 1. 使用 switch_to.alert() 方法处理弹窗 如果弹窗是 JavaScript 提示框或确认框,我们可以使用 switch_to.alert() 方法来获取弹窗对象,然后使用 accept() 或 dismiss() 方法处理它。例如: ``` from selenium import webdriver driver = webdriver.Firefox() driver.get("http://www.example.com") alert = driver.switch_to.alert() message = alert.text alert.accept() ``` 这段代码会打开一个网页,等待页面加载完毕后,获取页面中的 alert 对象,并将弹窗的文本内容存储在 message 变量中,最后点击确认按钮来关闭弹窗。 2. 使用 execute_script() 方法执行JavaScript代码 如果弹窗是一个 div 元素,我们可以使用 execute_script() 方法执行 JavaScript 代码来模拟用户行为。例如: ``` from selenium import webdriver driver = webdriver.Firefox() driver.get("http://www.example.com") div = driver.find_element_by_id("dialog") driver.execute_script("arguments[0].style.display = 'none';", div) ``` 这段代码会打开一个网页,等待页面加载完毕后,找到页面中 id 为 dialog 的 div 元素,并使用 execute_script() 方法执行一段 JavaScript 代码来将该元素隐藏。我们可以使用类似的方法来模拟其他用户行为,例如点击按钮、移动鼠标等。 3. 使用 expected_conditions.visibility_of_element_located() 方法等待弹窗出现 有时候,弹窗不会在页面加载完毕后立即出现,在这种情况下,我们可以使用 expected_conditions.visibility_of_element_located() 方法来等待弹窗出现。例如: ``` from selenium import webdriver from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC from selenium.webdriver.common.by import By driver = webdriver.Firefox() driver.get("http://www.example.com") wait = WebDriverWait(driver, 10) button = wait.until(EC.presence_of_element_located((By.ID, "button"))) button.click() div = wait.until(EC.visibility_of_element_located((By.ID, "dialog"))) message = div.text ``` 这段代码会打开一个网页,等待页面加载完毕后,使用 WebDriverWait 对象来等待 id 为 button 的按钮出现,并点击它。然后继续等待 id 为 dialog 的 div 元素出现,并将弹窗的文本内容存储在 message 变量中。我们可以使用类似的方法来等待其他元素的出现、消失或变化,并在相应的条件满足时执行相应的操作。 以上是 Python Selenium 处理 div 弹窗的三种方法,具体使用哪种方法取决于弹窗的类型、具体的场景以及开发者自己的喜好。无论使用哪种方法,都需要仔细地阅读文档和教程,并进行充分的测试和调试,以确保代码的正确性和稳定性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值