配置 Yale CAS Server 來實現單點登陸(SSO)

來源:互聯網
上載者:User

本配置文檔參考Argan 的 blog ...用Yale CAS Server 來實現單點登陸(SSO)
Argan 的 blog ...地址: http://blog.matrix.org.cn/page/cas

配置JAVA_HOME如下:
JAVA_HOME = D:/Java/jdk1.5.0_06

CAS (Central Authentication Service)是Yale大學的ITS開發的一套JAVA實現的開源
的SSO(single sign-on)的服務。

這裡用一個簡單的例子來說明用CAS來實現單點登陸(SSO)。

Yale CAS Server 的配置過程

CAS (Central Authentication Service)是Yale大學的ITS開發的一套JAVA實現的開源
的SSO(single sign-on)的服務。該服務是以一個java web app(eg:cas.war)來進行服務的,
使用時需要將cas.war發布到一個servlet2.3相容的伺服器上,並且伺服器需要支援SSL,
在需要使用該服務的其他伺服器(客戶),只要進行簡單的配置就可以實現SSO了。

CAS 的用戶端可以有很多種,因為驗證的結果是以XML的格式返回的,CAS的用戶端已
打包進去的有java,perl,python,asp,apache module等好幾種用戶端樣本,你還可以根據
需要實現一個自己的用戶端,非常簡單!~

下面我們以tomcat 5.0 作為CAS Server(server1),另外一台tomcat5.0 為client(client1)
為例進行說明。

1.下載cas-server和cas-client(可選,建議使用)
http://www.ja-sig.org/downloads/cas/cas-server-3.0.zip
http://www.yale.edu/tp/cas/cas-client-2.0.11.zip

2.將cas-server-3.0.zip解壓,並將lib/cas.war拷貝到server1的webapps下

3.產生SERVER的認證
keytool -genkey -alias my-alias-name -keyalg RSA -keystore keystore.keystore

4.在server1配置tomcat使用HTTPS
$CATALINA_HOME/conf/server.xml裡
<Connector port="8443"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" disableUploadTimeout="true"
acceptCount="100" debug="0" scheme="https" secure="true"
clientAuth="false" sslProtocol="TLS"
keystoreFile="C:/Documents and Settings/new/keystore.keystore"
keystorePass="changeit" />

5.在要使用CAS的用戶端client1裡設定(以servlets-examples這個APP為例),我們使用
ServletFilter(CAS client裡提供的)來實現SSO的檢查。

修改servlets-examples/WEB-INF/web.xml

<filter>
<filter-name>CASFilter</filter-name>
<filter-class>edu.yale.its.tp.cas.client.filter.CASFilter</filter-class>
<init-param>
<param-name>edu.yale.its.tp.cas.client.filter.loginUrl</param-name>
<param-value>https://localhost:8443/cas/login</param-value>
</init-param>
<init-param>
<param-name>edu.yale.its.tp.cas.client.filter.validateUrl</param-name>
<param-value>https://localhost:8443/cas/proxyValidate</param-value>
</init-param>

<init-param>
<param-name>edu.yale.its.tp.cas.client.filter.serverName</param-name>
<param-value>localhost:8080</param-value>
</init-param>

</filter>

<filter-mapping>
<filter-name>CASFilter</filter-name>
<url-pattern>/servlet/*</url-pattern>
</filter-mapping>

6.將cas-client-2.0.11.zip解壓,把java/lib/casclient.jar拷貝到client1伺服器上的
webapps/servlets-examples/WEB-INF/lib目錄下(如果沒有就建一個)

7.匯出SERVER的認證,用來給所有需要用到的用戶端匯入
keytool -export -file myserver.cert -alias my-alias-name -keystore keystore.keystore

8.在用戶端的JVM裡匯入信任的SERVER的認證(根據情況有可能需要管理員權限)

#keytool -import -keystore $JAVA_HOME/jre/lib/security/cacerts -file myserver.cert -alias my-alias-name
keytool -import -keystore D:/Java/jdk1.5.0_06/jre/lib/security/cacerts -file myserver.cert -alias localhost

9.test & done.
把server1和client1分別起來,檢查啟動的LOG是否正常,如果一切OK,就訪問
http://client1:8080/servlets-examples/servlet/HelloWorldExample
系統會自動跳轉到一個驗證頁面,隨便輸入一個相同的帳號,密碼,嚴正通過之後就會訪問
到真正的HelloWorldExample這個servlet了

更多資訊請參考
http://www.yale.edu/tp/cas/
http://www-106.ibm.com/developerworks/web/library/wa-singlesign/

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.