WCF - Sicherheit

Ein WCF-Dienst verfügt über ein robustes Sicherheitssystem mit zwei Sicherheitsmodi oder -stufen, sodass nur ein vorgesehener Client auf die Dienste zugreifen kann. Die Sicherheitsbedrohungen, die bei einer verteilten Transaktion häufig auftreten, werden von WCF weitgehend gemildert.

Wichtige Sicherheitsfunktionen

Der WCF-Dienst verfügt über vier wichtige Sicherheitsfunktionen, wie in der folgenden Abbildung dargestellt.

  • Authentication - Hier beschränkt sich die Authentifizierung nicht auf die Identifizierung des Absenders der Nachricht, sondern ist gegenseitig, dh die Authentifizierung des Nachrichtenempfängers ist erforderlich, um die Möglichkeit eines Mittelsmannangriffs auszuschließen.

  • Authorization- Dies ist der nächste Schritt eines WCF-Dienstes zur Gewährleistung der Sicherheit. Hier wird festgelegt, ob der Dienst den Anrufer autorisieren soll, weiterzumachen oder nicht. Obwohl die Autorisierung nicht von der Authentifizierung abhängig ist, folgt sie normalerweise der Authentifizierung.

  • Confidentiality- Der Informationsaustausch zwischen einem Anrufer und einem Dienst wird vertraulich behandelt, um seine Interpretation durch andere Personen einzuschränken, für die die Nachricht nicht bestimmt ist. Um dies zu ermöglichen, wird die Verschlüsselung zusammen mit einer Vielzahl anderer Mechanismen verwendet.

  • Integrity - Das letzte Schlüsselkonzept ist die Wahrung der Integrität, dh die Gewissheit, dass die Nachricht auf ihrem Weg vom Absender zum Empfänger von niemandem manipuliert wurde.

Sicherheitsmodus übertragen

WCF bietet die folgenden Übertragungssicherheitsmodi, um eine sichere Kommunikation zwischen einem Client und einem Server sicherzustellen. Die verschiedenen Übertragungssicherheitsmodi werden unten erwähnt.

  • None- Dieser Modus garantiert keinerlei Nachrichtensicherheit und der Dienst erhält keine Anmeldeinformationen über den Client. Dieser Modus ist sehr riskant, da er möglicherweise Manipulationen an Nachrichten zulässt und daher nicht empfohlen wird.

<wsHttpBinding>
   <binding name = "WCFSecurityExample">
      <security mode = "None"/>
   </binding>
</wsHttpBinding>
  • Transport- Dieser Modus ist der einfachste Weg, um eine sichere Nachrichtenübertragung mithilfe von Kommunikationsprotokollen wie TCP, IPC, Https und MSMQ zu erreichen. Dieser Modus ist effektiver, wenn die Übertragung von Punkt zu Punkt erfolgt und hauptsächlich in einer kontrollierten Umgebung, dh in Intranetanwendungen, verwendet wird.

<wsHttpBinding>
   <binding name = "WCFSecurityExample">
      <security mode = "Transport"/>
   </binding>
</wsHttpBinding>
  • Message- Der Sicherheitsmodus ermöglicht die gegenseitige Authentifizierung und bietet in hohem Maße Datenschutz, da die Nachrichten verschlüsselt sind und über http transportiert werden können, was nicht als sicheres Protokoll angesehen wird. Hier wird die Sicherheit durchgängig bereitgestellt, ohne zu berücksichtigen, wie viele Vermittler an einer Nachrichtenübertragung beteiligt sind und ob ein gesicherter Transport vorliegt oder nicht. Der Modus wird normalerweise von Internetanwendungen verwendet.

<wsHttpBinding>
   <binding name = "WCFSecurityExample">
      <security mode = "Message"/>
   </binding>
</wsHttpBinding>
  • Mixed - Dieser Sicherheitsmodus wird nicht häufig verwendet und die Clientauthentifizierung wird nur auf Clientebene angeboten.

<wsHttpBinding>
   <binding name = "WCFSecurityExample">
      <security mode = "TransportWithMessageCredential"/>
   </binding>
</wsHttpBinding>
  • Both- Dieser Sicherheitsmodus umfasst sowohl Transportsicherheit als auch Nachrichtensicherheit, um eine robuste Sicherheitsabdeckung zu bieten, führt jedoch häufig zu einer Überlastung der Gesamtleistung. Dieser wird nur von MSMQ unterstützt.

<netMsmqBinding>
   <binding name = "WCFSecurityExample">
      <security mode = "Both"/>
   </binding>
</netMsmqBinding>

Alle WCF-Bindungen mit Ausnahme von BasicHttpBinding verfügen standardmäßig über ein gewisses Maß an Übertragungssicherheit.

Sicherheitsstufe für Nachrichten

Die Sicherheit auf Nachrichtenebene hängt nicht von den WCF-Protokollen ab. Es wird mit Nachrichtendaten selbst verwendet, indem die Daten unter Verwendung eines Standardalgorithmus verschlüsselt werden. Für verschiedene Bindungen für die Nachrichtensicherheitsstufe stehen eine Reihe von Clientanmeldeinformationen zur Verfügung, die im Folgenden erläutert werden.

Client credentials for message level security in WCF

None- Hier wird die Nachricht durch Verschlüsselung gesichert, während keine Clientauthentifizierung durchgeführt wird, sodass ein anonymer Client auf den Dienst zugreifen kann. Mit Ausnahme von BasicHttpBinding unterstützen alle WCF-Bindungen diesen Client-Berechtigungsnachweis. Es ist jedoch zu beachten, dass für NetNamedPipeBinding dieser Client-Berechtigungsnachweis überhaupt nicht verfügbar ist.

  • Windows- Hier finden sowohl die Nachrichtenverschlüsselung als auch die Clientauthentifizierung für einen in Echtzeit angemeldeten Benutzer statt. Auch in diesem Fall ist NetNamedPipeBinding im Gegensatz zu allen anderen WCF-Bindungen nicht verfügbar, und BasicHttpBinding bietet keine Unterstützung.

  • UserName- Hier werden Nachrichten verschlüsselt und durch Anbieten eines Benutzernamens gesichert, und Clients werden authentifiziert, wenn sie ein Kennwort angeben müssen. BasicHttpBinding unterstützt genau wie die beiden oben genannten Client-Anmeldeinformationen UserName nicht und ist für NetNamedPipeBinding nicht verfügbar.

  • Certificate- Zusammen mit der Nachrichtenverschlüsselung erhalten sowohl der Client als auch der Dienst eine Authentifizierung mit Zertifikat. Dieser Client-Berechtigungsnachweis ist verfügbar und wird von allen WCF-Bindungen mit Ausnahme von NetNamedPipeBinding unterstützt.

  • IssuedToken- Ausgestellte Token von einer Behörde wie Cardspace werden zur Authentifizierung der Nachrichten verwendet. Hier wird auch die Verschlüsselung von Nachrichten durchgeführt.

Der folgende Code zeigt, wie Clientanmeldeinformationen in der Sicherheitsstufe / im Sicherheitsmodus für WCF-Nachrichten konfiguriert werden.

<netTcpBinding>
   <binding name = "WCFMessageSecurityExample">
      <security mode = "Message">
         <message clientCredentialType = "None"/>
      </security>   
   </binding>
</netTcpBinding>

<netMsmqBinding>...</netMsmqBinding>
</bindings>
<behaviors>...</behaviors>

Hierbei ist zu beachten, dass der Transportsicherheitsmodus einen Vorteil gegenüber der Nachrichtensicherheitsstufe hat, da ersterer schneller ist. Es erfordert keine zusätzliche Codierung und bietet Interoperabilitätsunterstützung und verringert somit nicht die Gesamtleistung.

Unter Sicherheitsgesichtspunkten ist der Nachrichtensicherheitsmodus jedoch robuster, protokollunabhängig und bietet End-to-End-Sicherheit.