ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

JWT 模拟登录

2022-08-15 19:31:09  阅读:170  来源: 互联网

标签:登录 URL JWT token print response 模拟


分析目标

打开开发者工具,登录目标网站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())

标签:登录,URL,JWT,token,print,response,模拟
来源: https://www.cnblogs.com/istart/p/16589395.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有