При вызове SOAP WS мы должны указать wsa в заголовке SOAP.Это будет выглядеть так:
<env:Header xmlns:wsa="http://www.w3.org/2005/08/addressing">
<wsa:To env:mustUnderstand="true">_enpoint_</wsa:To>
<wsa:Action>_action_</wsa:Action>
</env:Header>
Мы автоматически сгенерировали прокси из wsdl, используя wsdl.exe
Чтобы избежать необходимости изменять автоматически сгенерированный код, я хотел добавитьновый частичный класс делает эту работу.Мне нравится этот подход , чтобы сделать это, поэтому я получил следующий код:
public partial class WebserviceProxy
{
private const string DEFAULT_WSA_NAMESPACE = "wsa";
private string _wsaNamespace;
public string WsaNamespace
{
get => _wsaNamespace ?? (_wsaNamespace = DEFAULT_WSA_NAMESPACE);
set => _wsaNamespace = value;
}
public string To { get; set; }
public string Action { get; set; }
protected override WebRequest GetWebRequest(Uri uri)
{
WebRequest request = base.GetWebRequest(uri);
request.Headers.Add($"{WsaNamespace}:{nameof(To)}", To);
request.Headers.Add($"{WsaNamespace}:{nameof(Action)}", Action);
return request;
}
}
Проблема в том, что этот код не работает, и я получаю исключение при вызове base.GetWebRequest(uri)
:
System.ArgumentException: Specified value has invalid HTTP Header characters.
Parameter name: name
at System.Net.WebHeaderCollection.CheckBadChars(String name, Boolean isHeaderValue)
at System.Net.WebHeaderCollection.Add(String name, String value)
at IcamWebserviceProxy.GetWebRequest(Uri uri)
Поскольку я не уверен, что нахожусь на правильном пути, я ищу здесь помощь.
Даже если упомянутая проблема решена, мне все равно придетсяукажите правильное пространство имен wsa в качестве атрибута Heder.
[edit] URI (проверено на конечной точке SoapUI, работающей на той же машине):
- uri {http://localhost:9000/mockDataExchangeAdminservice} System.Uri
AbsolutePath "/mockDataExchangeAdminservice" string
AbsoluteUri "http://localhost:9000/mockDataExchangeAdminservice" string
AllowIdn false bool
Authority "localhost:9000" string
DnsSafeHost "localhost" string
Fragment "" string
HasAuthority true bool
Host "localhost" string
HostNameType Dns System.UriHostNameType
HostType DnsHostType System.Uri.Flags
IdnHost "localhost" string
IsAbsoluteUri true bool
IsDefaultPort false bool
IsDosPath false bool
IsFile false bool
IsImplicitFile false bool
IsLoopback true bool
IsNotAbsoluteUri false bool
IsUnc false bool
IsUncOrDosPath false bool
IsUncPath false bool
LocalPath "/mockDataExchangeAdminservice" string
OriginalString "http://localhost:9000/mockDataExchangeAdminservice" string
OriginalStringSwitched false bool
PathAndQuery "/mockDataExchangeAdminservice" string
Port 9000 int
PrivateAbsolutePath "/mockDataExchangeAdminservice" string
Query "" string
Scheme "http" string
SecuredPathIndex 0 ushort
+ Segments {string[2]} string[]
+ Syntax {System.UriParser.BuiltInUriParser} System.UriParser {System.UriParser.BuiltInUriParser}
UserDrivenParsing false bool
UserEscaped false bool
UserInfo "" string
m_DnsSafeHost null string
m_Flags DnsHostType | AuthorityFound | LoopbackHost | NotDefaultPort | MinimalUriInfoSet | AllUriInfoSet | HostUnicodeNormalized | RestUnicodeNormalized System.Uri.Flags
+ m_Info {System.Uri.UriInfo} System.Uri.UriInfo
m_String "http://localhost:9000/mockDataExchangeAdminservice" string
+ m_Syntax {System.UriParser.BuiltInUriParser} System.UriParser {System.UriParser.BuiltInUriParser}
m_iriParsing true bool
m_originalUnicodeString null string
+ Static members
[edit2] Исключение выдается изHttpWebClientProtocol.GetWebRequest
при возврате webRequest (последняя строка):
protected override WebRequest GetWebRequest(Uri uri)
{
WebRequest webRequest = base.GetWebRequest(uri);
HttpWebRequest httpWebRequest = webRequest as HttpWebRequest;
if (httpWebRequest != null)
{
httpWebRequest.UserAgent = this.UserAgent;
httpWebRequest.AllowAutoRedirect = this.allowAutoRedirect;
httpWebRequest.AutomaticDecompression = this.enableDecompression ? DecompressionMethods.GZip : DecompressionMethods.None;
httpWebRequest.AllowWriteStreamBuffering = true;
httpWebRequest.SendChunked = false;
if (this.unsafeAuthenticatedConnectionSharing != httpWebRequest.UnsafeAuthenticatedConnectionSharing)
httpWebRequest.UnsafeAuthenticatedConnectionSharing = this.unsafeAuthenticatedConnectionSharing;
if (this.proxy != null)
httpWebRequest.Proxy = this.proxy;
if (this.clientCertificates != null && this.clientCertificates.Count > 0)
httpWebRequest.ClientCertificates.AddRange(this.clientCertificates);
httpWebRequest.CookieContainer = this.cookieJar;
}
return webRequest;
}