码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • JWT(令牌)


    目录

    一.什么JWT?

    1.JWT官网解释翻译

    2.通俗解释

    3.JWT能做什么?

    4.传统的session认证

     二.JWT结构

    三.JWT实战

    相关面试题


    一.什么JWT?

    官网地址:JSON Web Token Introduction - jwt.io

    1.JWT官网解释翻译

    jsonwebtoken(JWT)是一个开放标准,定义了一个紧凑,自包含方式,用于在各方之间以json对象安全的传输信息(是数字签名的,可以验证信任)。

    2.通俗解释

    JWT是在各方安全信息传递的好方法。可以对JWT进行签名,可以确保发件人是我们所认为的人,保证内容不被篡改。

    3.JWT能做什么?

    • 授权认证,当用户登录会得到JWT,后续请求都携带JWT,可以访问允许的资源。
    • 安全的信息传递,可以检验信息是否被篡改。

    4.传统的session认证

    流程

     暴露问题

    • 每个用户认证之后(登录验证用户名密码,权限),生成对应的session,用户增多,增加服务端的压力
    • 在一台服务器上认证,在其他其他服务器上是无法获取对应的session,在分布式应用上就限制了负载均衡器能力
    • cookie被截获容易遭受跨站请求伪造的攻击(其实token也有泄露的可能)。

    基于JWT认证流程

    针对JWT登录相关操作(token就是JWT,JWT 是Json Web Token简写)

    1. 认证成功,将用户id放在负载里,生成token返回前端,前端存储(一般有效期为14天)
    2. 退出登录,在前端删除token,然后将登录的个人信息刷新为空。
    3. 每次请求将JWT放在 http header里,解决XSS,XSRF

     二.JWT结构

    JWT令牌的组成

    Header.Payload.Signature(Base64进行编码,可解码)
    • Header,表头由令牌类型和所使用的签名算法{ "alg" : "HS256", "typ" : "jwt" }
    • Payload,有效负载,携带信息,不要放敏感信息如用户名密码
    • Signature,使用base64编码后的Header,Payload和自定义的密钥,以及签名算法(Header里声明了)生成签名,是不可逆的,通过签名判断(验签过程)信息是否被篡改。

    三.JWT实战

    作者正在加紧写。。。。

    相关面试题

    • 什么是 JWT?为什么要用 JWT?
    • JWT优势?
    1. 是一个字符串,体积小,传输速度快。
    2. 跨语言,支持任何形式的web
    3. 将用户信息放在负载里,不用请求查询数据库
    4. 特别适合分布式系统
    5. 保存在前端,不会对后端造成压力
    • JWT 由哪些部分组成?
    • 如何基于 JWT 进行身份验证?
    • JWT 如何防止 Token 被篡改?
    • 如何加强 JWT 的安全性?
    • 如何让 Token 失效?

  • 相关阅读:
    Spark On Hive原理和配置
    学习笔记7--车辆控制平台
    JVM 相关知识学习
    自定义windows右键菜单,软件卸载后 右键菜单残留 打开方式残留 解决方法
    Android XML文件结构 和 用XmlPullParser 来解析xml文件
    物联网平台在AIoT领域8大场景应用
    非父子组件通信-发布订阅模式
    一篇搞懂 Spring事务
    SpringCloud OpenFeign 服务调用传递 token
    华为机试真题 Java 实现【最多团队】
  • 原文地址:https://blog.csdn.net/dfghjkkjjj/article/details/125332321
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号