您需要: 1. 对 ADFS STS 服务进行身份验证以获取 SecurityToken 2. 使用“CreateChannelWithIssuedToken”通过通道查询您的服务,如下所示:
var token = GetToken();
string uri = SERVICE_URL;
EndpointAddress address = new EndpointAddress(uri);
var binding = new WS2007FederationHttpBinding(WSFederationHttpSecurityMode.TransportWithMessageCredential);
binding.Security.Message.EstablishSecurityContext = false;
_factory = new ChannelFactory<IService>(binding, address);
_factory.ConfigureChannelFactory<IService>();
_factory.Credentials.SupportInteractive = false;
_service = _factory.CreateChannelWithIssuedToken<IService>(token);
GetToken 的代码如下所示:
public static SecurityToken GetToken(string username, string password, EndpointAddress federationServiceProxyAddress, EndpointAddress relyingPartyIdentifier)
{
var binding = new UserNameWSTrustBinding
{
SecurityMode = SecurityMode.TransportWithMessageCredential
};
var factory = new WSTrustChannelFactory(binding, federationServiceProxyAddress)
{
TrustVersion = System.ServiceModel.Security.TrustVersion.WSTrust13,
};
factory.Credentials.SupportInteractive = false;
factory.Credentials.UserName.UserName = username;
factory.Credentials.UserName.Password = password;
try
{
var requestSecurityToken = new RequestSecurityToken
{
RequestType = WSTrust13Constants.RequestTypes.Issue,
AppliesTo = relyingPartyIdentifier
};
var channel = factory.CreateChannel();
return channel.Issue(requestSecurityToken);//, out requestSecurityTokenResponse);
}
catch (MessageSecurityException exception)
{
// Invalid username or password
throw new MessageSecurityException(exception.Message, exception);
}
catch (Exception exception)
{
// Unknown error
throw new Exception(exception.Message, exception);
}
finally
{
try
{
if (factory.State == CommunicationState.Faulted)
{
factory.Abort();
}
else
{
factory.Close();
}
}
catch (Exception) { }
}
}
希望这可以帮助...