本文整理匯總了Java中org.apache.http.client.config.AuthSchemes.SPNEGO屬性的典型用法代碼示例。如果您正苦於以下問題:Java AuthSchemes.SPNEGO屬性的具體用法?Java AuthSchemes.SPNEGO怎麽用?Java AuthSchemes.SPNEGO使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類org.apache.http.client.config.AuthSchemes
的用法示例。
在下文中一共展示了AuthSchemes.SPNEGO屬性的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: toApacheAuthenticationScheme
/**
* Convert the customer-facing authentication method into an apache-specific authentication method.
*/
private String toApacheAuthenticationScheme(ProxyAuthenticationMethod authenticationMethod) {
if (authenticationMethod == null) {
throw new IllegalStateException("The configured proxy authentication methods must not be null.");
}
switch (authenticationMethod) {
case NTLM: return AuthSchemes.NTLM;
case BASIC: return AuthSchemes.BASIC;
case DIGEST: return AuthSchemes.DIGEST;
case SPNEGO: return AuthSchemes.SPNEGO;
case KERBEROS: return AuthSchemes.KERBEROS;
default: throw new IllegalStateException("Unknown authentication scheme: " + authenticationMethod);
}
}
示例2: KerberosHttpClient
private KerberosHttpClient(String user, String password, String domain, String kdc) {
try {
File krb5Config = createKrb5Configuration(domain, kdc);
File loginConfig = createLoginConfiguration();
System.setProperty("java.security.auth.login.config", loginConfig.toURI().toString());
System.setProperty("java.security.krb5.conf", krb5Config.toURI().toString());
System.setProperty("sun.security.krb5.debug", "false");
//Change this property to true, if you want debug output.
System.setProperty("javax.security.auth.useSubjectCredsOnly", "false");
RegistryBuilder<AuthSchemeProvider> registryBuilder = RegistryBuilder.create();
String id = AuthSchemes.SPNEGO;
SPNegoSchemeFactory schemeFactory = new SPNegoSchemeFactory(SKIP_PORT_AT_KERBEROS_DATABASE_LOOKUP);
Lookup<AuthSchemeProvider> authSchemeRegistry = registryBuilder.register(id, schemeFactory).build();
client = HttpClients.custom().setDefaultAuthSchemeRegistry(authSchemeRegistry)
.setConnectionManager(createConnectionManager()).build();
httpContext = getHttpContext();
loginContext = getLoginContext(user, password);
//without it, authentication will be failed.
final Subject subject = loginContext.getSubject();
final HttpGet get = new HttpGet(KerberosBpmClient.this.rootUri);
Subject.doAs(subject, this.privilegedExecute(get, httpContext));
} catch (Exception e) {
logger.error("Can't create Kerberos client!");
e.printStackTrace();
throw new RuntimeException(e);
}
}
示例3: WindowsNegotiateScheme
public WindowsNegotiateScheme(final String scheme, final String servicePrincipalName) {
super();
this.scheme = (scheme == null) ? AuthSchemes.SPNEGO : scheme;
this.challenge = null;
this.continueNeeded = true;
this.servicePrincipalName = servicePrincipalName;
if (this.log.isDebugEnabled()) {
this.log.debug("Created WindowsNegotiateScheme using " + this.scheme);
}
}
示例4: create
@Override
public AuthScheme create(final HttpContext context) {
return new WindowsNegotiateScheme(AuthSchemes.SPNEGO, servicePrincipalName);
}
示例5: getSchemeName
@Override
public String getSchemeName() {
return AuthSchemes.SPNEGO;
}