2017-04-19 11 views
3

URL을 <samlp:response> 메시지로 특정 URL에 게시하는 방법이 필요합니다. 상당히 간단하고 .NET은 Saml2Assertion 클래스에서 도움이되지만 방법을 찾을 수 없습니다. 그 주장을 응답으로 감싸고 연재 시키라.C# 4.5 (WIF)에서 assertion에서 SAML 응답 만들기

Saml2Assertion assert = new Saml2Assertion(new Saml2NameIdentifier("SAMLIssuer")); 
assert.Subject = new Saml2Subject(new Saml2NameIdentifier("10001", new Uri("urn:oasis:names:tc:SAML:2.0:nameid-format:persistent"))); 
Saml2AuthenticationContext context = new Saml2AuthenticationContext(new Uri("urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport")); 
assert.Statements.Add(new Saml2AuthenticationStatement(context, DateTime.Now)); 

string assertion; 
using (var sw = new StringWriter()) 
{ 
    var xws = new XmlWriterSettings(); 
    using (var xw = XmlWriter.Create(sw, xws)) 
    { 
     var handler = new Saml2SecurityTokenHandler(); 
     handler.WriteToken(xw, new Saml2SecurityToken(assert)); 
    } 
    assertion = sw.ToString(); 
} 

내가 어설 얻을 XML은 잘 보인다 그래서

<?xml version="1.0" encoding="utf-16"?> 
<Assertion ID="_fc348927-c0bf-4955-b98f-483043d8dedd" IssueInstant="2017-04-19T11:29:38.464Z" Version="2.0" xmlns="urn:oasis:names:tc:SAML:2.0:assertion"> 
    <Issuer>SAMLIssuer</Issuer> 
    <Subject> 
     <NameID Format="urn:oasis:names:tc:SAML:2.0:nameid-format:persistent">10001</NameID> 
    </Subject> 
    <AuthnStatement AuthnInstant="2017-04-19T11:29:39.040Z"> 
     <AuthnContext> 
      <AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</AuthnContextClassRef> 
     </AuthnContext> 
    </AuthnStatement> 
</Assertion> 

, 지금 무엇? 어떻게 내 코드에서 얻기에받을 수 있나요 :

<samlp:Response 
    xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol" 
    xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" 
    ID="new id" 
    InResponseTo="old id" 
    Version="2.0" 
    IssueInstant="2017-04-19T11:29:39.040Z" 
    Destination="some url"> 
    <saml:Issuer>SAMLIssuer</saml:Issuer> 
    <samlp:Status> 
     <samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/> 
    </samlp:Status> 
    <saml:Assertion .... 

을 외부 라이브러리를 사용하거나 내 자신의 래퍼/문자열 회씩 연결하지 않고? 닷넷 4.5 구현에서 WIF를 구현하는 데 도움이되는 것을 찾을 수 없다.

답변