from selenium import webdriver from selenium.webdriver.common.keys import Keys from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC def login_bp(url, username, password): # 创建一个浏览器实例 options = webdriver.EdgeOptions() options.add_experimental_option('detach', True) # 打开登录页面 browser = webdriver.Edge() browser.get(url) # 找到用户名输入框并输入密码 username_input = WebDriverWait(browser, 10).until(EC.visibility_of_element_located((By.ID, 'username'))) username_input.send_keys(username) # 找到密码输入框并输入密码 password_input = WebDriverWait(browser, 10).until(EC.visibility_of_element_located((By.ID, 'password'))) password_input.send_keys(password) # 模拟回车键,提交表单 login_btn = browser.find_element(by=By.ID, value='denglub') login_btn.send_keys(Keys.ENTER) return 0 if __name__ == '__main__': # 定义目标信息 atr_url = { 'url': 'http://pfs.ikhtech.com/FAPI/login.jsp', 'username': 'zhangwei', 'password': 'zhangwei' } login_bp(atr_url['url'], atr_url['username'], atr_url['password']) 之后我该如何获取页面返回的cookie、响应体、载荷等信息
时间: 2024-04-17 22:29:10 浏览: 196
您可以使用Selenium的`browser`对象来获取页面返回的cookie、响应体、载荷等信息。以下是一些常用的方法:
1. 获取cookie信息:
- 使用`browser.get_cookies()`方法可以获取当前页面的所有cookie。
- 使用`browser.get_cookie(name)`方法可以获取指定名称的cookie。
2. 获取响应体和载荷信息:
- 使用`browser.page_source`属性可以获取当前页面的HTML源代码。
- 使用`browser.current_url`属性可以获取当前页面的URL。
这些方法可以在登录成功后调用,例如在`login_bp`函数的最后添加以下代码:
```python
# 获取cookie信息
cookies = browser.get_cookies()
print("Cookies:", cookies)
# 获取响应体和载荷信息
page_source = browser.page_source
current_url = browser.current_url
print("Page Source:", page_source)
print("Current URL:", current_url)
```
请注意,获取这些信息的时机很重要。在登录成功后,您可以立即获取cookie信息。而获取响应体和载荷信息可能需要等待页面加载完成,可以使用合适的等待条件(例如`EC.visibility_of_element_located`)来确保页面加载完成后再进行获取。
阅读全文