詳解基于JWT的springboot權(quán)限驗(yàn)證技術(shù)實(shí)現(xiàn)
JWT簡(jiǎn)介
Json Web Token(JWT):JSON網(wǎng)絡(luò)令牌,是為了在網(wǎng)絡(luò)應(yīng)用環(huán)境間傳遞聲明而制定的一種基于JSON的開(kāi)放標(biāo)準(zhǔn)((RFC 7519)。JWT是一個(gè)輕便的安全跨平臺(tái)傳輸格式,定義了一個(gè)緊湊的自包含的方式用于通信雙方之間以 JSON 對(duì)象行使安全的傳遞信息。因?yàn)閿?shù)字簽名的存在,這些信息是可信的。
實(shí)現(xiàn)步驟:
環(huán)境spring boot
1、添加jwt依賴(lài)
<dependency> <groupId>com.auth0</groupId> <artifactId>java-jwt</artifactId> <version>3.8.1</version> </dependency> <dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt</artifactId> <version>0.9.1</version> </dependency>
2、在src下創(chuàng)建annotation包
新建自定義注解類(lèi) JwtToken
package com.qf.tyleryue_one.annotation;import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target;/** * 自定義注解:方法前 表示方法需要攔截 */@Target({ElementType.METHOD,ElementType.TYPE})@Retention(RetentionPolicy.RUNTIME)public @interface JwtToken {}
3、在src下創(chuàng)建utils包
新建自定義JwtUtils工具類(lèi)
package com.qf.tyleryue_one.utils;import com.auth0.jwt.JWT;import com.auth0.jwt.JWTCreator;import com.auth0.jwt.JWTVerifier;import com.auth0.jwt.algorithms.Algorithm;import jdk.internal.org.objectweb.asm.TypeReference;import java.util.Date;/** * 用來(lái)生成簽名,校驗(yàn)簽名,通過(guò)簽名 */public class JwtUtils { //令牌有效時(shí)間 private final static long EXPIRE_TIME=5*60*1000; //密鑰 private final static String SECRECT='Tyler_Yue_key'; /** * 創(chuàng)建令牌 */ public static String sign(String userId){ //構(gòu)建失效時(shí)鐘 Date exipre_date = new Date(System.currentTimeMillis() + EXPIRE_TIME); //創(chuàng)建令牌 JWTCreator.Builder builder = JWT.create(); //給jwt令牌playload中放入發(fā)令牌放的用戶(hù) //給userid用戶(hù)發(fā)令牌 builder.withAudience(userId); //設(shè)置令牌失效時(shí)間 builder.withExpiresAt(exipre_date); //對(duì)令牌密鑰進(jìn)行加密 Algorithm algorithm = Algorithm.HMAC256(SECRECT); String sign = builder.sign(algorithm); return sign;//返回令牌 } /** * 驗(yàn)證令牌 */ public static boolean verifyToken(String token){ try { //生成校驗(yàn)器 Algorithm algorithm = Algorithm.HMAC256(SECRECT); //校驗(yàn) JWTVerifier build = JWT.require(algorithm).build(); //無(wú)異常則校驗(yàn)成功 return true; } catch (Exception e) { throw new RuntimeException('令牌過(guò)期'); } }}
4、在src下新建vo包
封裝一個(gè)返回用戶(hù)帶令牌的 對(duì)象
package com.qf.tyleryue_one.vo;import com.alibaba.druid.filter.AutoLoad;import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor;/** * 封裝一個(gè)返回 含令牌的用戶(hù)對(duì)象 */@Data@AllArgsConstructor@NoArgsConstructorpublic class TokenVo { //用戶(hù)名 private String usernaem; //令牌名 private String token;}
5、舉例controller層用戶(hù)登錄業(yè)務(wù)登錄帶令牌
package com.qf.tyleryue_one.controller;import com.qf.tyleryue_one.entity.VueUser;import com.qf.tyleryue_one.service.VueUserService;import com.qf.tyleryue_one.utils.JwtUtils;import com.qf.tyleryue_one.vo.Msg;import com.qf.tyleryue_one.vo.TokenVo;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.*;import java.util.UUID;/** * 登錄業(yè)務(wù) */@Controllerpublic class VueUserController { @Autowired private VueUserService vueUserService; @RequestMapping(value = '/dealLogin',method = RequestMethod.POST) @CrossOrigin @ResponseBody public Msg login(@RequestBody VueUser vueUser){ VueUser vueUser1 = vueUserService.selectByUsername(vueUser.getUsername()); if (vueUser1!=null){ if (vueUser1.getPassword().equals(vueUser.getPassword())){//密碼匹配,發(fā)放令牌///隨機(jī)生成字符串未useridString userid = UUID.randomUUID().toString();String token = JwtUtils.sign(userid);//封裝令牌對(duì)象TokenVo tokenVo = new TokenVo(vueUser.getUsername(), token);return new Msg(200,'登錄成功,令牌已發(fā)放',tokenVo); }else {return new Msg(403,'密碼錯(cuò)誤',null); } }else { return new Msg(403,'用戶(hù)不存在',null); } }}
到此這篇關(guān)于詳解基于JWT的springboot權(quán)限驗(yàn)證技術(shù)實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)springboot JWT權(quán)限驗(yàn)證內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 小技巧處理div內(nèi)容溢出2. ASP刪除img標(biāo)簽的style屬性只保留src的正則函數(shù)3. 怎樣才能用js生成xmldom對(duì)象,并且在firefox中也實(shí)現(xiàn)xml數(shù)據(jù)島?4. 解析原生JS getComputedStyle5. .NET SkiaSharp 生成二維碼驗(yàn)證碼及指定區(qū)域截取方法實(shí)現(xiàn)6. PHP字符串前后字符或空格刪除方法介紹7. jsp實(shí)現(xiàn)登錄界面8. XML入門(mén)的常見(jiàn)問(wèn)題(二)9. 得到XML文檔大小的方法10. PHP循環(huán)與分支知識(shí)點(diǎn)梳理
