WEB - token

Posted Rocinante

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了WEB - token相关的知识,希望对你有一定的参考价值。

token概念参考

  1. https://ninghao.net/blog/2834
  2. https://stackoverflow.com/questions/1592534/what-is-token-based-authentication
  3. http://www.woshipm.com/pd/877760.html

session和token的区别

  1. https://security.stackexchange.com/questions/81756/session-authentication-vs-token-authentication
  2. https://www.zhihu.com/question/51759560

2. 用户注册后验证的激活链接也用到token。例如flask-mail实现这个功能。

详细看flasky中如何实现session和token

3. token可以防止csrf攻击,可以防止表单重复提交。

用Python模拟登录网站时需要获取authenticity_token。
原因: https://www.jianshu.com/p/d73e971da41c
注意: 模拟登录并不是进行CSRF攻击,只是模拟浏览器的行为

import requests
from bs4 import BeautifulSoup

# cookies中存了sessionID和其他信息,来验证身份和提供信息给服务器
# 存取cookies,因为登录页面和登录后的页面的cookies不同,所以如果登录成功后还是用登录前的cookies的话,操作会失败,返回到登录页面。
cookie_dict = {}

# 1. 获取authenticity_token,或者又叫csrf_token,防止表单重复提交,防止csrf攻击。其实就是token的功能。
# 发送http请求,获取登录页面
response1 = requests.get(‘https://github.com/login‘)
# 实例化文档解析器bs
s1 = BeautifulSoup(response1.text,‘html.parser‘)
# 通过bs找到对应的标签对象,再找到token的值
token = s1.find(name=‘input‘,attrs={‘name‘:‘authenticity_token‘}).get(‘value‘)
# 获取第一次请求(登录页面)的cookies,以字典的形式。因为requests的接口是要求传入的cookies是字典形式的。
cookie_dict.update(response1.cookies.get_dict())

# 2. 将用户名,密码和token,登录页面的cookies发送到服务端,post请求进行登录操作。
"""
utf8:?
authenticity_token:ollV+avLm6Fh3ZevegPO7gOH7xUzEBL0NWdA1aOQ1IO3YQspjOHbfnaXJOtVLQ95BtW9GZlaCIYd5M6v7FGUKg==
login:asdf
password:asdf
commit:Sign in
"""
response2 = requests.post(
    ‘https://github.com/session‘,
    data={
        "utf8": ‘?‘,
        "authenticity_token": token,
        ‘login‘: ‘[email protected]‘,
        ‘password‘: ‘xxx‘,
        ‘commit‘: ‘Sign in‘
    },
    cookies=cookie_dict
)
# print(response2.text)

# 3. 登录成功后,利用登录后的cookies。进行访问/settings/emails这个页面的操作
cookie_dict.update(response2.cookies.get_dict())
#
response3 = requests.get(
    url=‘https://github.com/settings/emails‘,
    cookies=cookie_dict
)
print(response3.text)

# 4. 操作成功后,将返回的页面写入文件中。(可以本地live server浏览)
with open(‘./test1111111.html‘,‘wb‘) as f:
        f.write(response3.content)

4. 总结

token可保护重要的操作、服务,类似于session,是一种身份验证方法。不用每次都使用username和password去进行身份验证获得服务、操作权限。



以上是关于WEB - token的主要内容,如果未能解决你的问题,请参考以下文章

Express实战 - 应用案例- realworld-API - 路由设计 - mongoose - 数据验证 - 密码加密 - 登录接口 - 身份认证 - token - 增删改查API(代码片段

Laravel:如何在控制器的几种方法中重用代码片段

JAVA WEB代码片段

web代码片段

在片段中设置文本颜色

代码片段 - Golang 实现简单的 Web 服务器