![](/img/trans.png)
[英]Is there a universal class for bitmaps(, so it can be send from a UWP Client to a WCF Service)?
[英]Send ADFS Token From Client to a WCF Service
我有一個要求-在我的Silverlight應用程序中,需要通過一個中間WCF服務連接到WCF服務以獲取數據,該中間WCF服務與Silverlight位於同一域中。 也就是說,Silverlight將要呼叫中間服務,該服務將隨請求一起附加IssuedToken,並將其發送到主WCF客戶端。 WCF主服務將從Thread.Principal檢索聲明。
var binding = new WS2007FederationHttpBinding(WSFederationHttpSecurityMode.TransportWithMessageCredential);
binding.Security.Message.EstablishSecurityContext = false;
var factory = new ChannelFactory<IMyService>(binding, new EndpointAddress("https://myservice.cloudapp.net:4432/MyService.svc"));
var channel = factory.CreateChannelActingAs(((ClaimsIdentity)((ClaimsPrincipal)HttpContext.Current.User).Identity).BootstrapToken);
var data = channel.GetData();
但是這段代碼失敗了。 我找不到有關如何實現此目的的屬性文檔。 誰能幫我這個忙。
謝謝,
您需要: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) { }
}
}
希望這可以幫助...
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.