Morgen jeder,
Ich habe versucht, eine Anwendung zu schreiben, die einige GETs von einem Remote-Webdienst ausführt, der eine Authentifizierung erfordert. Mein Hauptproblem ist, dass die Mehrheit dieser Remote-Server (und es gibt viele von ihnen) keine gültigen Zertifikate haben. Ich habe Code, um das ungültige Zertifikat zu akzeptieren und Code, um auf die Herausforderung mit dem korrekten uname & amp reagieren; pass (unten). Das Problem, das ich habe, ist, dass die beiden zusammen spielen. Ich kann keinen Weg finden, die Herausforderung sowohl NSURLCredential
s als auch eine Möglichkeit zu senden, die Rückrufe korrekt zu verketten. Wenn ich versuche, sie zu verketten, kann ich mein NSURLRequest
nicht zweimal didReceiveAuthenticationChallenge
aufrufen.
Irgendwelche Gedanken würden geschätzt werden!
Code für die Authentifizierung ...
%Vor% Sie können nur auf eine NSURLAuthenticationChallenge
mit einem Berechtigungsnachweis für diese Herausforderung antworten. Sie können bestimmen, welche Art von Challenge Sie erhalten haben:
Die möglichen Werte sind hier dokumentiert . Bei einem ungültigen Serverzertifikat lautet die Authentifizierungsmethode NSURLAuthenticationMethodServerTrust
. In Ihrem Code sollten Sie die Authentifizierungsmethode überprüfen und entsprechend reagieren.
Es ist kein Fehler, wenn Sie nicht jedes Mal beide Authentifizierungsprobleme bekommen. Sie können Anmeldeinformationen zwischenspeichern, wenn Sie sie erstellen. Wenn Sie dies tun, werden Sie nicht unbedingt erneut dazu aufgefordert.
Tags und Links iphone cocoa nsurlconnection nsurlrequest nsurlcredential