openidsinglesignonaction.java
来自「CAS在Tomcat中实现单点登录项目,单点登录(Single Sign On 」· Java 代码 · 共 62 行
JAVA
62 行
/* * Copyright 2007 The JA-SIG Collaborative. All rights reserved. See license * distributed with this file and available online at * http://www.uportal.org/license.html */package org.jasig.cas.support.openid.web.flow;import org.jasig.cas.authentication.principal.Credentials;import org.jasig.cas.authentication.principal.Service;import org.jasig.cas.support.openid.authentication.principal.OpenIdCredentials;import org.jasig.cas.support.openid.authentication.principal.OpenIdService;import org.jasig.cas.support.openid.web.support.DefaultOpenIdUserNameExtractor;import org.jasig.cas.support.openid.web.support.OpenIdUserNameExtractor;import org.jasig.cas.util.annotation.NotNull;import org.jasig.cas.web.flow.AbstractNonInteractiveCredentialsAction;import org.jasig.cas.web.support.WebUtils;import org.springframework.webflow.execution.RequestContext;/** * Attempts to utilize an existing single sign on session, but only if the * Principal of the existing session matches the new Principal. Note that care * should be taken when using credentials that are automatically provided and * not entered by the user. * * @author Scott Battaglia * @version $Revision: 1.1 $ $Date: 2005/08/19 18:27:17 $ * @since 3.1 */public final class OpenIdSingleSignOnAction extends AbstractNonInteractiveCredentialsAction { @NotNull private OpenIdUserNameExtractor extractor = new DefaultOpenIdUserNameExtractor(); public void setExtractor(final OpenIdUserNameExtractor extractor) { this.extractor = extractor; } @Override protected Credentials constructCredentialsFromRequest(final RequestContext context) { final String ticketGrantingTicketId = WebUtils.getTicketGrantingTicketId(context); final String userName = this.extractor .extractLocalUsernameFromUri(context.getRequestParameters() .get("openid.identity")); final Service service = WebUtils.getService(context); context.getExternalContext().getSessionMap().put("openIdLocalId", userName); // clear the service because otherwise we can fake the username if (service instanceof OpenIdService && userName == null) { context.getFlowScope().remove("service"); } if (ticketGrantingTicketId == null || userName == null) { return null; } return new OpenIdCredentials( ticketGrantingTicketId, userName); }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?