Автор: Сад Латиао
В основном он делится учебными ресурсами по тестированию, которые помогут вам быстро понять индустрию тестирования, а также помогает новичкам, которые хотят сменить карьеру, продвинуться по карьерной лестнице и стать старшими инженерами по тестированию.
Существует множество способов отправки HTTP-запросов, а также множество часто используемых инструментов, таких как почтальон, Jmeter, Loadrunner и т. д., но если вы хотите объединить их с автоматизированным кодом, вам необходима библиотека запросов Python. использование Python для отправки HTTP-запросов, файлов cookie и сеансов. Соответствующий контент.
Запросы на представление библиотеки:
Библиотека HTTP, основанная на urllib, написанная на языке Python и использующая лицензированный протокол Apache2 с открытым исходным кодом, по сравнению с библиотекой urllib библиотека Requests более удобна.
(Иностранный) Первый способ установки:
pip install requests
(Внутренний) Способ установки второй:
pip install requests -i https://pypi.douban.com/simple/
Синтаксис запросов:
resp = Requests.get(url='URL-адрес',headers={K:V},data={K:V},json={K:V},cookies=данные cookie[например: токен])
# в:
# get() соответствует методу HTTP-запроса, который нужно отправить, который можно изменить для публикации, размещения и удаления в зависимости от реальной ситуации.
# URL: соответствует URL в строке HTTP-запроса.
# заголовки: заголовки запросов, соответствующие http-запросам. Формат пары ключ-значение {ключ:значение}
# данные: для типа формы Тело запроса. Формат данных такой же, как указано выше, который также представляет собой пару ключ-значение {ключ:значение}.
# json: для типа json Тело запроса. Формат данных такой же, как указано выше, который также представляет собой пару ключ-значение {ключ:значение}.
# Файлы cookie: пользовательская информация для хранилища.
# resp: представляет пакет ответа (строка ответа, заголовок ответа, тело ответа), возвращаемый после успешной отправки HTTP-запроса.
# пример:
import requests
# Пакет гида
resp = requests.post(url='https://www.baidu.com',
# Введите URL-адрес
headers={"Content-Type": "application/x-www-form-urlencoded"},
# Заполните заголовок запроса
data={"username": "liuguoxing", "passwd": "123456"})
# Если нет других требований к информации, ее не нужно передавать. Параметры являются необязательными.
print(resp.text)
# Распечатать ответ в текстовом формате
print(resp.json())
# Распечатать ответ в формате json
Захват и доставка файлов cookie:
import requests
# Пакет гида
resp = requests.get(url='http://xxxx')
# URL-адрес запроса для получения содержимого ответа
my_cookie = resp.cookies
# захватывать файлы cookie
resp_2 = requests.post(url='xxx', headers='xxx', data='xxx', cookies=my_cookie)
# Передача файлов cookie между запросами
print(resp_2.text)
# Распечатайте содержимое второго интерфейса
# Менее часто используемые методы сбора данных↓
'''
resp.url Получить URL
resp.status_code Получить код статуса
resp.encoding Получить формат кодировки
resp.headers Получить заголовки ответов
resp.text Получить данные тела ответа в текстовом формате
resp.content Получить данные тела ответа в формате байт-кода
resp.json() Получить данные тела ответа в формате JSON.
'''
Введение, связанное с файлами cookie:
Файлы cookie не являются встроенными в протокол http. Это технология, изобретенная инженерами, чтобы компенсировать тот факт, что http является протоколом без сохранения состояния.
Файлы cookie в основном существуют на стороне браузера (клиента) и в основном используются для хранения небольшого количества информации, не чувствительной к пользователю.
Размер файла cookie по умолчанию составляет 4 КБ (может быть расширен), а объем хранимых данных невелик.
Данные в файлах cookie можно легко получить. Поэтому он обычно не используется для хранения важных конфиденциальных данных.
Метод аутентификации Cookie+Session:
На приведенном выше рисунке запрос доступа Baidu используется в качестве примера для описания процесса передачи идентификатора сеанса. Часть, в которой идентификатор сеанса шифруется с помощью алгоритма хеширования, опущена.
Введение, связанное с сессией:
Сессия есть «сессия»
Сеанс возникает при общении в компьютерной сети. С момента установления соединения браузера с сервером до момента отключения от сервера весь процесс называется «сеансом». Например: вводите имя пользователя и пароль для входа, и генерируется сессия — пользователь выходит из системы, выходит, браузер закрывается, и сессия завершается.
Характеристики сессии:
Сеанс не является частью протокола http и не является частью браузера.
Данные сеанса хранятся на стороне сервера
Типы данных, которые можно сохранить в сеансе, относительно широки, а емкость велика. (Зависит от сервера)
Вы можете использовать сеанс для управления файлами cookie.
Управляйте файлами cookie через сеанс:
Пример сценария: сначала запросите интерфейс получения кода проверки, а затем передайте содержимое, возвращенное интерфейсом кода проверки, в интерфейс входа в систему.
1. Создайте экземпляр сеанса (объект класса).
2. Используйте экземпляр сеанса для вызова запроса интерфейса кода проверки (GET).
3. Используйте тот же экземпляр сеанса для вызова запроса интерфейса входа в систему (POST).
4. После отправки запроса сессию необходимо закрыть.
1.my_session = requests.Session()
2.resp_verify = my_session.get(url='xxx')
3.resp_login = my_session.post(url='xxx',data='xxxx',headers='xxxx')
4.my_session.close()
# Управление файлами cookie через сеанс устраняет необходимость передачи файлов cookie и реализует автоматическую передачу параметров.
Выше описан метод использования запросов для отправки HTTP-запросов и использования сеанса для завершения автоматической передачи файлов cookie. Если у вас есть какие-либо вопросы, оставьте сообщение в области комментариев для обсуждения ~.