当前位置:首页 > 技术文章 > 正文内容

JWT的正确使用方法,API开发为什么使用JWT

zonemu1周前 (07-25)技术文章8

API开发越来越成为主流,需要各自Access Token做登录状态。

甚至目前web端mvvm应用,如angular、vue、react都使用了jwt方式,也就是不再使用cookie和session作为登录状态。有很多作为这种无状态http的身份登录状态方法,原理也差不多,无非就是获得客户端的标识,把服务器的信息和客户端的交互信息在传输时附带上。

较为流行的传输身份验证码方法就是jwt,jwt只是一种约定,可选择不同的数据加密签名。

本质上只是一种“签名”而不是加密。

jwt生成的token如下:

eyJhbGciOiJIUzI1NiJ9.eyJ1aWQiOjEsImFpZCI6MSwidXNlcm5hbWUiOiJhZG1pbiIsIm1vYmlsZSI6IjEzNTI5NTEzMTA0IiwiaXAiOiIwOjA6MDowOjA6MDowOjEiLCJleHAiOjE1ODU4NDc5MTJ9.edv0BBpe_S6GDmtSp6Q7stsRrxBDesWr9MOjqcGdyR8

事实上就是把token分成三段,使用点号 " ." 分割字符串。前两段的内容就是header和payload。后面的是使用选择的加密算法生成的签名。

JWT.io 上面有各种不同语言的实现,不同的语言不同的库能解析和生成,以及附加的参数不同。但基本原理就是使用base64进行数据编码,再进行签名。而不是传输数据是直接加密的,当然你也可以选择加密的算法,但是越复杂服务器解析越慢。


因为jwt只是编码,不是一种加密,所以jwt token作为身份令牌,需要注意不要把危险的参数如密码放在token里,如果你执意要这么做,那么就需要把token放在服务器数据库或者缓存,再生产一个签名使用加密签名进行api与服务器的通信,但这实在是多此一举。

jwt本就是连接授权认证,如果每次连接还做持久化查询,那么无疑增加了性能消耗。

而传输一个身份ID其实就可以了,所以,jwt尽量简短简单即可。

选择实现库或者自己实现都可以,但是最好选择github star数量多的,这是大多数人验证过的。

传输jwt一般使用header,也可以使用get参数传值。这看服务器端与客户端的http请求库如何方便实现。

比如某些前端上传工具,就不能自定义header,那就只能使用url get参数传。服务器也要做好适当的接口规划。

相关文章

【Vue3 基础】05.组件化(组件使用vuex)

这是 Vue3 + Vite + Pinia +TS + Element-Plus 实战系列文档。最近比较忙没什么时间写文章,争取早日把这个系列完结吧~生命周期和模板引用在本章之前,我们通过响应式 a...

崩溃!3 道 React 面试必卡题,吃透稳过金九银十

凌晨三点还在对着 “React 组件为什么重复渲染” 抓耳挠腮?别慌!今天挑出 3 道让 90% 候选人卡壳的高频题,全是大厂面试官挖的 “坑”,手把手教你见招拆招,看完直接装进面试 “弹药库”!先问...

程序员开发必会之git常用命令,git配置、拉取、提交、分支管理

整理日常开发过程中经常使用的git命令!git配置SSH刚进入项目开发中,我们首先需要配置git的config、配置SSH方式拉取代码,以后就免输入账号密码了!# 按顺序执行 git config -...

jenkins2.107+tomcat8+jdk1.8的安装和发布代码3种方式

jenkins2.107+tomcat8+jdk1.8的安装和发布代码3种方式如果对运维课程感兴趣,可以在b站上或csdn上搜索我的账号: 运维实战课程,可以关注我,学习更多免费的运维实战技术视频1....

基于Docker构建安装Git/GitLab,以及制作springboot工程镜像

今天给大家分享的是《领先的开源自动化服务器Jenkins的应用实战》之基于Docker安装构建Git/GitLab版本控制与代码云存储的场所;使用Git管理项目,springboot工程制作镜像知识体...

VIM配置整理(vim配置教程)

一、基本配色set number set showcmd set incsearch set expandtab set showcmd set history=400 set autoread se...