基本認証を使用して、ローカルでホストされている WCF REST サービスを HTTPS 経由で呼び出そうとしています。
これは機能し、Authorization ヘッダーは問題なく通過し、すべてが満足しています。
ServicePointManager.ServerCertificateValidationCallback = ValidateServerCertficate;
var request = (HttpWebRequest)WebRequest.Create("https://localhost/MyService/MyService.svc/");
request.Method = "GET";
request.ContentType = "application/json";
request.Headers.Add(
System.Net.HttpRequestHeader.Authorization,
"Basic " + this.EncodeBasicAuthenticationCredentials("UserA", "123"));
WebResponse webResponse = request.GetResponse();
using (Stream webStream = webResponse.GetResponseStream())
{
if (webStream != null)
{
using (StreamReader responseReader = new StreamReader(webStream))
{
string response = responseReader.ReadToEnd();
}
}
}
ただし、RestSharp を使用しようとすると、Authorization ヘッダーがリクエストで通過しません。
ServicePointManager.ServerCertificateValidationCallback = ValidateServerCertficate;
var credentials = this.EncodeBasicAuthenticationCredentials("UserA", "123");
var client = new RestSharp.RestClient("https://localhost/MyService/MyService.svc/");
var restRq = new RestSharp.RestRequest("/");
restRq.Method = Method.GET;
restRq.RootElement = "/";
restRq.AddHeader("Authorization", "Basic " + credentials);
var restRs = client.Execute(restRq);
RestSharp メソッドの何が間違っていますか?
AddHeader メソッドが機能することは次の理由でわかっています。
restRq.AddHeader("Rum", "And Coke");
「承認」のみが取り除かれている/欠落しているようです。