cas添加url單點漫游認證

url單點漫游認證

url單點漫游認證模式說明

應用場景

  • url單點漫游采用url加密參數(shù)驗證握手方式洛口,需要接入系統(tǒng)實現(xiàn)url單點漫游參數(shù)的接收稚照、驗證蹂空,以及驗證通過后的握手登錄。
  • 特點:原理及實現(xiàn)較為簡單果录、支持各種開發(fā)語言web系統(tǒng)(可提供JAVA上枕、.NET、ASP弱恒、PHP等示例說明)辨萍、支持用戶對照
  • 接入條件:接入系統(tǒng)需要實現(xiàn)url單點漫游驗證登錄。
  • 應用場景:接入系統(tǒng)愿意作一定的開發(fā)調(diào)試工作返弹。

接入方式

  • 用戶在平臺登錄后锈玉,點擊業(yè)務系統(tǒng)單點登錄的鏈接后進入該系統(tǒng),該系統(tǒng)讀取平臺單點漫游url參數(shù)义起,并使用密鑰解密后還原出來用戶帳號拉背,時間戳,判斷用戶信息并扇。
  • 平臺端與業(yè)務系統(tǒng)端共同約定五個參數(shù):
userName //業(yè)務系統(tǒng)用戶帳號  
strSysDatetime//時間戳  
verify//校驗碼  
url//訪問業(yè)務系統(tǒng)的某個地址
pt_key//為雙方約定的密鑰去团,通常采用字符串方式
  • 由平臺端直接訪問業(yè)務系統(tǒng)時,需要在url中加入四個參數(shù)值傳遞給業(yè)務系統(tǒng)穷蛹。其中verify由userName土陪、strSysDatetime、pt_key(pt_key為雙方約定的密鑰肴熏,通常采用字符串方式)組成并采用md5方式加密形成的最終的一個串值鬼雀。
  • 業(yè)務系統(tǒng)獲取各個參數(shù)后,首先比較業(yè)務系統(tǒng)服務器時間同傳遞過來的strSysDatetime是否在允許的時間差范圍內(nèi)(注意雙方服務器時間需保持標準時間)蛙吏,若在時間差范圍內(nèi)源哩,則需將userName、strSysDatetime鸦做、pt_key 進行加密后同verify進行比較励烦,若一致,則可以正常登錄泼诱。

補充說明

  • 流程及判斷規(guī)則:由主平臺服務器向業(yè)務系統(tǒng)傳遞參數(shù)坛掠;
  • 公共密鑰:雙方共同約定,可以是一個字符串。
  • 加密解密方式:采用MD5的加密算法屉栓,校驗判斷同時加入時間戳判斷舷蒲,時間戳通常計算為從1970年1月1日午夜起至現(xiàn)在的時間差,用秒表示友多。

代碼部分牲平,可參考cas4.2.7添加新頁面

controller代碼(部分)

  • 注意!由于登錄后session銷毀域滥,故不能使用session保存信息纵柿,本例采用從登錄日志獲取用戶名的方法
@Controller
public class UrlSSOController extends AbstractUrlViewController {

    private final DataSource dataSource;
    private final JdbcTemplate jdbcTemplate;

    @Autowired
    public UrlSSOController(@Qualifier("dataSource")
                                    final DataSource dataSource) {
        this.dataSource = dataSource;
        jdbcTemplate = new JdbcTemplate(dataSource);

    }

    @Override
    protected String getViewNameForRequest(HttpServletRequest request) {

        String appid = request.getParameter("appid");
        String url = request.getParameter("url");

        //獲取用戶名,因為session會被銷毀,無法存儲信息启绰,故根據(jù)ip從登錄日志中查找
        String ip = getRemoteAddr(request);
        CsUserLogin csUserLogin = getUserLogin(ip);
        String userName = csUserLogin.getLoginName();

        //獲取ptKey
        List<CsWebappNode> webappNodeList = getWebapp(appid);
        String ptKey = webappNodeList.get(0).getAppSecret();
        //獲取系統(tǒng)時間
        String strSysDatetime = DateUtils.getDateTime();
        //獲取MD5藐窄,明文為appID+userName+ptKey+sysDatetime
        String md5Info = userName+ptKey+strSysDatetime;
        MD5Util md5Util = MD5Util.getInstance();
        String md5 = md5Util.calcMD5(md5Info);

        String returnUrl ="";


        try {
            String params = "userName="+userName+"&strSysDatetime="+URLEncoder.encode(strSysDatetime, "utf-8")+"&verify="+md5;
            if (url.contains("?")){
                returnUrl = url+params;
            }else{
                returnUrl = url+"?"+params;
            }
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        }
        return "redirect:"+returnUrl;
    }

}

配置WEB-INF/spring-configuration/applicationContext.xml,新增bean并配置

web.xml配置

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末酬土,一起剝皮案震驚了整個濱河市荆忍,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌撤缴,老刑警劉巖刹枉,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異屈呕,居然都是意外死亡微宝,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進店門虎眨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蟋软,“玉大人,你說我怎么就攤上這事嗽桩≡朗兀” “怎么了?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵碌冶,是天一觀的道長湿痢。 經(jīng)常有香客問我,道長扑庞,這世上最難降的妖魔是什么譬重? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任譬猫,我火速辦了婚禮原探,結(jié)果婚禮上壮不,老公的妹妹穿的比我還像新娘乘碑。我一直安慰自己,他們只是感情好渣聚,可當我...
    茶點故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布匀归。 她就那樣靜靜地躺著择懂,像睡著了一般。 火紅的嫁衣襯著肌膚如雪邑遏。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天恰矩,我揣著相機與錄音记盒,去河邊找鬼。 笑死外傅,一個胖子當著我的面吹牛纪吮,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播萎胰,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼碾盟,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了技竟?” 一聲冷哼從身側(cè)響起冰肴,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎榔组,沒想到半個月后熙尉,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡搓扯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年检痰,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片锨推。...
    茶點故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡铅歼,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出换可,到底是詐尸還是另有隱情椎椰,我是刑警寧澤,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布沾鳄,位于F島的核電站俭识,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏洞渔。R本人自食惡果不足惜套媚,卻給世界環(huán)境...
    茶點故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望磁椒。 院中可真熱鬧堤瘤,春花似錦、人聲如沸浆熔。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至慎皱,卻和暖如春老虫,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背茫多。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工祈匙, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人天揖。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓夺欲,卻偏偏與公主長得像,于是被迫代替她去往敵國和親今膊。 傳聞我的和親對象是個殘疾皇子些阅,可洞房花燭夜當晚...
    茶點故事閱讀 43,465評論 2 348

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)斑唬,斷路器市埋,智...
    卡卡羅2017閱讀 134,628評論 18 139
  • 國家電網(wǎng)公司企業(yè)標準(Q/GDW)- 面向?qū)ο蟮挠秒娦畔?shù)據(jù)交換協(xié)議 - 報批稿:20170802 前言: 排版 ...
    庭說閱讀 10,916評論 6 13
  • 需求場景: 老板讓我檢測我公司的網(wǎng)站是否符合PCICompliance,完全不知道PCICompliance是什么...
    OSSIMCN閱讀 810評論 0 1
  • 看著當初學校那漂亮和開得自信的櫻花恕刘, 讓我不禁回想 何時腰素,這心眼也小了,脾氣越來越暴躁雪营。 已然沒了遠方的吶喊弓千,獨自...
    jfdream閱讀 207評論 0 0
  • 這是封面上的一句話谴餐,字不大姻政,卻讓人一字一頓地讀下去...... 始于偶然,陷于思考岂嗓,忠于感悟汁展。一個偶然的機會翻開這...
    雪糕糕糕閱讀 171評論 0 2