我想按照下面的示例从 c# 代码在 soap 请求的标头中传递安全令牌
我的服务网址http://nclpwntapp10188.devaonnet.aon.net:9089/ECMGenericWS/v2/ECMGenericWS/ECMGenericWS.wsdl
<soapenv:Envelope xmlns:ecm="http://www.ECMGenericWebService.ecm.aon.com/ECMGenericWS/" xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/">
<soapenv:Header>
<wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" soapenv:mustUnderstand="1">
<wsse:UsernameToken xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" wsu:Id="UsernameToken-8">
<wsse:Username>rrrrr</wsse:Username>
<wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordDigest">test</wsse:Password>
<wsse:Nonce EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary">f8nUe3YupTU5ISdCy3X9Gg==</wsse:Nonce>
<wsu:Created>2011-05-04T19:01:40.981Z</wsu:Created>
</wsse:UsernameToken>
</wsse:Security>
</soapenv:Header>
我尝试了以下解决方案,但它对我不起作用
如何将标头中的用户名/密码传递给 SOAP WCF 服务
我确信有这方面的库,但是如果您有权访问原始XML并希望自己解析它,则需要定义如下的类:
[XmlRoot(Namespace = "http://schemas.xmlsoap.org/soap/envelope/")]
public class Envelope
{
[XmlElement(Namespace = "http://schemas.xmlsoap.org/soap/envelope/")]
public Header Header { get; set; }
}
public class Header
{
[XmlElement(Namespace = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd")]
public Security Security { get; set; }
}
public class Security
{
[XmlAttribute(Namespace = "http://schemas.xmlsoap.org/soap/envelope/")]
public int mustUnderstand { get; set; }
[XmlElement(Namespace = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd")]
public UsernameToken UsernameToken { get; set; }
}
public class UsernameToken
{
[XmlAttribute(Namespace = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd")]
public string Id { get; set; }
public string Username { get; set; }
public Password Password { get; set; }
public Nonce Nonce { get; set; }
[XmlElement(Namespace = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd")]
public DateTime Created { get; set; }
}
public class Password
{
[XmlAttribute()]
public string Type { get; set; }
[XmlText]
public string Value { get; set; }
}
public class Nonce
{
[XmlAttribute()]
public string EncodingType { get; set; }
[XmlText]
public string Value { get; set; }
}
此时,您可以使用 XmlSerializer 实例对其进行反序列化,例如:
const string xml = "...";
using (var stream = new MemoryStream(Encoding.UTF8.GetBytes(xml)))
{
var serializer = new XmlSerializer(typeof(Envelope));
var envelope = (Envelope)serializer.Deserialize(stream);
// Do stuff with Envelope, Security, UsernameToken, etc here...
}
=====
编辑:Harpreet要求提供完整的代码示例,所以这里是下面的。
请注意,我还添加了示例 XML 中缺少的结束</soapenv:Envelope>
标记。
using System;
using System.IO;
using System.Text;
using System.Xml.Serialization;
// REF:
// How to pass security token in header of a soap request
// https://stackoverflow.com/questions/57194919/how-to-pass-security-token-in-header-of-a-soap-request/57195772
namespace Parse_security_token_in_header_of_a_soap_request
{
[XmlRoot(Namespace = "http://schemas.xmlsoap.org/soap/envelope/")]
public class Envelope
{
[XmlElement(Namespace = "http://schemas.xmlsoap.org/soap/envelope/")]
public Header Header { get; set; }
}
public class Header
{
[XmlElement(Namespace = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd")]
public Security Security { get; set; }
}
public class Security
{
[XmlAttribute(Namespace = "http://schemas.xmlsoap.org/soap/envelope/")]
public int mustUnderstand { get; set; }
[XmlElement(Namespace = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd")]
public UsernameToken UsernameToken { get; set; }
}
public class UsernameToken
{
[XmlAttribute(Namespace = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd")]
public string Id { get; set; }
public string Username { get; set; }
public Password Password { get; set; }
public Nonce Nonce { get; set; }
[XmlElement(Namespace = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd")]
public DateTime Created { get; set; }
}
public class Password
{
[XmlAttribute()]
public string Type { get; set; }
[XmlText]
public string Value { get; set; }
}
public class Nonce
{
[XmlAttribute()]
public string EncodingType { get; set; }
[XmlText]
public string Value { get; set; }
}
class Program
{
const string xml =
"<soapenv:Envelope xmlns:ecm="http://www.ECMGenericWebService.ecm.aon.com/ECMGenericWS/" xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/">rn" +
"<soapenv:Header>rn" +
"<wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" soapenv:mustUnderstand="1">rn" +
"<wsse:UsernameToken xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" wsu:Id="UsernameToken-8">rn" +
"<wsse:Username>rrrrr</wsse:Username>rn" +
"<wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordDigest" >test</wsse:Password>rn" +
"<wsse:Nonce EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary" >f8nUe3YupTU5ISdCy3X9Gg==</wsse:Nonce>rn" +
"<wsu:Created>2011-05-04T19:01:40.981Z</wsu:Created>rn" +
"</wsse:UsernameToken>rn" +
"</wsse:Security>rn" +
"</soapenv:Header>rn" +
"</soapenv:Envelope>rn";
static void Main(string[] args)
{
using (var stream = new MemoryStream(Encoding.UTF8.GetBytes(xml)))
{
var serializer = new XmlSerializer(typeof(Envelope));
var envelope = (Envelope)serializer.Deserialize(stream);
// Do stuff with Envelope here...
Console.WriteLine(envelope);
}
}
}
}