CloudFoundry的UAA有一个RemoteTokenServices类(也是Spring oauth2的一部分),它通过转到UAA服务器的check_token端点来进行授权令牌验证。 UAA的示例 api 和 app 应用程序分别用作资源服务器和客户端应用程序。
来自示例 api的 spring-servlet.xml:
<bean id="tokenServices" class="org.cloudfoundry.identity.uaa.oauth.RemoteTokenServices">
<property name="checkTokenEndpointUrl" value="${checkTokenEndpointUrl}" />
<property name="clientId" value="app" />
<property name="clientSecret" value="appclientsecret" />
</bean>
您知道为什么这个类(以及需要在Authorization标头中编码这些值的check_token端点)需要clientId和clientSecret吗?在我看来,它从资源服务器依赖于客户端应用程序。如果其中一个客户端机密在这里“硬编码”,我如何使用多个客户端应用程序?
答案 0 :(得分:1)
我通过彻底阅读UAA documentation来弄明白自己,我仍然认为它在UAA示例应用程序中令人困惑: