1. Общие сведения
Являясь одной из крупнейших комплексных платформ электронной коммерции в Китае, JD.com имеет огромную базу пользователей и обширную информацию о продуктах. Для разработчиков и тестировщиков решающее значение имеет то, как эффективно выполнять сканирование данных и тестирование интерфейса на веб-сайте JD. При выполнении этих операций статус входа является незаменимой ссылкой. В этой статье будет показано, как использовать среду тестирования Pytest для поддержания статуса пользователя путем имитации входа пользователя и обхода проверки входа.
2. Как работают файлы cookie
Прежде чем рассказать, как использовать файлы cookie для обхода входа в систему, давайте сначала поймем, как работают файлы cookie. Файл cookie — это небольшой фрагмент данных, отправляемый сервером браузеру и сохраняемый на компьютере пользователя. Когда пользователь посещает веб-сайт, браузер отправляет файл cookie обратно на сервер, тем самым помогая серверу идентифицировать пользователя и поддерживать его вход в систему.
3. Этапы реализации автоматического тестирования интерфейса Pytest
3.1 Подготовка
Сначала нам нужно установить библиотеку Pytest и подготовить тестовый код и тестовые данные, необходимые для автоматизации тестирования интерфейса.
3.2 Получите файл cookie статуса входа в систему
Прежде чем проводить автоматическое тестирование интерфейса веб-сайта JD.com, вам сначала необходимо выполнить операцию входа в систему вручную и получить информацию о файлах cookie после успешного входа в систему с помощью инструментов разработчика браузера или других методов.
3.3 Добавьте файлы cookie в тестовый код
При написании кода для автоматизации тестирования интерфейса добавьте полученную информацию о файлах cookie в заголовок запроса, чтобы имитировать статус входа пользователя.
4. Шаги по реализации обхода файлов cookie
Далее мы подробно расскажем, как использовать Python и Pytest для обхода файлов cookie, и в качестве примера рассмотрим сканирование веб-сайта JD.
1. Получите файл cookie для входа.
Во-первых, нам нужно получить файл cookie для входа. Мы можем использовать Selenium для имитации входа на веб-сайт JD.com и получения информации о файлах cookie после входа в систему из браузера.
from selenium import webdriver
import random
# Случайно генерировать UA
user_agents = [
"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.110 Safari/537.36",
"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/94.0.4606.71 Safari/537.36",
"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36",
]
# Случайно выберите UA
user_agent = random.choice(user_agents)
# Установите параметры Chrome
options = webdriver.ChromeOptions()
# Настроить UA
options.add_argument(f'user-agent={user_agent}')
# Установить прокси
options.add_argument(f'--proxy-server=http://{proxyUser}:{proxyPass}@{proxyHost}:{proxyPort}')
# Запустить браузер
driver = webdriver.Chrome(options=options)
# Откройте страницу входа в JD
driver.get('https://passport.jd.com/new/login.aspx')
# Введите пароль от своей учетной записи и войдите в систему
driver.find_element_by_id('loginname').send_keys('your_username')
driver.find_element_by_id('nloginpwd').send_keys('your_password')
driver.find_element_by_id('loginsubmit').click()
# Получить куки после входа в систему
cookies = driver.get_cookies()
# Закрыть браузер
driver.quit()
# Преобразование файлов cookie в словарную форму
cookie_dict = {cookie['name']: cookie['value'] for cookie in cookies}
Далее мы будем использовать Pytest для написания тестовых примеров и использовать полученные файлы cookie для входа в процесс тестирования.
import pytest
import requests
@pytest.fixture(scope='session')
def login_cookie():
return cookie_dict
def test_crawl_jd_data(login_cookie):
url = 'https://www.jd.com/'
headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/97.0.4692.71 Safari/537.36'}
response = requests.get(url, headers=headers, cookies=login_cookie)
assert response.status_code == 200
assert «Цзиндун» in response.text
В приведенном выше коде мы определяем приспособление login_cookie для получения файла cookie для входа. Затем мы написали тестовый пример test_crawl_jd_data, в котором мы отправили запрос с файлом cookie для входа и подтвердили, что код состояния возврата равен 200, а ответ содержит ключевое слово «JD.com».
Наконец, мы можем использовать Pytest для запуска тестов.
$ pytest test_jd_crawler.py
При использовании файлов cookie для обхода входа в систему необходимо обратить внимание на следующие моменты: