日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

如何使用會話Cookie和Java實現JWT身份驗證

瀏覽:212日期:2022-08-15 14:21:52

HTTP是無狀態協議,用于傳輸數據。它啟用了客戶端和服務器端>之間的通信。它最初是為了在Web瀏覽器和Web服務器之間建立連接而建立的。比如在網上購物,我們添加一些商品,例如。耳機到我們的購物車,然后,我們繼續尋找其他項目,在此期間,我們希望在執行任何其他任務是存儲購物車項目的狀態且不丟失它們。這意味著我們希望在整個購物過程中記住我們的狀態。由于HTTP是無狀態協議,因此要克服問題,我們可以使用會話或者令牌

1、基于會話的身份驗證

在JSON Web令牌出現之前,我們主要使用這種身份驗證。在這種身份驗證中,服務器負責身份驗證,客戶端不知道發送請求后服務器端會發生什么。

那么什么是會話Cookie?

由于客戶端未指定Expires(過期時間)或Max-Age(最大上限)指令,因此在客戶端關閉時將其刪除。但是,Web瀏覽器可能會使用會話還原,這會使大多數會話Cookie永久保持狀態,就像從未關閉過瀏覽器一樣。

如何使用會話Cookie和Java實現JWT身份驗證

用戶在網絡瀏覽器上登錄網站發生什么。例如,用戶登錄后,服務器 將為該用戶創建一個會話并將該會話數據存儲在服務器內存中。當用戶在網站上執行某些活動時,會創建一個會話ID,該會話ID存儲在客戶端瀏覽器的cookie中。在用戶提出的每個請求中,cookie都將隨之發送。然后,當用戶最初登錄時,服務器可以使用存儲在服務器內存中的會話數據來驗證Cookie上的會話數據。當用戶從網站注銷時,該會話數據將從數據庫和服務器內存中刪除。

2、基于令牌的身份驗證

在基于令牌的身份驗證中,我們使用JWT(JSON Web Tokens)進行身份驗證。這是RESTful API的廣泛使用方法。

如何使用會話Cookie和Java實現JWT身份驗證

當用戶發送帶有登錄詳細信息的用戶身份驗證請求時,服務器將以JSON WEB TOKENS(JWT)的形式創建一個加密的令牌,并將其發送回客戶端。當客戶端收到令牌時,這意味著該用戶以通過身份驗證,可以使用客戶端執行任何活動。

JWT通常存儲在客戶端的localstorage中,當用戶從服務器請求任何數據或對該網站執行任何活動時,JWT將作為該用戶的唯一密鑰發送。因此,當服務器接收到該請求時,它將針對每個請求驗證JWT僅是該特定用戶,然后將所需的響應發送回客戶端。

localStorage.setItem('key', 'value');

用戶狀態存儲在客戶端JWT中。當用戶注銷時,令牌將從客戶端(localStorage)中刪除。因此,大多數數據存儲在客戶端,并且可以直接訪問,而不是向服務器發送請求。

JSON WEB TOKENS由(.)連接的三個部分組成:1.標頭2.有效載荷3.簽名

JWT結構:xxxxx.yyyyy.zzzzz

輸出包含三個由點分割的Base64-URL字符串,可以在HTML和HTTP環境中輕松傳遞這些字符串,與基于XML的標準(例如SAML)相比,它更緊湊。

JWT已對先前的標頭和有效負載進行了編碼,并用一個密鑰進行簽名,如下

如何使用會話Cookie和Java實現JWT身份驗證

哪個更好用?

在現代Web應用程序中,JWT被廣泛使用,因為它的伸縮性優于基于會話的cookie,因為令牌存儲在客戶端,而會話使用服務器內存來存儲用戶數據,這可能是一個大問題。大量用戶一次訪問應用程序。由于JWT是隨著每個請求一起發送的,而且包含所有用戶信息,因此即使對JWT進行了編碼,也有必要在JWT中使用必要的信息,并且應避免使用敏感信息或者將其加密以防止安全攻擊。

沒有固定的方法可以始終使用,它取決于開發人員和要求的類型,以找出在哪種情況下需要使用哪種方法。

3、jwt實現登錄

//定義JWT的有效時長七天 private static final long EXPIRE_TIME = 60 * 1000 * 60 * 24 * 7; //簽發人 private static String ISSUER = 'K_ang'; /*秘鑰*/ private static final String SING = K*&^A%$#N@!G;

/** * 生成令牌 * * @param map * @return */ public static String getToken(Map<String, String> map) { //設置過期時間 Date date = null; try { date = new Date(System.currentTimeMillis() + EXPIRE_TIME); //創建token JWTCreator.Builder builder = JWT.create() .withIssuer(ISSUER) .withExpiresAt(date); //添加信息 map.forEach((k, v) -> { builder.withClaim(k, v); }); return builder.sign(Algorithm.HMAC256(SING)); } catch (Exception e) { e.printStackTrace(); return null; } } /** * 驗證token * * @param token */ public static boolean verify(String token, String userNo) { try { //設置加密算法 JWTVerifier verifier = JWT.require(Algorithm.HMAC256(SING)).withClaim('userNo', userNo).build(); //校驗token DecodedJWT jwt = verifier.verify(token); return true; } catch (Exception e) { return false; } } /** * 獲取token信息方法 * * @param * @return */ public static String getTokenInfo(String token) { DecodedJWT decode = JWT.decode(token); return decode.getClaim('userNo').asString(); }}

@PostMapping('/login') public Result login(@PathParam('empNo') String empNo, @PathParam('empPassword') String empPassword) { if (empNo == null || ''.equals(empNo)) { return ResultUtil.error(103, '請輸入用戶名,用戶名不能為空'); } if (empPassword == null || ''.equals(empPassword)) { return ResultUtil.error(103, '請輸入密碼,密碼不能為空'); } Emp emp = empService.login(empNo, empPassword); if (emp == null) { return ResultUtil.error(103, '用戶不存在,獲取token失敗'); } if (emp.getEmpPassword() == null || !emp.getEmpPassword().equals(empPassword)) { return ResultUtil.error(103, '密碼錯誤,獲取token失敗'); } //正常token String token = JwtUtils.sign(empNo, empPassword); emp.setToken(token); return ResultUtil.success(200, '登錄成功', emp); }

以上就是如何使用會話Cookie和Java實現JWT身份驗證的詳細內容,更多關于使用會話Cookie和Java實現JWT身份驗證的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品日本欧美一区二区三区| 日韩久久99| 日韩和欧美一区二区三区| 欧美日韩国产探花| www.九色在线| 国产中文在线播放| 欧美日韩水蜜桃| 99精品视频在线| 久久激情综合网| 国产精品永久| 亚洲精品亚洲人成在线观看| japanese国产精品| 免费黄网站欧美| 国产极品久久久久久久久波多结野| 综合激情在线| 欧美午夜不卡影院在线观看完整版免费| 久久中文字幕av| 视频在线观看91| 国产精品红桃| 久久久天天操| 中文字幕一区二区三区日韩精品| 国产精品久久久久久模特| 亲子伦视频一区二区三区| 亚洲欧美激情诱惑| 欧美精品第一区| 亚洲深夜影院| 另类综合日韩欧美亚洲| 黄色欧美日韩| 日本va欧美va精品发布| 亚洲欧洲美洲av| 亚洲少妇自拍| 日韩欧美看国产| 日韩有码av| 国产午夜精品一区二区三区欧美| 伊人久久大香伊蕉在人线观看热v| 欧美一级二区| 好看的av在线不卡观看| 精品色999| 亚洲欧美一级| 欧美日韩激情| 国产成人精品福利| 久久国内精品自在自线400部| 2023国产精品久久久精品双 | 精品日韩一区| 日韩激情中文字幕| 99在线观看免费视频精品观看| 久久精品国产福利| 青草av.久久免费一区| 色欧美自拍视频| 国产精品网站在线看| 日韩精品久久久久久久软件91| 欧美特黄一区| 久久久久蜜桃| 亚洲国内精品| 一区在线观看| 在线免费观看亚洲| 亚洲欧洲美洲国产香蕉| 日本成人在线不卡视频| 日韩一区二区三区高清在线观看| 亚洲色图综合| 久久国产精品免费精品3p| 69堂免费精品视频在线播放| 国产亚洲一区| 精品亚洲二区| 久久亚洲在线| 久久av综合| 麻豆国产欧美日韩综合精品二区| 国产精品伊人| 国产精品激情电影| 精品一区二区三区中文字幕视频| 久久国产人妖系列| 欧美aa在线视频| 日本一二区不卡| 电影天堂国产精品| 国产综合精品| 亚洲一区二区三区在线免费| 蜜臀精品一区二区三区在线观看| 久久国产尿小便嘘嘘| 国产精品伊人| 久久亚洲人体| 在线成人动漫av| 亚洲在线久久| 国产精品午夜av| 日本精品不卡| 亚洲一区av| 久久精品国产久精国产| 天堂日韩电影| 亚洲乱亚洲高清| 国产一区丝袜| 9国产精品视频| 国产亚洲精品精品国产亚洲综合| 精品视频网站| 免费观看不卡av| 亚洲人成网77777色在线播放| 综合欧美精品| 你懂的亚洲视频| 99在线精品免费视频九九视| 日韩精品中文字幕吗一区二区| 国产中文欧美日韩在线| 午夜电影亚洲| 精品国产乱码久久久久久1区2匹| 黄色精品网站| 精品三级久久| 国产精品视频一区二区三区综合| 欧美日韩一区二区综合| 青青草视频一区| 婷婷亚洲综合| 国产伦久视频在线观看| 日韩精品一二三| 国产午夜久久av| 91精品电影| 久久精品二区亚洲w码| 美女黄网久久| 欧美gv在线| 精品高清久久| 欧美久久久网站| 一区二区电影在线观看| 久草免费在线视频| 国产日产精品_国产精品毛片| 亚洲手机视频| 欧美韩日一区| 国产精品久久| 欧美亚洲色图校园春色| 夜夜嗨网站十八久久| 麻豆久久久久久| 国产日产精品_国产精品毛片| 综合国产精品| 亚洲黄色在线| 婷婷色综合网| 亚洲国产影院| 91久久国产| 极品裸体白嫩激情啪啪国产精品| 久久精品欧洲| 国产一区二区三区亚洲综合| 久久激情av| 国产视频一区二| 国产精品99精品一区二区三区∴| 日本在线不卡视频| 亚洲欧美日韩高清在线| 精品日产乱码久久久久久仙踪林| 精品国产不卡一区二区| av高清不卡| 伊人久久大香线蕉av不卡| 成人午夜精品| 国产精品日本| 国产欧美一区二区色老头| 久久wwww| 久久精品av| 亚洲精品大片| 美女精品视频在线| 久久天堂精品| 亚洲综合中文| 久久久久久久久成人| 日本韩国欧美超级黄在线观看| 波多视频一区| 日本久久一区| 久久久777| 国产精品jk白丝蜜臀av小说| 精品日韩视频| 日本免费一区二区视频| 日本а中文在线天堂| 综合欧美精品| 色综合www| 亚洲精品中文字幕99999| 久久久男人天堂| 青草国产精品| 久久久久久久久久久妇女 | 在线观看亚洲精品福利片| 国产午夜一区| 蜜桃tv一区二区三区| 精品一区二区三区视频在线播放 | 日韩精品亚洲aⅴ在线影院| 精品久久在线| 日本欧美在线| 亚洲综合不卡| 欧美成人国产| 里番精品3d一二三区| 国产精品试看| 久久九九精品| 日韩伦理福利| 欧美黄色一区二区| 日韩激情精品| 三级欧美在线一区| 图片区亚洲欧美小说区| 日韩亚洲一区在线| 精品国产乱码久久久久久樱花| 亚洲欧洲专区| 亚洲欧美视频| 国产精品日本| 欧洲精品一区二区三区| 亚洲影视一区二区三区| 99久久久国产精品美女| 国产欧美一区二区三区国产幕精品| 久久91导航| 欧美freesex黑人又粗又大| 成人日韩av| 久久国内精品视频| 国产欧美一区| 嫩草伊人久久精品少妇av杨幂| 国产日韩欧美在线播放不卡|