JWT 模拟登录

分析目标

打开开发者工具,登录目标网站JWT登录地址

Snipaste_2022-08-15_17-48-31

从图中可以看出请求API为https://login3.scrape.center/api/login,请求体为JSON格式的数据,而不是表单

Snipaste_2022-08-15_17-51-41

再看响应结果,可以看出响应也是Json格式的数据,包含token数据

Snipaste_2022-08-15_17-51-41

翻下一页,可以看出请求头中多个一个Authorization字段,值就是token数据

Snipaste_2022-08-15_18-57-44

确定思路

  1. 模拟登录请求,带上登录信息,获取返回的JWT
  2. 之后请求的时候加上Authorization字段,值就是JWT对应的内容

代码实现

import requests
from urllib.parse import urljoin

# url和登录信息
BASE_URL = 'https://login3.scrape.center/'
LOGIN_URL = urljoin(BASE_URL, '/api/login')
INDEX_URL = urljoin(BASE_URL, '/api/book')
USERNAME = 'admin'
PASSWORD = 'admin'

# 首页登录
response_login = requests.post(LOGIN_URL, data={
    'username': USERNAME,
    'password': PASSWORD
})
data = response_login.json()
print('Response Json', data)

# 获取token
jwt = data.get('token')
print('JWT', jwt)

# 设置headers,Authorization值为token的值
headers = {
    'Authorization': f'jwt {jwt}'
}

# 请求其他页面
response_index = requests.get(INDEX_URL, params={
    'limit': 18,
    'offset': 0

}, headers=headers)

# 结果
print("Response Status", response_index.status_code)
print("Response URL", response_index.url)
print("Response DATA", response_index.json())
posted @ 2022-08-15 19:21  吓吾一跳  阅读(110)  评论(0编辑  收藏  举报