2012-05-31 39 views
3

我必須讓我的WCF客戶端使用Web服務(IBM DataPower)並使用Web Services Security X.509 Certificate Token Profile 1.1 OASIS Standard Specification, 1 February 2006對請求進行簽名/加密。如何使WCF客戶端符合特定的WS-Security

到目前爲止,我已經創建了一個自定義綁定和「思考」我沿着正確的路線工作:

更新,以反映最新的嘗試

Private Function CreateCustomBinding() As Channels.Binding 

    Dim asbe As New Channels.AsymmetricSecurityBindingElement 

    asbe.MessageSecurityVersion = MessageSecurityVersion.WSSecurity10WSTrustFebruary2005WSSecureConversationFebruary2005WSSecurityPolicy11BasicSecurityProfile10 

    asbe.InitiatorTokenParameters = New ServiceModel.Security.Tokens.X509SecurityTokenParameters 
    asbe.RecipientTokenParameters = New ServiceModel.Security.Tokens.X509SecurityTokenParameters 

    asbe.MessageProtectionOrder = Security.MessageProtectionOrder.EncryptBeforeSign 

    asbe.SecurityHeaderLayout = SecurityHeaderLayout.Strict 

    asbe.IncludeTimestamp = True 
    asbe.SetKeyDerivation(False) 

    asbe.DefaultAlgorithmSuite = Security.SecurityAlgorithmSuite.Basic128Rsa15 'By default, AES-128 is used as the encryption algorithm. 

    'Add the elements to the custom binding 
    Dim myBinding As New CustomBinding 

    'element order is important - see http://msdn.microsoft.com/en-us/library/ms733893(v=vs.90).aspx 

    'Protocol Binding Elements (security) 
    myBinding.Elements.Add(asbe) 

    'Encoding Binding Element 
    myBinding.Elements.Add(New TextMessageEncodingBindingElement(MessageVersion.Soap11WSAddressing10, System.Text.Encoding.UTF8)) 

    'Transport Binding Element 
    Dim httpsBindingElement As New HttpsTransportBindingElement() 
    httpsBindingElement.RequireClientCertificate = True 
    myBinding.Elements.Add(httpsBindingElement) 

    Return myBinding 

End Function 

然後用這個像這樣綁定:

Dim epi As EndpointIdentity = EndpointIdentity.CreateDnsIdentity("xgtwsqa.theirdomain.com") 

Dim epuri As Uri = New Uri("https://xgtwqa.theirdomain.com/5067/ProcessRepairOrder") 
Dim ea As New EndpointAddress(epuri, epi, New AddressHeaderCollection) 

Dim myBinding As Binding = GetCustomBinding2() 

' Create the client. 
Dim starClientProxy As New wcfStarServiceProxy.starTransportPortTypesClient(myBinding, ea) 

' Specify a certificate to use for authenticating the client. 
starClientProxy.ClientCredentials.ClientCertificate.SetCertificate(StoreLocation.CurrentUser, StoreName.My, X509FindType.FindBySubjectName, "*.mydomain.org.uk") 

starClientProxy.ClientCredentials.ServiceCertificate.SetDefaultCertificate(StoreLocation.CurrentUser, StoreName.AddressBook, X509FindType.FindBySubjectName, "xgtwsqa.theirdomain.com") 

'starClientProxy.ClientCredentials.ServiceCertificate.SetScopedCertificate(StoreLocation.CurrentUser, StoreName.AddressBook, X509FindType.FindBySubjectName, "xgtwsqa.theirdomain.com", New Uri("https://xgtwqa.thedomain.com/5067/ProcessRepairOrder")) 

' Begin using the client. 
Dim response As wcfStarServiceProxy.AcknowledgeRepairOrderPayload = starClientProxy.ProcessMessage(payload) 

會有人告訴我還有什麼我需要在綁定配置(我很確定e綁定方法不太正確)或者向我提供我需要的代碼?

以上產生以下SOAP:

<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/" 
xmlns:a="http://www.w3.org/2005/08/addressing" 
xmlns:u="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd"> 

    <s:Header> 
    <a:Action s:mustUnderstand="1" u:Id="_3"> 
    http://www.starstandards.org/webservices/2009/transport/operations/ProcessMessage</a:Action> 
    <a:MessageID u:Id="_4"> 
    urn:uuid:c2acbb72-49c2-465b-b177-e806494cdef7</a:MessageID> 
    <a:ReplyTo u:Id="_5"> 
     <a:Address> 
     http://www.w3.org/2005/08/addressing/anonymous</a:Address> 
    </a:ReplyTo> 
    <a:To s:mustUnderstand="1" u:Id="_6"> 
    https://xgtwqa.theirdomain.com/5067/ProcessRepairOrder</a:To> 
    <o:Security s:mustUnderstand="1" 
    xmlns:o="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd"> 

     <u:Timestamp u:Id="uuid-b8d302ff-a098-42bb-afc6-694e647c23b0-1"> 

     <u:Created>2012-06-01T14:35:18.781Z</u:Created> 
     <u:Expires>2012-06-01T14:40:18.781Z</u:Expires> 
     </u:Timestamp> 
     <o:BinarySecurityToken u:Id="uuid-7f9c9673-ae43-4fb5-8510-03cc4b98fa93-2" 
     ValueType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-x509-token-profile-1.0#X509v3" 
     EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary"> 
     removed</o:BinarySecurityToken> 
     <o:BinarySecurityToken u:Id="uuid-7f9c9673-ae43-4fb5-8510-03cc4b98fa93-1" 
     ValueType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-x509-token-profile-1.0#X509v3" 
     EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary"> 
     removed</o:BinarySecurityToken> 
     <e:EncryptedKey Id="_0" 
     xmlns:e="http://www.w3.org/2001/04/xmlenc#"> 
     <e:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-1_5" /> 
     <KeyInfo xmlns="http://www.w3.org/2000/09/xmldsig#"> 
      <o:SecurityTokenReference> 
      <o:Reference ValueType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-x509-token-profile-1.0#X509v3" 
      URI="#uuid-7f9c9673-ae43-4fb5-8510-03cc4b98fa93-1" /> 
      </o:SecurityTokenReference> 
     </KeyInfo> 
     <e:CipherData> 
      <e:CipherValue> 
      removed</e:CipherValue> 
     </e:CipherData> 
     </e:EncryptedKey> 
     <Signature xmlns="http://www.w3.org/2000/09/xmldsig#"> 
     <SignedInfo> 
      <CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#" /> 
      <SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1" /> 
      <Reference URI="#_2"> 
      <Transforms> 
       <Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#" /> 
      </Transforms> 
      <DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" /> 
      <DigestValue>removed</DigestValue> 
      </Reference> 
      <Reference URI="#_3"> 
      <Transforms> 
       <Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#" /> 
      </Transforms> 
      <DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" /> 
      <DigestValue>removed</DigestValue> 
      </Reference> 
      <Reference URI="#_4"> 
      <Transforms> 
       <Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#" /> 
      </Transforms> 
      <DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" /> 
      <DigestValue>removed</DigestValue> 
      </Reference> 
      <Reference URI="#_5"> 
      <Transforms> 
       <Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#" /> 
      </Transforms> 
      <DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" /> 
      <DigestValue>removed</DigestValue> 
      </Reference> 
      <Reference URI="#_6"> 
      <Transforms> 
       <Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#" /> 
      </Transforms> 
      <DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" /> 
      <DigestValue>removed</DigestValue> 
      </Reference> 
      <Reference URI="#uuid-b8d302ff-a098-42bb-afc6-694e647c23b0-1"> 

      <Transforms> 
       <Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#" /> 
      </Transforms> 
      <DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" /> 
      <DigestValue>removed</DigestValue> 
      </Reference> 
     </SignedInfo> 
     <SignatureValue> 
     removed</SignatureValue> 
     <KeyInfo> 
      <o:SecurityTokenReference> 
      <o:Reference ValueType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-x509-token-profile-1.0#X509v3" 
      URI="#uuid-7f9c9673-ae43-4fb5-8510-03cc4b98fa93-2" /> 
      </o:SecurityTokenReference> 
     </KeyInfo> 
     </Signature> 
     <e:ReferenceList xmlns:e="http://www.w3.org/2001/04/xmlenc#"> 
     <e:DataReference URI="#_1" /> 
     </e:ReferenceList> 
    </o:Security> 
    </s:Header> 
    <s:Body u:Id="_2" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:xsd="http://www.w3.org/2001/XMLSchema"> 
    <e:EncryptedData Id="_1" 
    Type="http://www.w3.org/2001/04/xmlenc#Content" 
    xmlns:e="http://www.w3.org/2001/04/xmlenc#"> 
     <e:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes128-cbc"> 
     </e:EncryptionMethod> 
     <KeyInfo xmlns="http://www.w3.org/2000/09/xmldsig#"> 
     <o:SecurityTokenReference xmlns:o="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd"> 
      <o:Reference URI="#_0"></o:Reference> 
     </o:SecurityTokenReference> 
     </KeyInfo> 
     <e:CipherData> 
     <e:CipherValue>removed</e:CipherValue> 
     </e:CipherData> 
    </e:EncryptedData> 
    </s:Body> 
</s:Envelope> 

這是SOAP,我預計發送樣本:

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" 
xmlns:wsa="http://www.w3.org/2005/08/addressing" 
xmlns:star="http://www.starstandard.org/STAR/5" 
xmlns:tran="http://www.starstandards.org/webservices/2005/10/transport"> 

    <soap:Header> 
    <wsa:To>urn:removed/star/services/v1/GetConditionCodes</wsa:To> 
    <wsa:Action> 
    http://www.starstandards.org/webservices/2005/10/transport/operations/ProcessMessage</wsa:Action> 
    <wsa:MessageID> 
    ef67ec85-d5c7-4669-b1a6-440ec2fe938b</wsa:MessageID> 

    <tns:RespondTo xmlns:tns="urn:removed/soa/routing/v1.0"> 
     <tns:Endpoint> 
     https://b2b-test.mydomain.com/Async/removed/StarWebService.ashx</tns:Endpoint> 
    </tns:RespondTo> 
    <tran:payloadManifest> 
     <tran:manifest contentID="A0" 
     namespaceURI="http://www.starstandard.org/STAR/5" 
     element="GetStandardCodes" version="5.2.4" /> 
    </tran:payloadManifest> 
    <wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" 
    mustUnderstand="1"> 
     <u:Timestamp xmlns:u="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" 
     Id="timestamp" u:Id="timestamp"> 
     <u:Created>2012-05-30T16:39:39Z</u:Created> 
     <u:Expires>2012-05-30T16:44:39Z</u:Expires> 
     </u:Timestamp> 
     <wsse:BinarySecurityToken xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" 
     ValueType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-x509-token-profile-1.0#X509v3" 
     EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary" 
     wsu:Id="binary_security_token"> 
     removed</wsse:BinarySecurityToken> 
     <EncryptedKey xmlns="http://www.w3.org/2001/04/xmlenc#"> 
     <EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-1_5" /> 
     <KeyInfo xmlns="http://www.w3.org/2000/09/xmldsig#"> 
      <wsse:SecurityTokenReference> 
      <wsse:KeyIdentifier ValueType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-x509-token-profile-1.0#X509SubjectKeyIdentifier" 
      EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary"> 
      4qEuhS3IWjReFLSSCOcVoN6Ywzo=</wsse:KeyIdentifier> 
      </wsse:SecurityTokenReference> 
     </KeyInfo> 
     <CipherData> 
      <CipherValue> 
      removed</CipherValue> 
     </CipherData> 
     <ReferenceList> 
      <DataReference URI="#encrypt" /> 
     </ReferenceList> 
     </EncryptedKey> 
     <Signature xmlns="http://www.w3.org/2000/09/xmldsig#"> 
     <SignedInfo> 
      <CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#" /> 
      <SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1" /> 
      <Reference URI="#body"> 
      <Transforms> 
       <Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#" /> 
      </Transforms> 
      <DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" /> 
      <DigestValue>removeddigestvalue</DigestValue> 
      </Reference> 
      <Reference URI="#timestamp"> 
      <Transforms> 
       <Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#" /> 
      </Transforms> 
      <DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" /> 
      <DigestValue>removeddigestvalue</DigestValue> 
      </Reference> 
     </SignedInfo> 
     <SignatureValue> 
     removed</SignatureValue> 
     <KeyInfo> 
      <wsse:SecurityTokenReference> 
      <wsse:Reference URI="#binary_security_token" 
      ValueType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-x509-token-profile-1.0#X509v3" /> 
      </wsse:SecurityTokenReference> 
     </KeyInfo> 
     </Signature> 
    </wsse:Security> 
    </soap:Header> 
    <soap:Body xmlns:u="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" 
    id="body" u:Id="body"> 
    <EncryptedData xmlns="http://www.w3.org/2001/04/xmlenc#" 
    Id="encrypt" Type="http://www.w3.org/2001/04/xmlenc#Content"> 
     <EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes128-cbc" /> 
     <CipherData> 
     <CipherValue> 
     removed</CipherValue> 
     </CipherData> 
    </EncryptedData> 
    </soap:Body> 
</soap:Envelope> 
+0

請發表所需的肥皂 –

+0

@YaronNaveh的樣本 - 我已經更新了我的問題與我唯一的樣本。我可以看到它與我所製作的不同。如果你能弄清楚我需要做什麼,那麼瞭解「如何知道」如何解決這一問題也很有用。 –

回答

5

嘗試使用此配置:

 <customBinding> 
      <binding name="NewBinding0"> 
       <textMessageEncoding messageVersion="Soap11WSAddressing10" /> 
       <security authenticationMode="MutualCertificate" messageProtectionOrder="SignBeforeEncrypt" 
        messageSecurityVersion="WSSecurity10WSTrustFebruary2005WSSecureConversationFebruary2005WSSecurityPolicy11BasicSecurityProfile10"> 
        <secureConversationBootstrap /> 
       </security> 
       <httpTransport /> 
      </binding> 
     </customBinding> 
    </bindings> 

如果你想使用代碼,主要的區別是在版本中使用WSSEcurity10(甚至你你需要11個,這是兼容的)和messageProtectionOrder(這就是爲什麼你只看到加密而不是簽名)。

這可能需要進一步微調,讓我知道進展。

,因爲你使用的代碼還設置:

asbe.RecipientTokenParameters.X509ReferenceStyle=X509KeyIdentifierClauseType .SubjectKeyIdentifier 

和:

asbe.RecipientTokenParameters.InclusionMode = SecurityTokenInclusionMode.Never 
+0

他們給我以下信息 - 加密:算法:AES128-CBC 生成XML:EncryptionMethod Algorithm =「http://www.w3.org/2001/04/xmlenc#rsa-1_5 簽名:RSA/DSA 算法:rsa-sha1 以XML SignatureMethod生成算法= http://www.w3.org/2000/09/xmldsig#rsa-sha1 –

+0

謝謝,但這不會運行(提供的URI方案'https'無效;預期'http'。參數名稱:via)。 –

+0

我修改了我的代碼,使用Soap11WSAddressing10和WSSecurity10WSTrustFebruary2005WSSecureConversationFebruary2005WSSecurityPolicy11BasicSecurityProfile10,但現在得到了「400錯誤請求」 –