CAS单点登录 - 创建用户会话、全局门票、临时票据
生活随笔
收集整理的這篇文章主要介紹了
CAS单点登录 - 创建用户会话、全局门票、临时票据
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
CAS的統(tǒng)一登錄接口目的:1. 登錄后創(chuàng)建用戶的全局會(huì)話 ? ? ? ? ? ? ? ? -> ?uniqueToken2. 創(chuàng)建用戶全局門(mén)票,用以表示在CAS端是否登錄 ?-> ?userTicket3. 創(chuàng)建用戶的臨時(shí)票據(jù),用于回跳回傳 ? ? ? ? ?-> ?tmpTicket
// 2. 實(shí)現(xiàn)用戶的redis會(huì)話
String uniqueToken = UUID.randomUUID().toString().trim();
UsersVO usersVO = new UsersVO();
BeanUtils.copyProperties(userResult, usersVO);
usersVO.setUserUniqueToken(uniqueToken);
redisOperator.set(REDIS_USER_TOKEN + ":" + userResult.getId(),JsonUtils.objectToJson(usersVO));// 3. 生成ticket門(mén)票,全局門(mén)票,代表用戶在CAS端登錄過(guò)
String userTicket = UUID.randomUUID().toString().trim();// 3.1 用戶全局門(mén)票需要放入CAS端的cookie中
setCookie(COOKIE_USER_TICKET, userTicket, response);// 4. userTicket關(guān)聯(lián)用戶id,并且放入到redis中,代表這個(gè)用戶有門(mén)票了,可以在各個(gè)景區(qū)游玩
redisOperator.set(REDIS_USER_TICKET + ":" + userTicket, userResult.getId());// 5. 生成臨時(shí)票據(jù),回跳到調(diào)用端網(wǎng)站,是由CAS端所簽發(fā)的一個(gè)一次性的臨時(shí)ticket
String tmpTicket = createTmpTicket();/*** userTicket: 用于表示用戶在CAS端的一個(gè)登錄狀態(tài):已經(jīng)登錄* tmpTicket: 用于頒發(fā)給用戶進(jìn)行一次性的驗(yàn)證的票據(jù),有時(shí)效性*//*** 舉例:* 我們?nèi)?dòng)物園玩耍,大門(mén)口買(mǎi)了一張統(tǒng)一的門(mén)票,這個(gè)就是CAS系統(tǒng)的全局門(mén)票和用戶全局會(huì)話。* 動(dòng)物園里有一些小的景點(diǎn),需要憑你的門(mén)票去領(lǐng)取一次性的票據(jù),有了這張票據(jù)以后就能去一些小的景點(diǎn)游玩了。* 這樣的一個(gè)個(gè)的小景點(diǎn)其實(shí)就是我們這里所對(duì)應(yīng)的一個(gè)個(gè)的站點(diǎn)。* 當(dāng)我們使用完畢這張臨時(shí)票據(jù)以后,就需要銷(xiāo)毀。*/
/*** 創(chuàng)建臨時(shí)票據(jù)* @return*/
private String createTmpTicket() {String tmpTicket = UUID.randomUUID().toString().trim();try {redisOperator.set(REDIS_TMP_TICKET + ":" + tmpTicket,MD5Utils.getMD5Str(tmpTicket), 600);} catch (Exception e) {e.printStackTrace();}return tmpTicket;
}
private void setCookie(String key,String val,HttpServletResponse response) {Cookie cookie = new Cookie(key, val);cookie.setDomain("sso.com");cookie.setPath("/");response.addCookie(cookie);
}
public static final String REDIS_USER_TOKEN = "redis_user_token";
public static final String REDIS_USER_TICKET = "redis_user_ticket";
public static final String REDIS_TMP_TICKET = "redis_tmp_ticket";public static final String COOKIE_USER_TICKET = "cookie_user_ticket";
?
總結(jié)
以上是生活随笔為你收集整理的CAS单点登录 - 创建用户会话、全局门票、临时票据的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: CAS单点登录 - 用户登录与校验
- 下一篇: Apollo快速使用