jwt相關(guān)介紹及使用

JWT:JSON Web Token是目前最流行的跨域認(rèn)證解決方案,用戶身份的認(rèn)證以前我們都是怎么做的呢骑晶,一般步驟都是這樣的:用戶將用戶名及密碼傳輸?shù)椒?wù)器,服務(wù)器認(rèn)證通過后將用戶相關(guān)信息保存到session中,然后返回session_id將其寫到用戶的cookie中盒件,用戶后面所有請求都會(huì)通過cookie將session_id傳輸?shù)胶笈_(tái),后臺(tái)通過session_id可以對用戶進(jìn)行身份認(rèn)證舱禽。這種方案在單機(jī)情況下沒有問題炒刁,但是在集群環(huán)境下就必須要求session數(shù)據(jù)共享,這個(gè)問題我們在spt的開發(fā)開始就遇到過誊稚,我們處理方案是通過將session存儲(chǔ)到redis中翔始,然后改變tomcat服務(wù)器的session讀取邏輯贡耽,該方案對于Tomcat的版本有要求刀森,同時(shí)需要對每一臺(tái)tomcat進(jìn)行處理繁涂,由于session持久化到redis中所以也存在session丟失的可能揪利。而jwt是將用戶信息完全以加密的形式返回給客戶端镊叁,客戶端每次發(fā)送請求時(shí)都將該信息發(fā)送到服務(wù)器進(jìn)行身份驗(yàn)證俺祠,也就是服務(wù)器端不再保存session信息潘懊,即服務(wù)的無狀態(tài)线婚。

原理

JWT 的原理是狼电,服務(wù)器認(rèn)證以后蜒灰,生成一個(gè) JSON 對象弦蹂,發(fā)回給用戶,格式如下:{ "username": "cys", "權(quán)限": "/api/user", "expire": "2018-10-28 00:00:00" } 强窖,用戶與服務(wù)端通信的時(shí)候凸椿,都要發(fā)回這個(gè) JSON 對象。服務(wù)器完全只靠這個(gè)對象認(rèn)定用戶身份翅溺。為了防止用戶篡改數(shù)據(jù)脑漫,服務(wù)器在生成這個(gè)對象的時(shí)候,會(huì)加上簽名咙崎。 服務(wù)器就不保存任何 session 數(shù)據(jù)了窿撬,也就是說,服務(wù)器變成無狀態(tài)了叙凡,從而比較容易實(shí)現(xiàn)擴(kuò)展劈伴。

使用方式

客戶端收到服務(wù)器返回的 JWT,可以儲(chǔ)存在 cookie 里面握爷,也可以儲(chǔ)存在 localStorage跛璧。 此后,客戶端每次與服務(wù)器通信新啼,都要帶上這個(gè) JWT追城。你可以把它放在 Cookie 里面自動(dòng)發(fā)送,但是這樣不能跨域燥撞,所以更好的做法是放在 HTTP 請求的頭信息Authorization字段里面座柱。 Authorization: Bearer 另一種做法是,跨域的時(shí)候物舒,JWT 就放在 POST 請求的數(shù)據(jù)體里面色洞。

后臺(tái)集成

目前后臺(tái)用的spring boot,所以主要就是介紹spring boot如何集成jwt

1冠胯、pom文件中添加maven依賴如下:


2火诸、security中不對登錄及其他請求進(jìn)行攔截,配置如下:


3荠察、登錄時(shí)操作如下:


4置蜀、接口調(diào)用時(shí)操作如下:


主要操作有,獲取到用戶的token悉盆,通過服務(wù)器的私鑰判斷該token是否合法盯荤,然后獲取用戶的權(quán)限判斷當(dāng)前請求是否合法。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末焕盟,一起剝皮案震驚了整個(gè)濱河市秋秤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖航缀,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異堰怨,居然都是意外死亡芥玉,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進(jìn)店門备图,熙熙樓的掌柜王于貴愁眉苦臉地迎上來灿巧,“玉大人,你說我怎么就攤上這事揽涮】倥海” “怎么了?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵蒋困,是天一觀的道長盾似。 經(jīng)常有香客問我,道長雪标,這世上最難降的妖魔是什么零院? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮村刨,結(jié)果婚禮上告抄,老公的妹妹穿的比我還像新娘。我一直安慰自己嵌牺,他們只是感情好打洼,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著逆粹,像睡著了一般募疮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上僻弹,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天酝锅,我揣著相機(jī)與錄音,去河邊找鬼奢方。 笑死搔扁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蟋字。 我是一名探鬼主播稿蹲,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼鹊奖!你這毒婦竟也來了苛聘?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎设哗,沒想到半個(gè)月后唱捣,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡网梢,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年震缭,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片战虏。...
    茶點(diǎn)故事閱讀 38,599評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡拣宰,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出烦感,到底是詐尸還是另有隱情巡社,我是刑警寧澤,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布手趣,位于F島的核電站晌该,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏绿渣。R本人自食惡果不足惜气笙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望怯晕。 院中可真熱鬧潜圃,春花似錦、人聲如沸舟茶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽吧凉。三九已至隧出,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間阀捅,已是汗流浹背胀瞪。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留饲鄙,地道東北人凄诞。 一個(gè)月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像忍级,于是被迫代替她去往敵國和親帆谍。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評論 2 348