26

基本認証を使用して、ローカルでホストされている 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");

「承認」のみが取り除かれている/欠落しているようです。

4

3 に答える 3

34

ヘッダーを「手動で」追加する代わりに、次のことを行います。

var client = new RestSharp.RestClient("https://localhost/MyService/MyService.svc/");
client.Authenticator = new HttpBasicAuthenticator("UserA", "123");
于 2013-07-20T14:03:27.513 に答える
14

ミラノの回答を使用して、REST サービス呼び出しを機能させました (GET を使用)

    Dim client2 As RestClient = New RestClient("https://api.clever.com")

    Dim request2 As RestRequest = New RestRequest("me", Method.GET)

    request2.AddParameter("Authorization", "Bearer " & j.access_token, ParameterType.HttpHeader)

    Dim response2 As IRestResponse = client2.Execute(request2)
    Response.Write("** " & response2.StatusCode & "|" & response2.Content & " **")

重要なのは、「Bearer」という単語の後にスペースがあることを確認することでしたが、これはどのタイプのカスタム トークン認証ヘッダーにも当てはまる可能性があります。

于 2016-09-14T15:29:29.733 に答える