SpringBoot 集成JJwt的使用

前言

JWT(Json Web Token)是實現(xiàn)token技術(shù)的一種解決方案兽间,用于前端和服務(wù)端進行身份認(rèn)證鳖眼,本文只是基于如何快速創(chuàng)建秘鑰和解析秘鑰再悼,至于后端使用過濾器校驗邏輯,可自行補充
1. pom.xml
<dependencies>
        <!-- web依賴 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--  lombok依賴 -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.8</version>
        </dependency>

        <!-- json工具 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.68</version>
        </dependency>
        <!-- jwt -->
        <dependency>
            <groupId>io.jsonwebtoken</groupId>
            <artifactId>jjwt</artifactId>
            <version>0.9.0</version>
        </dependency>
    </dependencies>
2. JwtUtils
package com.lss.jwt_test.util;

import java.util.Date;
import java.util.HashMap;
import java.util.Map;

import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;

import com.lss.jwt_test.rest.TestController;
import io.jsonwebtoken.Claims;
import io.jsonwebtoken.JwtBuilder;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import org.apache.tomcat.util.codec.binary.Base64;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class JwtUtils {
    /**
     * token 過期時間, 單位: 秒. 這個值表示 30 天
     */
    private static final long TOKEN_EXPIRED_TIME = 30 * 24 * 60 * 60;

    public static final String jwtId = "tokenId";

    /**
     * jwt 加密解密密鑰(可自行填寫)
     */
    private static final String JWT_SECRET = "1234567890";

    /**
     * 創(chuàng)建JWT
     */
    public static String createJWT(Map<String, Object> claims, Long time) {
        SignatureAlgorithm signatureAlgorithm = SignatureAlgorithm.HS256; //指定簽名的時候使用的簽名算法屡立,也就是header那部分褂痰,jjwt已經(jīng)將這部分內(nèi)容封裝好了亩进。
        Date now = new Date(System.currentTimeMillis());

        SecretKey secretKey = generalKey();
        long nowMillis = System.currentTimeMillis();//生成JWT的時間
        //下面就是在為payload添加各種標(biāo)準(zhǔn)聲明和私有聲明了
        JwtBuilder builder = Jwts.builder() //這里其實就是new一個JwtBuilder,設(shè)置jwt的body
                .setClaims(claims)          //如果有私有聲明缩歪,一定要先設(shè)置這個自己創(chuàng)建的私有的聲明归薛,這個是給builder的claim賦值,一旦寫在標(biāo)準(zhǔn)的聲明賦值之后,就是覆蓋了那些標(biāo)準(zhǔn)的聲明的
                .setId(jwtId)                  //設(shè)置jti(JWT ID):是JWT的唯一標(biāo)識主籍,根據(jù)業(yè)務(wù)需要习贫,這個可以設(shè)置為一個不重復(fù)的值,主要用來作為一次性token,從而回避重放攻擊崇猫。
                .setIssuedAt(now)           //iat: jwt的簽發(fā)時間
                .signWith(signatureAlgorithm, secretKey);//設(shè)置簽名使用的簽名算法和簽名使用的秘鑰
        if (time >= 0) {
            long expMillis = nowMillis + time;
            Date exp = new Date(expMillis);
            builder.setExpiration(exp);     //設(shè)置過期時間
        }
        return builder.compact();
    }


    /**
     * 驗證jwt
     */
    public static Claims verifyJwt(String token) {
        //簽名秘鑰沈条,和生成的簽名的秘鑰一模一樣
        SecretKey key = generalKey();
        Claims claims;
        try {
            claims = Jwts.parser()  //得到DefaultJwtParser
                    .setSigningKey(key)         //設(shè)置簽名的秘鑰
                    .parseClaimsJws(token).getBody();
        } catch (Exception e) {
            claims = null;
        }//設(shè)置需要解析的jwt
        return claims;

    }

    /**
     * 由字符串生成加密key
     *
     * @return
     */
    public static SecretKey generalKey() {
        String stringKey = JWT_SECRET;
        byte[] encodedKey = Base64.decodeBase64(stringKey);
        SecretKey key = new SecretKeySpec(encodedKey, 0, encodedKey.length, "AES");
        return key;
    }

    /**
     * 根據(jù)userId和openid生成token
     */
    public static String generateToken(String openId, Integer userId) {
        Map<String, Object> map = new HashMap<>();
        map.put("userId", userId);
        map.put("openId", openId);
        map.put("sub", openId);
        return createJWT(map, TOKEN_EXPIRED_TIME);
    }

    public static void main(String[] args) {
        // 生成token
        String s = generateToken("111", 20);
        System.out.println(s);

        // 驗證
        String token = "eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiIxMTEiLCJvcGVuSWQiOiIxMTEiLCJleHAiOjE1OTI1NTc3ODMsInVzZXJJZCI6MjAsImlhdCI6MTU5MjU1NTE5MSwianRpIjoidG9rZW5JZCJ9.X7JHnx3Y5wtb-n3pT9tft2I4hENJdeRxW2QWaI4jv2E";
        Claims claims = verifyJwt(token);
        String subject = claims.getSubject();
        String userId = (String)claims.get("userId");
        String openId = (String)claims.get("openId");
        String sub = (String)claims.get("sub");
        System.out.println("subject:" + subject);
        System.out.println("userId:" + userId);
        System.out.println("openId:" + openId);
        System.out.println("sub:" + sub);
    }
}
3. 驗證

使用時可再main方法中驗證

希望對你有所幫助!
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末需忿,一起剝皮案震驚了整個濱河市诅炉,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌屋厘,老刑警劉巖涕烧,帶你破解...
    沈念sama閱讀 222,000評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異汗洒,居然都是意外死亡议纯,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評論 3 399
  • 文/潘曉璐 我一進店門溢谤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來瞻凤,“玉大人,你說我怎么就攤上這事世杀》Р危” “怎么了?”我有些...
    開封第一講書人閱讀 168,561評論 0 360
  • 文/不壞的土叔 我叫張陵瞻坝,是天一觀的道長蛛壳。 經(jīng)常有香客問我,道長所刀,這世上最難降的妖魔是什么衙荐? 我笑而不...
    開封第一講書人閱讀 59,782評論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮浮创,結(jié)果婚禮上忧吟,老公的妹妹穿的比我還像新娘。我一直安慰自己斩披,他們只是感情好瀑罗,可當(dāng)我...
    茶點故事閱讀 68,798評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著雏掠,像睡著了一般斩祭。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上乡话,一...
    開封第一講書人閱讀 52,394評論 1 310
  • 那天摧玫,我揣著相機與錄音,去河邊找鬼。 笑死诬像,一個胖子當(dāng)著我的面吹牛屋群,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播坏挠,決...
    沈念sama閱讀 40,952評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼芍躏,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了降狠?” 一聲冷哼從身側(cè)響起对竣,我...
    開封第一講書人閱讀 39,852評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎榜配,沒想到半個月后否纬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,409評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡蛋褥,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,483評論 3 341
  • 正文 我和宋清朗相戀三年临燃,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片烙心。...
    茶點故事閱讀 40,615評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡膜廊,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出淫茵,到底是詐尸還是另有隱情爪瓜,我是刑警寧澤,帶...
    沈念sama閱讀 36,303評論 5 350
  • 正文 年R本政府宣布痘昌,位于F島的核電站钥勋,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏辆苔。R本人自食惡果不足惜算灸,卻給世界環(huán)境...
    茶點故事閱讀 41,979評論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望驻啤。 院中可真熱鬧菲驴,春花似錦、人聲如沸骑冗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽贼涩。三九已至巧涧,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間遥倦,已是汗流浹背谤绳。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人缩筛。 一個月前我還...
    沈念sama閱讀 49,041評論 3 377
  • 正文 我出身青樓消略,卻偏偏與公主長得像,于是被迫代替她去往敵國和親瞎抛。 傳聞我的和親對象是個殘疾皇子艺演,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,630評論 2 359