Nach den meisten Informationen, die ich über OpenID gelesen habe, scheint ein Browser erforderlich zu sein. Ich schreibe eine WCF-Anwendung und möchte OpenID als Authentifizierungsmethode verwenden, aber meine Anwendung ist keine Webanwendung. Ist es möglich, WCF und OpenID zusammen zu verwenden, ohne einen Webbrowser zu benötigen?
Antworten
Zu viele Anzeigen?Während OpenID in seiner Spezifikation mit der Unabhängigkeit von Cookies und dergleichen prahlen kann, weil die Spezifikation nicht wirklich vorschreibt, wie diese Dinge verwendet werden, habe ich in der Realität noch nie eine gute OpenID-Lösung für irgendetwas anderes als das Einloggen in eine Website gesehen, was wirklich ihr primärer Anwendungsfall ist.
Es gibt jedoch eine gute Möglichkeit, WCF und OpenID trotzdem zu verwenden. Fügen Sie OAuth zu der Mischung hinzu. Die DotNetOpenAuth Bibliothek enthält ein Beispiel, das zeigt, wie ein WCF-Client autorisiert werden kann, einen WCF-Dienst über OAuth aufzurufen, wobei der Benutzer auf der Dienstseite OpenID verwendet, um sich als Teil des Autorisierungsprozesses anzumelden.
Wenn sich Ihre WCF-Anwendung also "anmelden" muss, um den WCF-Dienst aufzurufen, ist dies Teil einer einmaligen Einrichtung:
- Die Anwendung öffnet einen Browser, in dem der Benutzer die WCF-Service-Website (den OAuth Service Provider) sieht.
- Der Benutzer meldet sich mit seiner OpenID an (der Benutzer kann aber auch bereits angemeldet sein, in diesem Fall kann er diesen Schritt überspringen)
- Der OAuth SP fragt den Nutzer: "Möchten Sie dieser [wcf app] den Zugriff auf diese Website gestatten?"
- Der Nutzer bejaht dies und schließt den Browser.
- Die WCF-App hat nun dank des OAuth-Protokolls Zugriff auf den WCF-Dienst.
Dies funktioniert, weil hinter den Kulissen, wenn der Benutzer über den Webbrowser "Ja" zum Dienst sagt, der WCF-Anwendung ein spezieller maschinenfreundlicher Berechtigungsnachweis zugewiesen wird, den sie bei jedem WCF-Dienstaufruf verwendet, ähnlich wie ein Benutzername/Passwort.
Sehen Sie sich die DotNetOpenAuth-Bibliothek an. Sie enthält das Beispiel und alles, was Sie benötigen, um dies zu bewerkstelligen.
Aus der Lektüre der OpenID-Authentifizierung 2.0-Spezifikation Ich scheine eine Antwort gefunden zu haben:
Das Protokoll erfordert weder JavaScript noch moderne Browser. Das Authentifizierungsschema lässt sich gut mit "AJAX"-ähnlichen Einrichtungen kombinieren. Dies bedeutet, dass ein Endnutzer seine Identität gegenüber einer Relying Party nachweisen kann, ohne seine aktuelle Webseite verlassen zu müssen.
Die OpenID-Authentifizierung verwendet nur Standard-HTTP(S)-Anfragen und -Antworten, so dass es erfordert keine besonderen Fähigkeiten des User-Agents oder anderer Client-Software . OpenID ist nicht an die Verwendung von Cookies oder einen anderen spezifischen Mechanismus der Sitzungsverwaltung von Relying Party oder OpenID Provider gebunden. Erweiterungen für User-Agents können die Interaktion mit dem Endbenutzer vereinfachen, sind aber nicht erforderlich, um das Protokoll zu verwenden.
Jetzt muss ich nur noch einen cleveren Weg finden, damit es mit einem WCF-basierten Partner funktioniert...
Nehmen Sie eine OpenIdMembershipProvider (vielleicht gibt es noch andere). Konfigurieren Sie dann die Nachrichtensicherheit in WCF mit Benutzername-Authentifizierung, dann können Sie den ASPNET MembershipProvider zur Authentifizierung Ihres Benutzers verwenden. Ich glaube nicht, dass man eine einfachere Lösung finden kann ;)