SpringBoot整合shiro+jwt+redis - 無(wú)狀態(tài)token登錄(二)授權(quán)篇

更多最新技術(shù)文章歡迎大家訪問(wèn)我的個(gè)人博客○( ^皿^)っ豆腐別館

上文總覽篇中,相信大家已經(jīng)對(duì)接下來(lái)要做的事情有了總體思路及印象稍坯〕贶瘢總言之我們要做的就只有兩件事搓劫,一是授權(quán),二即是鑒權(quán)混巧。
  讓我們先從授權(quán)開(kāi)始枪向,何為授權(quán)?在這里簡(jiǎn)單地來(lái)講就是要頒發(fā)token咧党。何時(shí)頒發(fā)秘蛔?毫無(wú)疑問(wèn),無(wú)非就是在登錄/注冊(cè)成功之后傍衡。至于上文中提到的根據(jù)RefreshToken自動(dòng)刷新AccessToken深员,我將之歸置為token刷新,代碼實(shí)現(xiàn)于后續(xù)篇章說(shuō)明蛙埂。

一倦畅、Maven配置

<!-- jwt -->
<dependency>
    <groupId>com.auth0</groupId>
    <artifactId>java-jwt</artifactId>
    <version>${java-jwt.version}</version>
</dependency>

二、Application配置

server:
  port: 8001

spring:
  application:
    name: springboot-shiro-jwt-sso
  # profiles: springboot-shiro-jwt-sso

  ## Redis配置 - start
  redis:
    # Redis數(shù)據(jù)庫(kù)索引(默認(rèn)為0)
    database: 1
    # Redis服務(wù)器地址
    host: 127.0.0.1
    # Redis服務(wù)器連接端口
    port: 6379
    # Redis服務(wù)器連接密碼(默認(rèn)為空)
    # password: "doufuplus"
    # 連接超時(shí)時(shí)間(毫秒)
    timeout: 5000
    jedis:
      pool:
        # 連接池最大連接數(shù)(使用負(fù)值表示沒(méi)有限制)
        max-active: 8
        # 連接池最大阻塞等待時(shí)間(使用負(fù)值表示沒(méi)有限制)
        max-wait: -1
        # 連接池中的最大空閑連接
        max-idle: 8
        # 連接池中的最小空閑連接
        min-idle: 0
  ## Redis配置 - end


  ## 時(shí)間格式配置 - start
  jackson:
    serialization:
      write-dates-as-timestamps: true
  ## 時(shí)間格式配置 - end


## product配置 - start
info:
  app.name: springboot-shiro-jwt-sso
  company.name: doufuplus
  build.artifactId: $project.artifactId$
  build.modelVersion: $project.modelVersion$
## product配置 - end


## 日志配置 - start
logging:
  level:
    com.nfgj.medical.service: DEBUG
## 日志配置 - end


## 其它配置 - start
config:
  # JWT認(rèn)證加密私鑰(Base64加密)
  encrypt-jwtKey: U0JBUElOENhspJrzkyNjQ1NA
  # AccessToken過(guò)期時(shí)間(秒)
  accessToken-expireTime: 600
  # RefreshToken過(guò)期時(shí)間(秒)
  refreshToken-expireTime: 604800
## 其它配置 - end

三绣的、頒發(fā)Token

token的頒發(fā)并未有什么難度叠赐,主要是生成AccessToken放置于Header給前端。再生成RefreshToken保存于服務(wù)端即可屡江。此處使用redis保存芭概。

/**
 * 登錄
 * 轉(zhuǎn)載請(qǐng)注明出處,更多技術(shù)文章歡迎大家訪問(wèn)我的個(gè)人博客站點(diǎn):https://www.doufuplus.com
 *
 * @author 丶doufu
 * @date 2019/08/03
 */
@PostMapping("/login")
public Result login(String account, String password, HttpServletResponse response) {

    try {
        if (!("doufuplus".equals(account) && "123456".equals(password))) {
            return new Result(ResultCode.PASSWORD_ERROR, "account or password error.");
        }

        // 清除可能存在的shiro權(quán)限信息緩存
        if (redis.hasKey(RedisConstant.PREFIX_SHIRO_CACHE + account)) {
            redis.del(RedisConstant.PREFIX_SHIRO_CACHE + account);
        }

        // 設(shè)置RefreshToken盼理,時(shí)間戳為當(dāng)前時(shí)間戳谈山,直接設(shè)置即可(不用先刪后設(shè),會(huì)覆蓋已有的RefreshToken)
        String currentTimeMillis = String.valueOf(System.currentTimeMillis());
        redis.set(RedisConstant.PREFIX_SHIRO_REFRESH_TOKEN + account, currentTimeMillis,
                Integer.parseInt(refreshTokenExpireTime));

        // 從Header中Authorization返回AccessToken宏怔,時(shí)間戳為當(dāng)前時(shí)間戳
        String token = JwtUtil.sign(account, currentTimeMillis);
        response.setHeader("Authorization", token);
        response.setHeader("Access-Control-Expose-Headers", "Authorization");

        return new Result().OK();
    } catch (Exception e) {
        e.printStackTrace();
        return new Result(ResultCode.ERROR, e.getMessage());
    }
}

四奏路、清除Token

沒(méi)有買(mǎi)賣(mài)就沒(méi)有傷害,有登錄就會(huì)有退出臊诊。token的清除主要是做兩件事:

  1. 清除可能存在的shiro權(quán)限信息
  2. 清除RefreshToken
/**
 * 退出
 * 轉(zhuǎn)載請(qǐng)注明出處鸽粉,更多技術(shù)文章歡迎大家訪問(wèn)我的個(gè)人博客站點(diǎn):https://www.doufuplus.com
 *
 * @author 丶doufu
 * @date 2019/08/03
 */
@RequestMapping("/logout")
public Result logout() {
    try {
        String token = "";
        // 獲取頭部信息
        Enumeration<String> headerNames = request.getHeaderNames();
        while (headerNames.hasMoreElements()) {
            String key = (String) headerNames.nextElement();
            String value = request.getHeader(key);
            if ("Authorization".equalsIgnoreCase(key)) {
                token = value;
            }
        }
        // 校驗(yàn)token
        if (StringUtils.isBlank(token)) {
            return new Result(ResultCode.PARAM_ERROR);
        }
        String account = JwtUtil.getClaim(token, JwtConstant.ACCOUNT);
        if (StringUtils.isBlank(account)) {
            return new Result(ResultCode.NOT_LOGIN, "token失效或不正確.");
        }
        // 清除shiro權(quán)限信息緩存
        if (redis.hasKey(RedisConstant.PREFIX_SHIRO_CACHE + account)) {
            redis.del(RedisConstant.PREFIX_SHIRO_CACHE + account);
        }
        // 清除RefreshToken
        redis.del(RedisConstant.PREFIX_SHIRO_REFRESH_TOKEN + account);

        return new Result().OK();
    } catch (Exception e) {
        e.printStackTrace();
        return new Result(ResultCode.ERROR, e.getMessage());
    }
}

五、演示說(shuō)明

  1. 登錄成功抓艳,返回10200
    登錄成功-1.png
  2. 查看Header触机,Authorization返回AccessToken信息
    登錄成功-2.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市玷或,隨后出現(xiàn)的幾起案子儡首,更是在濱河造成了極大的恐慌,老刑警劉巖偏友,帶你破解...
    沈念sama閱讀 216,544評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蔬胯,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡位他,警方通過(guò)查閱死者的電腦和手機(jī)氛濒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)产场,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人舞竿,你說(shuō)我怎么就攤上這事京景。” “怎么了骗奖?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,764評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵确徙,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我重归,道長(zhǎng)米愿,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,193評(píng)論 1 292
  • 正文 為了忘掉前任鼻吮,我火速辦了婚禮育苟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘椎木。我一直安慰自己违柏,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布香椎。 她就那樣靜靜地躺著漱竖,像睡著了一般。 火紅的嫁衣襯著肌膚如雪畜伐。 梳的紋絲不亂的頭發(fā)上馍惹,一...
    開(kāi)封第一講書(shū)人閱讀 51,182評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音玛界,去河邊找鬼万矾。 笑死,一個(gè)胖子當(dāng)著我的面吹牛慎框,可吹牛的內(nèi)容都是我干的良狈。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼笨枯,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼薪丁!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起馅精,我...
    開(kāi)封第一講書(shū)人閱讀 38,917評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤严嗜,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后洲敢,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體阻问,經(jīng)...
    沈念sama閱讀 45,329評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評(píng)論 2 332
  • 正文 我和宋清朗相戀三年沦疾,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了称近。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,722評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡哮塞,死狀恐怖刨秆,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情忆畅,我是刑警寧澤衡未,帶...
    沈念sama閱讀 35,425評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站家凯,受9級(jí)特大地震影響缓醋,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜绊诲,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評(píng)論 3 326
  • 文/蒙蒙 一送粱、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧掂之,春花似錦抗俄、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,671評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至跟压,卻和暖如春胰蝠,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背震蒋。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,825評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工茸塞, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人喷好。 一個(gè)月前我還...
    沈念sama閱讀 47,729評(píng)論 2 368
  • 正文 我出身青樓翔横,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親梗搅。 傳聞我的和親對(duì)象是個(gè)殘疾皇子禾唁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容