Verwenden von APIs zum Hinzufügen von Zertifizierungsstellen von Drittanbietern für SCEP zu Intune
In Microsoft Intune können Sie Zertifizierungsstellen von Drittanbietern hinzufügen und diese Zertifizierungsstellen zertifikate mit dem Simple Certificate Enrollment Protocol (SCEP) ausstellen und überprüfen lassen. Eine Drittanbieterzertifizierungsstelle hinzufügen bietet eine Übersicht über dieses Feature und beschreibt die Administratoraufgaben in Intune.
Es gibt auch einige Entwickleraufgaben, die eine Open-Source-Bibliothek verwenden, die Microsoft in GitHub.com veröffentlicht hat. Die Bibliothek enthält eine API, die:
- Überprüft das von Intune dynamisch generierte SCEP-Kennwort.
- Benachrichtigt Intune über die Zertifikate, die auf Geräten erstellt wurden, die SCEP-Anforderungen übermitteln.
Mithilfe dieser API kann Ihr SCEP-Server eines Drittanbieters in die Intune SCEP-Verwaltungslösung für MDM-Geräte integriert werden. Die Bibliothek abstrahiert Aspekte wie Authentifizierung, Dienststandort und die ODATA-Intune-Dienst-API von ihren Benutzern.
SCEP-Verwaltungslösung
Mithilfe von Intune erstellen Administratoren SCEP-Profile und weisen diese Profile dann MDM-Geräten zu. Die SCEP-Profile enthalten Parameter, z. B.:
- Die URL des SCEP-Servers
- Das vertrauenswürdige Stammzertifikat der Zertifizierungsstelle
- Zertifikatattribute und mehr
Geräten, die mit Intune einchecken, wird das SCEP-Profil zugewiesen und mit diesen Parametern konfiguriert. Ein dynamisch generiertes SCEP-Anforderungskennwort wird von Intune erstellt und dann dem Gerät zugewiesen.
Diese Herausforderung enthält Folgendes:
- Das dynamisch generierte Anforderungskennwort
- Die Details zu den Parametern, die in der Zertifikatsignieranforderung (Certificate Signing Request, CSR) erwartet werden, die das Gerät an den SCEP-Server ausgibt
- Die Ablaufzeit der Herausforderung
Intune verschlüsselt diese Informationen, signiert das verschlüsselte Blob und packt diese Details dann in das SCEP-Anforderungskennwort.
Geräte, die den SCEP-Server kontaktieren, um ein Zertifikat anzufordern, geben dann dieses SCEP-Abfragekennwort. Der SCEP-Server sendet die CSR und das verschlüsselte SCEP-Anforderungskennwort zur Überprüfung an Intune. Dieses Anforderungskennwort und die CSR müssen die Überprüfung bestehen, damit der SCEP-Server ein Zertifikat für das Gerät ausstellen kann. Wenn eine SCEP-Herausforderung überprüft wird, werden die folgenden Überprüfungen durchgeführt:
- Überprüft die Signatur des verschlüsselten Blobs.
- Überprüft, ob die Abfrage nicht abgelaufen ist.
- Überprüft, ob das Profil weiterhin auf das Gerät ausgerichtet ist
- Überprüft, ob die vom Gerät in der CSR angeforderten Zertifikateigenschaften mit den erwarteten Werten übereinstimmen.
Die SCEP-Verwaltungslösung umfasst auch die Berichterstellung. Ein Administrator kann Informationen zur Bereitstellung status des SCEP-Profils und zu den Zertifikaten abrufen, die für die Geräte ausgestellt wurden.
Integration in Intune
Der Code für die Integration der Bibliothek in die Intune SCEP steht im GitHub-Repository Microsoft/Intune-Resource-Access zum Download zur Verfügung.
Die Integration der Bibliothek in Ihre Produkte umfasst die folgenden Schritte. Diese Schritte erfordern Kenntnisse zum Arbeiten mit GitHub-Repositorys und zum Erstellen von Projektmappen und Projekten in Visual Studio.
Registrieren, um Benachrichtigungen aus dem Repository zu erhalten
Klonen oder Herunterladen des Repositorys
Navigieren Sie im Ordner (https://github.com/Microsoft/Intune-Resource-Access/tree/develop/src/CsrValidation) zu der benötigten Bibliotheksimplementierung
\src\CsrValidation
.Erstellen Sie die Bibliothek mithilfe der Anweisungen in der INFODATEI.
Einschließen der Bibliothek in das Projekt, das Ihren SCEP-Server erstellt
Führen Sie die folgenden Aufgaben auf dem SCEP-Server aus:
- Ermöglichen Sie es dem Administrator, die Azure-Anwendung-ID, Azure-Anwendung Schlüssel und Mandanten-ID (in diesem Artikel) zu konfigurieren, die die Bibliothek für die Authentifizierung verwendet. Administratoren sollten berechtigt sein, den Azure-Anwendung-Schlüssel zu aktualisieren.
- Identifizieren von SCEP-Anforderungen, die ein Intune generiertes SCEP-Kennwort enthalten
- Verwenden der API-Bibliothek "Anforderung überprüfen", um Intune generierten SCEP-Kennwörter zu überprüfen
- Verwenden Sie die Bibliotheksbenachrichtigungs-APIs, um Intune über Zertifikate zu benachrichtigen, die für SCEP-Anforderungen mit den Intune generierten SCEP-Kennwörtern ausgestellt wurden. Informieren Sie Intune auch über Fehler, die bei der Verarbeitung dieser SCEP-Anforderungen auftreten können.
- Vergewissern Sie sich, dass der Server genügend Informationen protokolliert, um Administratoren bei der Problembehandlung zu unterstützen.
Abschließen von Integrationstests (in diesem Artikel) und Beheben von Problemen
Geben Sie dem Kunden eine schriftliche Anleitung, in der Folgendes erläutert wird:
- Wie der SCEP-Server im Microsoft Intune Admin Center integriert werden muss
- Abrufen des Azure-Anwendung-Bezeichners und Azure-Anwendung Schlüssels, die zum Konfigurieren der Bibliothek erforderlich sind
Integrieren eines SCEP-Servers in Azure
Für die Authentifizierung bei Intune benötigt der SCEP-Server eine Azure-Anwendung-ID, einen Azure-Anwendung-Schlüssel und eine Mandanten-ID. Der SCEP-Server muss auch für den Zugriff auf die Intune-API autorisiert werden.
Um diese Daten abzurufen, meldet sich der SCEP-Serveradministrator beim Azure-Portal an, registriert die Anwendung, erteilt der Anwendung sowohl die Berechtigung Microsoft Intune API\SCEP-Überprüfung als auch die Berechtigung Application.Read.All, erstellt einen Schlüssel für die Anwendung und lädt dann die Anwendungs-ID, den zugehörigen Schlüssel und die Mandanten-ID herunter.
Anleitungen zum Registrieren einer Anwendung und zum Abrufen der IDs und Schlüssel finden Sie unter Verwenden des Portals zum Erstellen einer Microsoft Entra Anwendung und eines Dienstprinzipals für den Zugriff auf Ressourcen.
Java-Bibliotheks-API
Die Java-Bibliothek wird als Maven-Projekt implementiert, das seine Abhängigkeiten abruft, wenn es erstellt wird. Die API wird von der -Klasse unter dem com.microsoft.intune.scepvalidation
IntuneScepServiceClient
-Namespace implementiert.
IntuneScepServiceClient-Klasse
Die IntuneScepServiceClient
-Klasse enthält die Methoden, die vom SCEP-Dienst verwendet werden, um SCEP-Kennwörter zu überprüfen, Intune über erstellte Zertifikate zu benachrichtigen und Fehler aufzulisten.
IntuneScepServiceClient-Konstruktor
Signatur:
IntuneScepServiceClient(
Properties configProperties)
Beschreibung:
Instanziiert und konfiguriert ein IntuneScepServiceClient
-Objekt.
Parameter:
- configProperties : Eigenschaftenobjekt mit Clientkonfigurationsinformationen
Die Konfiguration muss die folgenden Eigenschaften enthalten:
- AAD_APP_ID="Die während des Onboardingprozesses erhaltene Azure-Anwendung-ID"
- AAD_APP_KEY="Der während des Onboardingprozesses erhaltene Azure-Anwendung-Schlüssel"
- TENANT="Die Mandanten-ID, die während des Onboardingprozesses abgerufen wurde"
- PROVIDER_NAME_AND_VERSION="Informationen, die zur Identifizierung Ihres Produkts und seiner Version verwendet werden"
Wenn Ihre Lösung einen Proxy mit oder ohne Authentifizierung erfordert, können Sie die folgenden Eigenschaften hinzufügen:
- PROXY_HOST="Der Host, auf dem der Proxy gehostet wird."
- PROXY_PORT="Der Port, an dem der Proxy lauscht."
- PROXY_USER="Der Benutzername, der verwendet werden soll, wenn der Proxy die Standardauthentifizierung verwendet."
- PROXY_PASS="Das Kennwort, das verwendet werden soll, wenn der Proxy die Standardauthentifizierung verwendet."
Löst Folgendes aus:
- IllegalArgumentException : Wird ausgelöst, wenn der Konstruktor ohne ein ordnungsgemäßes Eigenschaftsobjekt ausgeführt wird.
Wichtig
Es empfiehlt sich, eine instance dieser Klasse zu instanziieren und zum Verarbeiten mehrerer SCEP-Anforderungen zu verwenden. Dadurch wird der Aufwand reduziert, da Authentifizierungstoken und Dienststandortinformationen zwischengespeichert werden.
Sicherheitshinweise
Der SCEP-Serverimplementierer muss die in den Konfigurationseigenschaften eingegebenen Daten, die im Speicher gespeichert werden, vor Manipulation und Offenlegung schützen. Es wird empfohlen, die richtigen ACLs und Verschlüsselung zu verwenden, um die Informationen zu schützen.
ValidateRequest-Methode
Signatur:
void ValidateRequest(
String transactionId,
String certificateRequest)
Beschreibung:
Überprüft eine SCEP-Zertifikatanforderung.
Parameter:
- transactionId: Die SCEP-Transaktions-ID
- certificateRequest : DER-codierte PKCS #10 Certificate Request Base64-codiert als Zeichenfolge
Löst Folgendes aus:
- IllegalArgumentException : Wird ausgelöst, wenn mit einem ungültigen Parameter aufgerufen wird.
- IntuneScepServiceException : Wird ausgelöst, wenn festgestellt wird, dass die Zertifikatanforderung ungültig ist.
- Ausnahme : Wird ausgelöst, wenn ein nicht erwarteter Fehler auftritt.
Wichtig
Von dieser Methode ausgelöste Ausnahmen sollten vom Server protokolliert werden. Beachten Sie, dass die IntuneScepServiceException
Eigenschaften detaillierte Informationen darüber enthalten, warum die Überprüfung der Zertifikatanforderung fehlgeschlagen ist.
Sicherheitshinweise:
- Wenn diese Methode eine Ausnahme auslöst, darf der SCEP-Server kein Zertifikat für den Client ausstellen.
- Fehler bei der Überprüfung von SCEP-Zertifikatanforderungen können auf ein Problem in der Intune-Infrastruktur hinweisen. Oder sie könnten angeben, dass ein Angreifer versucht, ein Zertifikat zu erhalten.
SendSuccessNotification-Methode
Signatur:
void SendSuccessNotification(
String transactionId,
String certificateRequest,
String certThumbprint,
String certSerialNumber,
String certExpirationDate,
String certIssuingAuthority)
Beschreibung:
Benachrichtigt Intune, dass im Rahmen der Verarbeitung einer SCEP-Anforderung ein Zertifikat erstellt wird.
Parameter:
- transactionId: Die SCEP-Transaktions-ID
- certificateRequest : DER-codierte PKCS #10 Certificate Request Base64-codiert als Zeichenfolge
- certThumprint : SHA1-Hash des Fingerabdrucks des bereitgestellten Zertifikats
- certSerialNumber : Seriennummer des bereitgestellten Zertifikats
- certExpirationDate : Ablaufdatum des bereitgestellten Zertifikats. Die Datum/Uhrzeit-Zeichenfolge sollte als WEB-UTC-Zeit (JJJJ-MM-TTThh:mm:sss.sssTZD) ISO 8601 formatiert werden.
- certIssuingAuthority : Name der Zertifizierungsstelle, die das Zertifikat ausgestellt hat
Löst Folgendes aus:
- IllegalArgumentException : Wird ausgelöst, wenn mit einem ungültigen Parameter aufgerufen wird.
- IntuneScepServiceException : Wird ausgelöst, wenn festgestellt wird, dass die Zertifikatanforderung ungültig ist.
- Ausnahme : Wird ausgelöst, wenn ein nicht erwarteter Fehler auftritt.
Wichtig
Von dieser Methode ausgelöste Ausnahmen sollten vom Server protokolliert werden. Beachten Sie, dass die IntuneScepServiceException
Eigenschaften detaillierte Informationen darüber enthalten, warum die Überprüfung der Zertifikatanforderung fehlgeschlagen ist.
Sicherheitshinweise:
- Wenn diese Methode eine Ausnahme auslöst, darf der SCEP-Server kein Zertifikat für den Client ausstellen.
- Fehler bei der Überprüfung von SCEP-Zertifikatanforderungen können auf ein Problem in der Intune-Infrastruktur hinweisen. Oder sie könnten angeben, dass ein Angreifer versucht, ein Zertifikat zu erhalten.
SendFailureNotification-Methode
Signatur:
void SendFailureNotification(
String transactionId,
String certificateRequest,
long hResult,
String errorDescription)
Beschreibung:
Benachrichtigt Intune, dass beim Verarbeiten einer SCEP-Anforderung ein Fehler aufgetreten ist. Diese Methode sollte nicht für Ausnahmen aufgerufen werden, die von den Methoden dieser Klasse ausgelöst werden.
Parameter:
- transactionId: Die SCEP-Transaktions-ID
- certificateRequest : DER-codierte PKCS #10 Certificate Request Base64-codiert als Zeichenfolge
- hResult : Win32-Fehlercode, der den aufgetretenen Fehler am besten beschreibt. Weitere Informationen finden Sie unter Win32-Fehlercodes.
- errorDescription: Beschreibung des aufgetretenen Fehlers
Löst Folgendes aus:
- IllegalArgumentException : Wird ausgelöst, wenn mit einem ungültigen Parameter aufgerufen wird.
- IntuneScepServiceException : Wird ausgelöst, wenn festgestellt wird, dass die Zertifikatanforderung ungültig ist.
- Ausnahme : Wird ausgelöst, wenn ein nicht erwarteter Fehler auftritt.
Wichtig
Von dieser Methode ausgelöste Ausnahmen sollten vom Server protokolliert werden. Beachten Sie, dass die IntuneScepServiceException
Eigenschaften detaillierte Informationen darüber enthalten, warum die Überprüfung der Zertifikatanforderung fehlgeschlagen ist.
Sicherheitshinweise:
- Wenn diese Methode eine Ausnahme auslöst, darf der SCEP-Server kein Zertifikat für den Client ausstellen.
- Fehler bei der Überprüfung von SCEP-Zertifikatanforderungen können auf ein Problem in der Intune-Infrastruktur hinweisen. Oder sie könnten angeben, dass ein Angreifer versucht, ein Zertifikat zu erhalten.
SetSslSocketFactory-Methode
Signatur:
void SetSslSocketFactory(
SSLSocketFactory factory)
Beschreibung:
Verwenden Sie diese Methode, um den Client darüber zu informieren, dass er bei der Kommunikation mit Intune die angegebene SSL-Socketfactory (anstelle der Standardeinstellung) verwenden muss.
Parameter:
- factory : Die SSL-Socketfactory, die der Client für HTTPS-Anforderungen verwenden soll.
Löst Folgendes aus:
- IllegalArgumentException : Wird ausgelöst, wenn mit einem ungültigen Parameter aufgerufen wird.
Hinweis
Die SSL Socket Factory muss bei Bedarf festgelegt werden, bevor die anderen Methoden dieser Klasse ausgeführt werden.
Integrationstests
Überprüfen und Testen, dass Ihre Lösung ordnungsgemäß in Intune integriert ist, ist ein Muss. Im Folgenden finden Sie eine Übersicht über die Schritte:
- Richten Sie ein Intune Testkonto ein.
- Integrieren Sie den SCEP-Server in die Azure-Portal (in diesem Artikel).
- Konfigurieren Sie den SCEP-Server mit den IDs und dem Schlüssel, die beim Onboarding Ihres SCEP-Servers erstellt wurden.
- Registrieren Sie Geräte , um die Szenarien in der Szenariotestmatrix zu testen.
- Erstellen Sie ein vertrauenswürdiges Stammzertifikatprofil für Ihre Testzertifizierungsstelle.
- Erstellen Sie SCEP-Profile, um die in der Szenariotestmatrix aufgeführten Szenarien zu testen.
- Weisen Sie die Profile Benutzern zu, die ihre Geräte registriert haben.
- Warten Sie, bis die Geräte mit Intune synchronisiert wurden. Oder synchronisieren Sie die Geräte manuell.
- Vergewissern Sie sich, dass das vertrauenswürdige Stammzertifikat und die SCEP-Profile auf den Geräten bereitgestellt werden.
- Vergewissern Sie sich, dass das vertrauenswürdige Stammzertifikat auf allen Geräten installiert ist.
- Vergewissern Sie sich, dass die SCEP-Zertifikate für die zugewiesenen Profile auf allen Geräten installiert sind.
- Vergewissern Sie sich, dass die Eigenschaften der installierten Zertifikate mit den im SCEP-Profil festgelegten Eigenschaften übereinstimmen.
- Vergewissern Sie sich, dass die ausgestellten Zertifikate im Intune Admin Center ordnungsgemäß aufgeführt sind.
Siehe auch
- Hinzufügen einer Drittanbieterzertifizierungsstelle ( Übersicht)
- Setup Intune
- Geräteregistrierung
- Konfigurieren von SCEP-Zertifikatprofilen (das Setup von Microsoft NDES Server\Connector wird für dieses Szenario nicht verwendet)