色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

基于springboot+jwt實現刷新token過程解析

瀏覽:2日期:2023-05-26 14:46:50

前一段時間講過了springboot+jwt的整合,但是因為一些原因(個人比較懶)并沒有更新關于token的刷新問題,今天跟別人閑聊,聊到了關于業務中token的刷新方式,所以在這里我把我知道的一些點記錄一下,也希望能幫到一些有需要的朋友,同時也希望給我一些建議,話不多說,上代碼!

1:這種方式為在線刷新,比方說設定的token有效期為30min,那么每次訪問資源時,都會在攔截器中去判斷一下token是否過期,如果沒有過期就刷新token的時間為30min,反之則會重新登錄,需要注意的是這種方式我是在登錄以后就將token存在了redis

//登錄方法中將token存在redis String token = JwtUtil.sign(userName,user.getId()); redisUtil.set(UserConstants.PREFIX_USER_TOKEN + token, token,UserConstants.TOKEN_EXPIRE_TIME); Map map=new HashMap(); map.put('token', token); return Result.success(map); //在攔截器中獲取token,并判斷token的有效期 String token = req.getHeader(UserConstants.ACCESS_TOKEN); if (Strings.isNullOrEmpty(token)) { return false; } Object reqToken=redisUtil.get(UserConstants.PREFIX_USER_TOKEN+token); if (ObjectUtils.isEmpty(reqToken)) { return false; } if(redisUtil.getExpire(UserConstants.PREFIX_USER_TOKEN+token) <1){ return false; } redisUtil.set(UserConstants.PREFIX_USER_TOKEN + token, token,UserConstants.TOKEN_EXPIRE_TIME); return true;

2.這種方式為免密登錄,也就是說,登錄一次后就不用再通過賬號密碼登錄,思路就是在生成token時候,在生成一個refToken來刷新,比如說我的token設置的有效期為5分鐘,refToken設置的為一周,那么在請求時候則判斷token是否過期,如果已經過期 就判斷refToken的時間有沒有過期,沒有過期則生成一個新的token給前端,同時重置這個refToken(看你自己),如果refToken已經過期則重新登錄,需要注意的是這次生成的token并不存在redis中,而是將refToken存在redis。

// 生成token String token = JwtUtil.sign(userName,user.getId()); //刷新token,免密登陸 String refToken=UUID.randomUUID().toString().replaceAll('-',''); redisUtil.set(UserConstants.PREFIX_USER_TOKEN + token, refToken,UserConstants.TOKEN_EXPIRE_TIME); Map map=new HashMap(); map.put('token', token); map.put('refToken', refToken); return Result.success(map); //這里在攔截其中校驗token,如果校驗失敗,則判斷redis的refToken是否過期 if (!JwtUtil.verify(token)) { if(redisUtil.getExpire(UserConstants.PREFIX_USER_TOKEN+token)>=1){HttpServletResponse httpServletResponse = (HttpServletResponse) response;String newRefToken=UUID.randomUUID().toString().replaceAll('-','');Integer userId=Integer.parseInt(JwtUtil.getUserId(token));User user=userService.selectOne(userId);String newToken=JwtUtil.sign(user.getUserName(),user.getId());httpServletResponse.setHeader('newToken',newToken);httpServletResponse.setHeader('newRefToken',newRefToken);return true; }else{return false; } }

3.貼一下我在postMan中的測試結果:

這里是登錄后返回的token和refToken:

基于springboot+jwt實現刷新token過程解析

這里是登陸成功之后的顯示:

基于springboot+jwt實現刷新token過程解析

這里是token過期后,refToken刷新的token:

基于springboot+jwt實現刷新token過程解析

這里是設定的refToken過期后在訪問的顯示:

基于springboot+jwt實現刷新token過程解析

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
主站蜘蛛池模板: 亚洲午夜一区二区三区 | 国产免费影院 | 性生活视频网 | 另类视频综合 | 男人把女人桶到喷白浆的视频 | 夜色精品国产一区二区 | 国产不卡一区二区三区免费视 | 91精品国产高清91久久久久久 | 日韩成人免费一级毛片 | 台湾三级香港三级在线理论 | 国产高清精品在线 | 新版天堂资源中文在线 | 国产做爰一区二区 | 国产一区欧美 | 国产三级香港在线观看 | 一个人的视频日本免费 | 一及 片日本 | 成人免费一区二区三区视频软件 | 2021一本久道 | 国产大片中文字幕在线观看 | 九九热爱视频精品视频高清 | 岛国搬运工最新网地址 | 欧美日韩精品国产一区在线 | 国产a级三级三级三级 | 国产a级三级三级三级 | 免费高清国产 | 91免费视频版 | 亚洲精品国产第一区二区三区 | 91热播 | 国产高清在线观看 | 国产成人精品免费视频大全软件 | a亚洲| 日韩精品在线看 | 国产高清精品一区 | 国产高清在线精品一区二区三区 | 国产欧美日韩精品一区二 | 在线观看国产亚洲 | 欧美顶级毛片在线播放小说 | 日本在线观看免费视频网址 | 成人免费在线观看视频 | 欧美日本免费观看αv片 |