﻿{"id":109,"date":"2013-07-24T21:47:44","date_gmt":"2013-07-24T13:47:44","guid":{"rendered":"http:\/\/blog.sway.com.cn\/?p=109"},"modified":"2013-07-24T21:50:03","modified_gmt":"2013-07-24T13:50:03","slug":"cas-server3-5-2-client3-2-1-%e5%8d%95%e7%82%b9%e7%99%bb%e5%bd%95%e6%97%a0%e8%af%81%e4%b9%a6%e5%85%a8%e6%94%bb%e7%95%a5","status":"publish","type":"post","link":"http:\/\/blog.sway.com.cn\/?p=109","title":{"rendered":"CAS Server3.5.2 + Client3.2.1 \u5355\u70b9\u767b\u5f55(\u65e0\u8bc1\u4e66\u5168\u653b\u7565)"},"content":{"rendered":"<p>\u914d\u7f6e\u73af\u5883:<br \/>\nJDK 1.6 +\u00a0TOMCAT 6<br \/>\nYale CAS Server3.5.2 +\u00a0Client3.2.1<\/p>\n<p>\u5de5\u4f5c\u51c6\u5907:<br \/>\n\u5230\u00a0http:\/\/www.jasig.org\/cas \u4e2d\u4e0b\u8f7d\u5bf9\u5e94\u7248\u672c\u7684 \u670d\u52a1\u5668\u7aefcas-server-3.5.2-release.zip \u548c \u5ba2\u6237\u7aefcas-client-3.2.1-release.zip<\/p>\n<p>\u4e00\u3001\u5c1d\u8bd5\u8fd0\u884cCAS\u670d\u52a1\u5668\u7aef<br \/>\n\u89e3\u538bcas-server-3.5.2-release.zip, \u5728\u91cc\u9762\u7684moudles\u6587\u4ef6\u5939\u91cc\u6709\u4e2acas-server-webapp-3.5.2.war\u6587\u4ef6, \u8fd9\u4e2a\u5c31\u662f\u670d\u52a1\u5668\u7684\u6240\u6709\u6587\u4ef6, \u89e3\u538b, \u8bbe\u7f6etomcat\u7684server.xml\u628a\u8be5\u6587\u4ef6\u5939\u6dfb\u52a0\u5bf9\u5e94\u7684\u865a\u62df\u76ee\u5f55, \u6211\u4eec\u4ee5 http:\/\/localhost:8080\/cas \u4e3a\u4f8b\uff0c\u767b\u5f55\u00a0http:\/\/localhost:8080\/cas \u540e\u4f60\u4eec\u53ef\u4ee5\u770b\u5230\u767b\u5f55\u754c\u9762\uff0c\u4fbf\u4e8e\u6d4b\u8bd5\uff0cCAS\u9ed8\u8ba4\u8f93\u5165\u76f8\u540c\u7684\u8d26\u53f7\u8ddf\u5bc6\u7801\u5373\u53ef\u901a\u8fc7\u767b\u5f55\u9a8c\u8bc1\u3002<\/p>\n<p>\u4e8c\u3001\u914d\u7f6eCAS\u670d\u52a1\u7aef\uff0c\u4f7f\u5176\u8bfb\u53d6mysql\u6570\u636e\u5e93\u5bf9\u5e94\u7684\u6570\u636e\u8fdb\u884c\u767b\u5f55\u5224\u65ad<\/p>\n<p>\u6253\u5f00CAS\u7684\/WEB-INF\/deployerConfigContext.xml\uff0c\u627e\u5230\u4ee5\u4e0b\u4ee3\u7801\u5e76\u6ce8\u91ca\u6389\uff0c\u53d6\u6d88\u6389\u539f\u6765\u7684\u7528\u4e8e\u6d4b\u8bd5\u7684\u7b80\u5355\u9a8c\u8bc1<\/p>\n<pre class=\"lang:xhtml decode:true\">&lt;bean class=\"org.jasig.cas.authentication.handler.support.SimpleTestUsernamePasswordAuthenticationHandler\" \/&gt;<\/pre>\n<p>\u6362\u6210\u4ee5\u4e0b\u7684\u9a8c\u8bc1\u65b9\u5f0f<\/p>\n<pre class=\"lang:xhtml decode:true\">&lt;bean class=\"org.jasig.cas.adaptors.jdbc.QueryDatabaseAuthenticationHandler\"&gt;\r\n\t&lt;property name=\"dataSource\" ref=\"dataSource\" \/&gt;\r\n\t&lt;property name=\"sql\" value=\"SELECT password FROM account WHERE email=?\" \/&gt;\r\n&lt;\/bean&gt;<\/pre>\n<p>\u5e76\u914d\u7f6e\u5bf9\u5e94\u7684\u6570\u636e\u6e90\uff08\u6dfb\u52a0bean\uff09\uff1a<\/p>\n<pre class=\"lang:xhtml decode:true\">\t&lt;!-- \u914d\u7f6e\u6570\u636e\u6e90 --&gt;\r\n\t&lt;bean id=\"dataSource\" class=\"org.springframework.jdbc.datasource.DriverManagerDataSource\"&gt;\r\n\t\t&lt;property name=\"driverClassName\"&gt;\r\n\t\t\t&lt;value&gt;com.mysql.jdbc.Driver&lt;\/value&gt;\r\n\t\t&lt;\/property&gt;\r\n\t\t&lt;property name=\"url\"&gt;\r\n\t\t\t&lt;value&gt;jdbc:mysql:\/\/localhost:3306\/sway_account?useUnicode=true&amp;amp;characterEncoding=utf-8&lt;\/value&gt;\r\n\t\t&lt;\/property&gt;\r\n\t\t&lt;property name=\"username\"&gt;\r\n\t\t\t&lt;value&gt;root&lt;\/value&gt;\r\n\t\t&lt;\/property&gt;\r\n\t\t&lt;property name=\"password\"&gt;\r\n\t\t\t&lt;value&gt;&lt;\/value&gt;\r\n\t\t&lt;\/property&gt;\r\n\t&lt;\/bean&gt;<\/pre>\n<p>&nbsp;<\/p>\n<p>\u4e09\u3001\u914d\u7f6eCAS\u5ba2\u6237\u7aef<\/p>\n<p>\u65b0\u5efa\u4e00\u4e2atomcat\u865a\u62df\u76ee\u5f55\uff0c\u6211\u4eec\u4ee5\u00a0http:\/\/localhost:8080\/test \u4e3a\u4f8b\uff0c\u5e76\u4e14\u786e\u4fdd\u91cc\u9762\u6709\u4e00\u4e2a\u53ef\u8bbf\u95ee\u7684\u6587\u4ef6\uff08\u6211\u4eec\u8fd9\u91cc\u4ee5index.jsp\u4e3a\u4f8b\uff09\uff0c\u89e3\u538bcas-client-3.2.1-release.zip\uff0c\u5728\u91cc\u9762modules\u91cc\u9762\u627e\u5230cas-client-core-3.2.1.jar\u4ee5\u53cacommons-logging-1.1.jar\u6587\u4ef6\uff0c\u590d\u5236\u5230\u00a0http:\/\/localhost:8080\/test \u9879\u76ee\u91cc\u9762\u7684 WEB-INF\/lib \u6587\u4ef6\u5939\u91cc\u9762\uff0c\u7136\u540e\u4fee\u6539\u91cc\u9762\u7684web.xml\u6587\u4ef6\uff0c\u6dfb\u52a0\u4ee5\u4e0b\u8fc7\u6ee4\u5668\uff1a<\/p>\n<pre class=\"lang:xhtml decode:true crayon-selected\">&lt;?xml version=\"1.0\" encoding=\"UTF-8\"?&gt;\r\n&lt;web-app id=\"WebApp_ID\" version=\"3.0\"\r\n\txmlns=\"http:\/\/java.sun.com\/xml\/ns\/javaee\" xmlns:xsi=\"http:\/\/www.w3.org\/2001\/XMLSchema-instance\"\r\n\txmlns:web=\"http:\/\/java.sun.com\/xml\/ns\/javaee\/web-app_2_5.xsd\"\r\n\txsi:schemaLocation=\"http:\/\/java.sun.com\/xml\/ns\/javaee \r\nhttp:\/\/java.sun.com\/xml\/ns\/javaee\/web-app_3_0.xsd\"&gt;\r\n\r\n\t&lt;welcome-file-list&gt;\r\n\t\t&lt;welcome-file&gt;index.jsp&lt;\/welcome-file&gt;  \r\n\t&lt;\/welcome-file-list&gt;\r\n\r\n\t&lt;listener&gt;\r\n\t\t&lt;listener-class&gt;org.jasig.cas.client.session.SingleSignOutHttpSessionListener&lt;\/listener-class&gt;\r\n\t&lt;\/listener&gt;\r\n\r\n\t&lt;!--\u8be5\u8fc7\u6ee4\u5668\u7528\u4e8e\u5b9e\u73b0\u5355\u70b9\u767b\u51fa\u529f\u80fd\uff0c\u53ef\u9009\u914d\u7f6e\u3002 --&gt;\r\n\t&lt;filter&gt;\r\n\t\t&lt;filter-name&gt;CAS Single Sign Out Filter&lt;\/filter-name&gt;\r\n\t\t&lt;filter-class&gt;org.jasig.cas.client.session.SingleSignOutFilter&lt;\/filter-class&gt;\r\n\t&lt;\/filter&gt;\r\n\t&lt;filter-mapping&gt;\r\n\t\t&lt;filter-name&gt;CAS Single Sign Out Filter&lt;\/filter-name&gt;\r\n\t\t&lt;url-pattern&gt;\/*&lt;\/url-pattern&gt;\r\n\t&lt;\/filter-mapping&gt;\r\n\r\n\t&lt;!--\u8be5\u8fc7\u6ee4\u5668\u8d1f\u8d23\u7528\u6237\u7684\u8ba4\u8bc1\u5de5\u4f5c\uff0c\u5fc5\u987b\u542f\u7528\u5b83 --&gt;\r\n\t&lt;filter&gt;\r\n\t\t&lt;filter-name&gt;CASFilter&lt;\/filter-name&gt;\r\n\t\t&lt;filter-class&gt;org.jasig.cas.client.authentication.AuthenticationFilter&lt;\/filter-class&gt;\r\n\t\t&lt;init-param&gt;\r\n\t\t\t&lt;param-name&gt;casServerLoginUrl&lt;\/param-name&gt;\r\n\t\t\t&lt;param-value&gt;http:\/\/localhost:8080\/cas\/login&lt;\/param-value&gt;\r\n\t\t\t&lt;!--\u8fd9\u91cc\u7684server\u662f\u670d\u52a1\u7aef\u7684IP --&gt;\r\n\t\t&lt;\/init-param&gt;\r\n\t\t&lt;init-param&gt;\r\n\t\t\t&lt;param-name&gt;serverName&lt;\/param-name&gt;\r\n\t\t\t&lt;param-value&gt;http:\/\/localhost:8080\/&lt;\/param-value&gt;\r\n\t\t&lt;\/init-param&gt;\r\n\t&lt;\/filter&gt;\r\n\t&lt;filter-mapping&gt;\r\n\t\t&lt;filter-name&gt;CASFilter&lt;\/filter-name&gt;\r\n\t\t&lt;url-pattern&gt;\/*&lt;\/url-pattern&gt;\r\n\t&lt;\/filter-mapping&gt;\r\n\r\n\t&lt;!-- \u8be5\u8fc7\u6ee4\u5668\u8d1f\u8d23\u5bf9Ticket\u7684\u6821\u9a8c\u5de5\u4f5c\uff0c\u5fc5\u987b\u542f\u7528\u5b83 --&gt;\r\n\t&lt;!-- ValidationFilter \u8fd9\u4e2afilter\u8d1f\u8d23\u5bf9\u8bf7\u6c42\u53c2\u6570ticket\u8fdb\u884c\u9a8c\u8bc1(ticket\u53c2\u6570\u662f\u8d1f\u8d23\u5b50\u7cfb\u7edf\u4e0eCAS\u8fdb\u884c\u9a8c\u8bc1\u4ea4\u4e92\u7684\u51ed\u8bc1)casServerUrlPrefix:CAS\u670d\u52a1\u8bbf\u95ee\u5730\u5740serverName:\u5f53\u524d\u5e94\u7528\u6240\u5728\u7684\u4e3b\u673a\u540d --&gt;\r\n\t&lt;filter&gt;\r\n\t\t&lt;filter-name&gt;CAS Validation Filter&lt;\/filter-name&gt;\r\n\t\t&lt;filter-class&gt;\r\n\t\t\torg.jasig.cas.client.validation.Cas20ProxyReceivingTicketValidationFilter\r\n\t\t&lt;\/filter-class&gt;\r\n\t\t&lt;init-param&gt;\r\n\t\t\t&lt;param-name&gt;casServerUrlPrefix&lt;\/param-name&gt;\r\n\t\t\t&lt;param-value&gt;http:\/\/localhost:8080\/cas&lt;\/param-value&gt;\r\n\t\t&lt;\/init-param&gt;\r\n\t\t&lt;init-param&gt;\r\n\t\t\t&lt;param-name&gt;serverName&lt;\/param-name&gt;\r\n\t\t\t&lt;param-value&gt;http:\/\/localhost:8080\/&lt;\/param-value&gt;\r\n\t\t&lt;\/init-param&gt;\r\n\t&lt;\/filter&gt;\r\n\t&lt;filter-mapping&gt;\r\n\t\t&lt;filter-name&gt;CAS Validation Filter&lt;\/filter-name&gt;\r\n\t\t&lt;url-pattern&gt;\/*&lt;\/url-pattern&gt;\r\n\t&lt;\/filter-mapping&gt;\r\n\r\n\t&lt;!-- 3.(\u53ef\u9009)HttpServletRequestWrapperFilter \u8fd9\u4e2a\u662fHttpServletRequet\u7684\u5305\u88f9\u7c7b\uff0c\u8ba9\u4ed6\u652f\u6301getUserPrincipal\uff0cgetRemoteUser\u65b9\u6cd5\u6765\u53d6\u5f97\u7528\u6237\u4fe1\u606f --&gt;\r\n\t&lt;!-- \u8be5\u8fc7\u6ee4\u5668\u8d1f\u8d23\u5b9e\u73b0HttpServletRequest\u8bf7\u6c42\u7684\u5305\u88f9\uff0c\u6bd4\u5982\u5141\u8bb8\u5f00\u53d1\u8005\u901a\u8fc7HttpServletRequest\u7684getRemoteUser()\u65b9\u6cd5\u83b7\u5f97SSO\u767b\u5f55\u7528\u6237\u7684\u767b --&gt;\r\n\t&lt;filter&gt;\r\n\t\t&lt;filter-name&gt;CAS HttpServletRequest Wrapper Filter&lt;\/filter-name&gt;\r\n\t\t&lt;filter-class&gt;org.jasig.cas.client.util.HttpServletRequestWrapperFilter&lt;\/filter-class&gt;\r\n\t&lt;\/filter&gt;\r\n\t&lt;filter-mapping&gt;\r\n\t\t&lt;filter-name&gt;CAS HttpServletRequest Wrapper Filter&lt;\/filter-name&gt;\r\n\t\t&lt;url-pattern&gt;\/*&lt;\/url-pattern&gt;\r\n\t&lt;\/filter-mapping&gt;\r\n\r\n\t&lt;!-- 4.(\u53ef\u9009)AssertionThreadLocalFilter \u8fd9\u4e2a\u7c7b\u628aAssertion\u4fe1\u606f\u653e\u5728ThreadLocal\u53d8\u91cf\u4e2d\uff0c\u8fd9\u6837\u5e94\u7528\u7a0b\u5e8f\u4e0d\u5728web\u5c42\u4e5f\u80fd\u591f\u83b7\u53d6\u5230\u5f53\u524d\u767b\u5f55\u4fe1\u606f Assertion assersion =AssertionHolder.getAssertion(); --&gt;\r\n\t&lt;!--\u8be5\u8fc7\u6ee4\u5668\u4f7f\u5f97\u5f00\u53d1\u8005\u53ef\u4ee5\u901a\u8fc7org.jasig.cas.client.util.AssertionHolder\u6765\u83b7\u53d6\u7528\u6237\u7684\u767b\u5f55\u540d\u3002\u6bd4\u5982AssertionHolder.getAssertion().getPrincipal().getName()\u3002--&gt;\r\n\t&lt;filter&gt;\r\n\t\t&lt;filter-name&gt;CAS Assertion Thread Local Filter&lt;\/filter-name&gt;\r\n\t\t&lt;filter-class&gt;org.jasig.cas.client.util.AssertionThreadLocalFilter&lt;\/filter-class&gt;\r\n\t&lt;\/filter&gt;\r\n\t&lt;filter-mapping&gt;\r\n\t\t&lt;filter-name&gt;CAS Assertion Thread Local Filter&lt;\/filter-name&gt;\r\n\t\t&lt;url-pattern&gt;\/*&lt;\/url-pattern&gt;\r\n\t&lt;\/filter-mapping&gt;\r\n\r\n&lt;\/web-app&gt;<\/pre>\n<p>&nbsp;<\/p>\n<p>\u56db\u3001\u8bfb\u53d6\u66f4\u591a\u7684\u5ba2\u6237\u7aef\u4fe1\u606f<\/p>\n<p>\u6253\u5f00CAS\u7684\/WEB-INF\/deployerConfigContext.xml\uff0c<br \/>\n\u627e\u5230bean id\u4e3a<i>attributeRepository<\/i>\u7684\u8fd9\u4e2a\u914d\u7f6e\uff0c\u4fee\u6539\u4e3a\u5982\u4e0b<\/p>\n<pre class=\"lang:xhtml decode:true\">\t\r\n\t&lt;bean id=\"attributeRepository\" class=\"org.jasig.services.persondir.support.jdbc.SingleRowJdbcPersonAttributeDao\"&gt;\r\n\t\t&lt;constructor-arg index=\"0\" ref=\"dataSource\" \/&gt;\r\n\t\t&lt;constructor-arg index=\"1\"&gt;\r\n\t\t\t&lt;value&gt;select * from account where {0}&lt;\/value&gt;\r\n\t\t&lt;\/constructor-arg&gt;\r\n\t\t&lt;!-- \u7ec4\u88c5sql\u7528\u7684\u67e5\u8be2\u6761\u4ef6\u5c5e\u6027 --&gt;\r\n\t\t&lt;property name=\"queryAttributeMapping\"&gt;\r\n\t\t\t&lt;map&gt;\r\n\t\t\t\t&lt;entry key=\"username\" value=\"email\" \/&gt;\r\n\t\t\t\t&lt;!-- &lt;entry key=\"username\" value=\"userAccount\" \/&gt; --&gt;\r\n\t\t\t&lt;\/map&gt;\r\n\t\t&lt;\/property&gt;\r\n\t\t&lt;!-- \u5982\u679c\u8981\u7ec4\u88c5\u591a\u4e2a\u67e5\u8be2\u6761\u4ef6\uff0c\u9700\u8981\u52a0\u4e0a\u4e0b\u9762\u8fd9\u4e2a\uff0c\u9ed8\u8ba4\u4e3aAND --&gt;\r\n\t\t&lt;!-- &lt;property name=\"queryType\"&gt;\r\n\t\t\t&lt;value&gt;OR&lt;\/value&gt;\r\n\t\t&lt;\/property&gt; --&gt;\r\n\t\t&lt;!-- \u8981\u83b7\u53d6\u7684\u5c5e\u6027\u5728\u8fd9\u91cc\u914d\u7f6e --&gt;\r\n\t\t&lt;property name=\"resultAttributeMapping\"&gt;\r\n\t\t\t&lt;map&gt;\r\n\t\t\t\t&lt;!--key\u4e3a\u5bf9\u5e94\u7684\u6570\u636e\u5e93\u5b57\u6bb5\u540d\u79f0\uff0cvalue\u4e3a\u63d0\u4f9b\u7ed9\u5ba2\u6237\u7aef\u83b7\u53d6\u7684\u5c5e\u6027\u540d\u5b57\uff0c\u7cfb\u7edf\u4f1a\u81ea\u52a8\u586b\u5145\u503c --&gt;\r\n\t\t\t\t&lt;entry key=\"id\" value=\"id\" \/&gt;\r\n\t\t\t\t&lt;entry key=\"email\" value=\"email\" \/&gt;\r\n\t\t\t\t&lt;entry key=\"emailValidated\" value=\"emailValidated\" \/&gt;\r\n\t\t\t\t&lt;entry key=\"password\" value=\"password\" \/&gt;\r\n\t\t\t\t&lt;entry key=\"registerTime\" value=\"registerTime\" \/&gt;\r\n\t\t\t\t&lt;entry key=\"lastLoginTime\" value=\"lastLoginTime\" \/&gt;\r\n\t\t\t\t&lt;entry key=\"balance\" value=\"balance\" \/&gt;\r\n\t\t\t&lt;\/map&gt;\r\n\t\t&lt;\/property&gt;\r\n\t&lt;\/bean&gt;<\/pre>\n<p>\u4fee\u6539\u8be5xml\u6587\u4ef6\u4e2d\u6700\u540e\u4e00\u4e2a\u9ed8\u8ba4\u7684serviceRegistryDao bean\uff0c\u627e\u5230&lt;bean\u00a0class=&#8221;org.jasig.cas.services.RegexRegisteredService&#8221;&gt;\u628a\u9ad8\u4eae\u90e8\u5206\u6dfb\u52a0\u8fdb\u53bb\uff1a<\/p>\n<pre class=\"lang:xhtml mark:7 decode:true\">&lt;bean class=\"org.jasig.cas.services.RegexRegisteredService\"&gt;\r\n                        &lt;property name=\"id\" value=\"0\" \/&gt;\r\n                        &lt;property name=\"name\" value=\"HTTP and IMAP\" \/&gt;\r\n                        &lt;property name=\"description\" value=\"Allows HTTP(S) and IMAP(S) protocols\" \/&gt;\r\n                        &lt;property name=\"serviceId\" value=\"^(https?|imaps?):\/\/.*\" \/&gt;\r\n                        &lt;property name=\"evaluationOrder\" value=\"10000001\" \/&gt;\r\n                        &lt;property name=\"ignoreAttributes\" value=\"true\"\/&gt;\r\n                    &lt;\/bean&gt;<\/pre>\n<p>\u6700\u540e\u4fee\u6539WEB-INF\\view\\jsp\\protocol\\2.0\\casServiceValidationSuccess.jsp\u6587\u4ef6<\/p>\n<pre class=\"lang:default decode:true\">&lt;%@page pageEncoding=\"UTF-8\"%&gt;\r\n&lt;%@ page session=\"false\" %&gt;\r\n&lt;%@ taglib prefix=\"c\" uri=\"http:\/\/java.sun.com\/jsp\/jstl\/core\" %&gt;\r\n&lt;%@ taglib uri=\"http:\/\/java.sun.com\/jsp\/jstl\/functions\" prefix=\"fn\" %&gt;\r\n\r\n&lt;cas:serviceResponse xmlns:cas='http:\/\/www.yale.edu\/tp\/cas'&gt;\r\n\r\n\t&lt;cas:authenticationSuccess&gt;\r\n        &lt;cas:user&gt;${fn:escapeXml(assertion.chainedAuthentications[fn:length(assertion.chainedAuthentications)-1].principal.id)}&lt;\/cas:user&gt;                \r\n        &lt;c:if test=\"${not empty pgtIou}\"&gt;\r\n                &lt;cas:proxyGrantingTicket&gt;${pgtIou}&lt;\/cas:proxyGrantingTicket&gt;\r\n        &lt;\/c:if&gt;\r\n        &lt;c:if test=\"${fn:length(assertion.chainedAuthentications) &gt; 1}\"&gt;\r\n                &lt;cas:proxies&gt;\r\n                &lt;c:forEach var=\"proxy\" items=\"${assertion.chainedAuthentications}\" varStatus=\"loopStatus\" begin=\"0\" end=\"${fn:length(assertion.chainedAuthentications)-2}\" step=\"1\"&gt;\r\n                            &lt;cas:proxy&gt;${fn:escapeXml(proxy.principal.id)}&lt;\/cas:proxy&gt;\r\n                &lt;\/c:forEach&gt;\r\n                &lt;\/cas:proxies&gt;\r\n        &lt;\/c:if&gt;\r\n        &lt;!-- \u5728server\u9a8c\u8bc1\u6210\u529f\u540e\uff0c\u8fd9\u4e2a\u9875\u9762\u8d1f\u8d23\u751f\u6210\u4e0e\u5ba2\u6237\u7aef\u4ea4\u4e92\u7684xml\u4fe1\u606f\uff0c\u5728\u9ed8\u8ba4\u7684casServiceValidationSuccess.jsp\u4e2d\uff0c\u53ea\u5305\u62ec\u7528\u6237\u540d\uff0c\u5e76\u4e0d\u63d0\u4f9b\u5176\u4ed6\u7684\u5c5e\u6027\u4fe1\u606f\uff0c\u56e0\u6b64\u9700\u8981\u5bf9\u9875\u9762\u8fdb\u884c\u6269\u5c55 --&gt;\r\n        &lt;c:if test=\"${fn:length(assertion.chainedAuthentications[fn:length(assertion.chainedAuthentications)-1].principal.attributes) &gt; 0}\"&gt;   \r\n            &lt;cas:attributes&gt;   \r\n                &lt;c:forEach var=\"attr\" items=\"${assertion.chainedAuthentications[fn:length(assertion.chainedAuthentications)-1].principal.attributes}\"&gt;                             \r\n                    &lt;cas:${fn:escapeXml(attr.key)}&gt;${fn:escapeXml(attr.value)}&lt;\/cas:${fn:escapeXml(attr.key)}&gt;                                 \r\n                &lt;\/c:forEach&gt;     \r\n            &lt;\/cas:attributes&gt;   \r\n        &lt;\/c:if&gt; \r\n    &lt;\/cas:authenticationSuccess&gt;\r\n\r\n&lt;\/cas:serviceResponse&gt;<\/pre>\n<p>\u7136\u540e\u5373\u53ef\u4f7f\u7528\u4ee5\u4e0b\u4ee3\u7801\u5728index.jsp\u4e2d\u83b7\u53d6\u5bf9\u5e94\u7684\u8fd4\u56de\u5bf9\u8c61:<\/p>\n<pre class=\"lang:java decode:true\">AttributePrincipal principal = (AttributePrincipal) request.getUserPrincipal();\r\nMap&lt;String, Object&gt; attributes = principal.getAttributes();<\/pre>\n<p>\u4ee5\u4e0b\u662f\u6211\u7528\u4e8e\u6d4b\u8bd5\u7684index.jsp<\/p>\n<pre class=\"lang:java decode:true\">&lt;%@ page language=\"java\" import=\"java.util.*\" contentType=\"text\/html;charset=utf-8\"%&gt;\r\n&lt;%@ page import=\"org.jasig.cas.client.authentication.AttributePrincipal,org.jasig.cas.client.validation.Assertion,org.jasig.cas.client.util.AbstractCasFilter\"%&gt;\r\n\r\n&lt;%\r\nString path = request.getContextPath();\r\nString basePath = request.getScheme()+\":\/\/\"+request.getServerName()+\":\"+request.getServerPort()+path+\"\/\";\r\n%&gt;\r\n\r\n&lt;!DOCTYPE HTML PUBLIC \"-\/\/W3C\/\/DTD HTML 4.01 Transitional\/\/EN\"&gt;\r\n&lt;html&gt;\r\n&lt;head&gt;\r\n\t&lt;base href=\"&lt;%=basePath%&gt;\"&gt;\r\n\t&lt;title&gt;CAS\u5355\u70b9\u767b\u5f55VS\u9000\u51fa&lt;\/title&gt;\r\n&lt;\/head&gt;\r\n&lt;body&gt;\r\n\r\n&lt;%\r\nAttributePrincipal principal = (AttributePrincipal) request.getUserPrincipal();\r\nMap&lt;String, Object&gt; attributes = principal.getAttributes();\r\n\/*for(Map.Entry&lt;String,Object&gt; m: attributes.entrySet()){ \r\n\tSystem.out.println(m.getKey()+\"---\"+m.getValue()); \r\n}*\/\r\n%&gt;\r\n\r\n[ \u5355\u70b9\u767b\u5f55\u6d4b\u8bd5 ]&lt;br \/&gt;&lt;br \/&gt;\r\n\u7528\u6237\u540d\uff1a&lt;%=principal.getName()%&gt;&lt;br \/&gt;\r\nid:&lt;%=attributes.get(\"id\")%&gt;&lt;br \/&gt;\r\nemail:&lt;%=attributes.get(\"email\")%&gt;&lt;br \/&gt;\r\nemailValidated:&lt;%=attributes.get(\"emailValidated\")%&gt;&lt;br \/&gt;\r\npassword:&lt;%=attributes.get(\"password\")%&gt;&lt;br \/&gt;\r\nregisterTime:&lt;%=attributes.get(\"registerTime\")%&gt;&lt;br \/&gt;\r\nlastLoginTime:&lt;%=attributes.get(\"lastLoginTime\")%&gt;&lt;br \/&gt;\r\nbalance:&lt;%=attributes.get(\"balance\")%&gt;&lt;br \/&gt;\r\n&lt;br \/&gt;\r\n&lt;a href=\"http:\/\/localhost:8080\/sway\/cas\/logout\"&gt;\u9000\u51fa&lt;\/a&gt;&lt;br \/&gt;&lt;br \/&gt;\r\n&lt;hr\/&gt;\r\n&lt;br \/&gt;&lt;br \/&gt;\r\n[ DEBUG ]&lt;br \/&gt;&lt;br \/&gt;\r\nmap\u4e2d\u5143\u7d20\u4e2a\u6570\u4e3a&lt;%=attributes.size()%&gt;\r\n\r\n&lt;\/body&gt;\r\n\r\n&lt;\/html&gt;<\/pre>\n<p>\u81f3\u6b64\u914d\u7f6e\u5b8c\u6bd5\uff0c\u5f80\u540e\u518d\u6559\u5927\u5bb6\u914d\u7f6e\u5bf9\u5e94\u7684SSL\u52a0\u5bc6\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u914d\u7f6e\u73af\u5883: JDK 1.6 +\u00a0TOMCAT 6 Yale CAS Server3.5.2 +\u00a0Client3 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[55],"tags":[56,57],"class_list":["post-109","post","type-post","status-publish","format-standard","hentry","category-sso","tag-cas","tag-ssoj2ee"],"_links":{"self":[{"href":"http:\/\/blog.sway.com.cn\/index.php?rest_route=\/wp\/v2\/posts\/109","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/blog.sway.com.cn\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/blog.sway.com.cn\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/blog.sway.com.cn\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/blog.sway.com.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=109"}],"version-history":[{"count":6,"href":"http:\/\/blog.sway.com.cn\/index.php?rest_route=\/wp\/v2\/posts\/109\/revisions"}],"predecessor-version":[{"id":114,"href":"http:\/\/blog.sway.com.cn\/index.php?rest_route=\/wp\/v2\/posts\/109\/revisions\/114"}],"wp:attachment":[{"href":"http:\/\/blog.sway.com.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=109"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/blog.sway.com.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=109"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/blog.sway.com.cn\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=109"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}