2017-02-11 1 views
0

Ich schreibe eine native iOS-Anwendung für Xamarin und benutze nsurlsession, um einen HTTP-Endpunkt zu treffen, der mir die grundlegende Authentifizierungsproblematik gibt.Xamarin iOS: Problem mit DidReceiveChallenge während der Verwendung von NSURLSession API

Mein Problem ist, dass die DidReceiveChallenge Methode in meinem Delegat wird nicht aufgerufen werden:

Mein Code:

NSUrl url = new NSUrl("http://httpbin.org/basic-auth/test/test"); 
     NSUrlRequest request = new NSUrlRequest(url); 
     NSUrlSession session = null; 
     NSUrlSessionConfiguration myConfig = NSUrlSessionConfiguration.DefaultSessionConfiguration; 
     MySessionDelegate myDelegate = new MySessionDelegate(); 
     NSOperationQueue myQueue = new NSOperationQueue(); 
     session = NSUrlSession.FromConfiguration(myConfig, myDelegate, myQueue); 

     NSUrlSessionTask task = session.CreateDataTask(request, (data, response, error) => 
     { 
      Debug.WriteLine("data is"+data+"response is"+response+"error is "+error); 

     }); 


     task.Resume(); 

Meine Delegierten Klasse:

public class MySessionDelegate : NSUrlSessionDelegate 
{ 

    public override void DidReceiveChallenge(NSUrlSession session, NSUrlAuthenticationChallenge challenge, Action<NSUrlSessionAuthChallengeDisposition, NSUrlCredential> completionHandler) 
    { 
     Debug.WriteLine("challenge is"+challenge.ProtectionSpace.AuthenticationMethod); 
     base.DidReceiveChallenge(session, challenge, completionHandler); 
    } 


} 

Die Anwendungsausgabe Ich bin zur Zeit bekommen:

data isresponse is<NSHTTPURLResponse: 0x170437700> { URL: http://httpbin.org/basic-auth/nsharma/[email protected] } { status code: 401, headers { 
    "Access-Control-Allow-Credentials" = true; 
    "Access-Control-Allow-Origin" = "*"; 
    "Content-Length" = 0; 
    Date = "Sat, 11 Feb 2017 03:18:45 GMT"; 
    Server = nginx; 
    Via = "1.1 nas58.airwlab.com"; 
    "Www-Authenticate" = "Basic realm=\"Fake Realm\""; 
} }error is 

Wie Sie sehen können, kann ich die URL treffen, die eine 401 aufgrund grundlegender Auth-Challenge ausgibt. Normalerweise würde ich erwarten, dass der Flow die DidReceiveChallenge-Methode in meiner Delegate-Instanz aufruft, aber sie ruft sie nie auf und beendet die Ausführung.

Antwort

0

war die falsche Delegate-Klasse:

public class MySessionDelegate : NSUrlSessionDelegate{ 
public override void DidReceiveChallenge(NSUrlSession session, 
NSUrlSessionTask task, NSUrlAuthenticationChallenge challenge, 
Action<NSUrlSessionAuthChallengeDisposition, NSUrlCredential> completionHandler){ 

} 
} 
Verwandte Themen