CAS单点登录 - 创建用户会话、全局门票、临时票据
生活随笔
收集整理的這篇文章主要介紹了
CAS单点登录 - 创建用户会话、全局门票、临时票据
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
CAS的統一登錄接口目的:1. 登錄后創建用戶的全局會話 ? ? ? ? ? ? ? ? -> ?uniqueToken2. 創建用戶全局門票,用以表示在CAS端是否登錄 ?-> ?userTicket3. 創建用戶的臨時票據,用于回跳回傳 ? ? ? ? ?-> ?tmpTicket
// 2. 實現用戶的redis會話
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門票,全局門票,代表用戶在CAS端登錄過
String userTicket = UUID.randomUUID().toString().trim();// 3.1 用戶全局門票需要放入CAS端的cookie中
setCookie(COOKIE_USER_TICKET, userTicket, response);// 4. userTicket關聯用戶id,并且放入到redis中,代表這個用戶有門票了,可以在各個景區游玩
redisOperator.set(REDIS_USER_TICKET + ":" + userTicket, userResult.getId());// 5. 生成臨時票據,回跳到調用端網站,是由CAS端所簽發的一個一次性的臨時ticket
String tmpTicket = createTmpTicket();/*** userTicket: 用于表示用戶在CAS端的一個登錄狀態:已經登錄* tmpTicket: 用于頒發給用戶進行一次性的驗證的票據,有時效性*//*** 舉例:* 我們去動物園玩耍,大門口買了一張統一的門票,這個就是CAS系統的全局門票和用戶全局會話。* 動物園里有一些小的景點,需要憑你的門票去領取一次性的票據,有了這張票據以后就能去一些小的景點游玩了。* 這樣的一個個的小景點其實就是我們這里所對應的一個個的站點。* 當我們使用完畢這張臨時票據以后,就需要銷毀。*/
/*** 創建臨時票據* @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";
?
總結
以上是生活随笔為你收集整理的CAS单点登录 - 创建用户会话、全局门票、临时票据的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: CAS单点登录 - 用户登录与校验
- 下一篇: Apollo快速使用