Kurz: Konfigurace Azure Active Directory B2C s platformou Arkose Labs
V tomto kurzu se dozvíte, jak integrovat ověřování Azure Active Directory B2C (Azure AD B2C) s platformou Arkose Labs Arkose Protect. Produkty Arkose Labs pomáhají organizacím proti útokům na roboty, převzetí účtu a podvodnému otevírání účtů.
Požadavky
Abyste mohli začít, budete potřebovat:
- Předplatné Azure
- Pokud ho nemáte, můžete získat bezplatný účet Azure.
- Tenant Azure AD B2C propojený s předplatným Azure
- Účet Arkose Labs
- Pokud chcete požádat o ukázku, přejděte na arkoselabs.com.
Popis scénáře
Integrace produktů Arkose Labs zahrnuje následující komponenty:
- Arkose Protect Platform – služba pro ochranu před roboty a jiným automatizovaným zneužitím.
-
Azure AD registrace uživatele B2C – prostředí registrace, které používá platformu Arkose Labs
- Vlastní konektory HTML, JavaScript a API se integrují s platformou Arkose.
-
Azure Functions – Váš hostovaný koncový bod rozhraní API, který funguje s funkcí konektorů rozhraní API
- Toto rozhraní API ověří token relace Arkose Labs na straně serveru.
- Další informace najdete v přehledu Azure Functions.
Následující diagram znázorňuje integraci platformy Arkose Labs s Azure AD B2C.
- Uživatel se zaregistruje a vytvoří účet. Uživatel vybere Odeslat a zobrazí se výzva k vynucení Arkose Labs.
- Uživatel dokončí výzvu. Azure AD B2C odešle stav do Arkose Labs, aby vygeneroval token.
- Arkose Labs odešle token do Azure AD B2C.
- Azure AD B2C volá zprostředkující webové rozhraní API pro předání registračního formuláře.
- Registrační formulář se odešle do Arkose Labs k ověření tokenu.
- Arkose Labs odesílá výsledky ověření do zprostředkujícího webového rozhraní API.
- Rozhraní API odešle výsledek úspěšného nebo neúspěšného Azure AD B2C.
- Pokud je výzva úspěšná, odešle se Azure AD B2C registrační formulář, který dokončí ověření.
Žádost o ukázku z Arkose Labs
- Přejděte na arkoselabs.com a rezervujte si ukázku.
- Vytvořte účet.
- Přejděte na přihlašovací stránku portálu Arkose .
- Na řídicím panelu přejděte do nastavení webu.
- Vyhledejte svůj veřejný klíč a privátní klíč. Tyto informace použijete později.
Poznámka
Hodnoty veřejného a privátního klíče jsou ARKOSE_PUBLIC_KEY
a ARKOSE_PRIVATE_KEY
.
Viz Azure-Samples/active-directory-b2c-node-sign-up-user-flow-arkose.
Integrace s Azure AD B2C
Vytvoření vlastního atributu ArkoseSessionToken
Vytvoření vlastního atributu:
- Přihlaste se k Azure Portal a pak přejděte na Azure AD B2C.
- Vyberte Atributy uživatele.
- Vyberte Přidat.
- Jako název atributu zadejte ArkoseSessionToken .
- Vyberte Vytvořit.
Další informace: Definování vlastních atributů v Azure Active Directory B2C
Vytvoření toku uživatele
Tok uživatele slouží k registraci a přihlášení nebo registraci. Při registraci se zobrazí tok uživatele Arkose Labs.
Vytváření toků uživatelů a vlastních zásad v Azure Active Directory B2C Pokud používáte tok uživatele, použijte doporučeno.
V nastavení toku uživatele přejděte na Atributy uživatele.
Vyberte deklaraci identity ArkoseSessionToken .
Konfigurace vlastního html, JavaScriptu a rozložení stránky
- Přejděte na Azure-Samples/active-directory-b2c-node-sign-up-user-flow-arkose.
- Vyhledejte šablonu HTML se značkami JavaScriptu
<script>
. Ty dělají tři věci:
Načtěte skript Arkose Labs, který vykreslí jejich widget a provede ověření Arkose Labs na straně klienta.
extension_ArkoseSessionToken
Skryjte vstupní element a popisek odpovídající vlastnímu atributuArkoseSessionToken
.Když uživatel dokončí výzvu Arkose Labs, jeho odpověď se ověří a vygeneruje se token. Zpětné
arkoseCallback
volání ve vlastním JavaScriptu nastaví hodnotu na vygenerovanouextension_ArkoseSessionToken
hodnotu tokenu. Tato hodnota se odešle do koncového bodu rozhraní API.Poznámka
Přejděte na developer.arkoselabs.com, kde najdete pokyny na straně klienta. Postupujte podle pokynů k použití vlastního KÓDU HTML a JavaScriptu pro tok uživatele.
V Azure-Samples upravte selfAsserted.html soubor tak, aby
<ARKOSE_PUBLIC_KEY>
odpovídal hodnotě, kterou jste vygenerovali pro ověření na straně klienta.Hostujte stránku HTML na webovém koncovém bodu s podporou sdílení prostředků mezi zdroji (CORS).
Podpora CORS pro Azure Storage
Poznámka
Pokud máte vlastní kód HTML, zkopírujte a vložte elementy
<script>
na stránku HTML.V Azure Portal přejděte na Azure AD B2C.
Přejděte na Toky uživatelů.
Vyberte tok uživatele.
Vyberte Rozložení stránky.
Vyberte Rozložení registrační stránky místního účtu.
V části Použít obsah vlastní stránky vyberte ANO.
Do pole Použít obsah vlastní stránky vložte vlastní identifikátor URI HTML.
(Volitelné) Pokud používáte zprostředkovatele sociálních identit, opakujte postup pro registrační stránku účtu sociální sítě.
V toku uživatele přejděte na Vlastnosti.
Vyberte Povolit JavaScript.
Další informace: Povolení javascriptových verzí a rozložení stránek v Azure Active Directory B2C
Vytvoření a nasazení rozhraní API
V této části se předpokládá, že k nasazení Azure Functions používáte Visual Studio Code. K nasazení můžete použít Azure Portal, terminál nebo příkazový řádek.
Přejděte na Visual Studio Marketplace a nainstalujte Azure Functions pro Visual Studio Code.
Místní spuštění rozhraní API
- V editoru Visual Studio Code přejděte v levém navigačním panelu na rozšíření Azure.
- Vyberte složku Local Project (Místní projekt ) pro místní funkci Azure Functions.
- Stiskněte klávesu F5 nebo vyberte Ladit>Spustit ladění. Tento příkaz používá konfiguraci ladění vytvořenou funkcí Azure Functions.
- Azure Functions generuje soubory pro místní vývoj, instaluje závislosti a v případě potřeby nástroje Function Core.
- Na panelu Terminálu editoru Visual Studio Code se zobrazí výstup z nástroje Function Core.
- Po spuštění hostitele vyberte Alt a klikněte na místní adresu URL ve výstupu.
- Otevře se prohlížeč a spustí funkci.
- V průzkumníku Azure Functions klikněte pravým tlačítkem na funkci, aby se zobrazila adresa URL místně hostované funkce.
Přidání proměnných prostředí
Ukázka v této části chrání koncový bod webového rozhraní API při použití základního ověřování HTTP. Další informace najdete na stránce Internet Engineering Task Force RFC 7617: Základní ověřování.
Uživatelské jméno a heslo se ukládají jako proměnné prostředí, nikoli jako součást úložiště. Další informace najdete v tématu Kód a testování Azure Functions místně v souboru místního nastavení.
- V kořenové složce vytvořte soubor local.settings.json.
- Zkopírujte a vložte do souboru následující kód:
{
"IsEncrypted": false,
"Values": {
"AzureWebJobsStorage": "",
"FUNCTIONS_WORKER_RUNTIME": "node",
"BASIC_AUTH_USERNAME": "<USERNAME>",
"BASIC_AUTH_PASSWORD": "<PASSWORD>",
"ARKOSE_PRIVATE_KEY": "<ARKOSE_PRIVATE_KEY>",
"B2C_EXTENSIONS_APP_ID": "<B2C_EXTENSIONS_APP_ID>"
}
}
- BASIC_AUTH_USERNAME a BASIC_AUTH_PASSWORD jsou přihlašovací údaje k ověření volání rozhraní API do funkce Azure Functions. Vyberte hodnoty.
-
<
> ARKOSE_PRIVATE_KEY je tajný klíč na straně serveru, který jste vygenerovali na platformě Arkose Labs.
- Volá ověřovací rozhraní API na straně serveru Arkose Labs, aby ověřilo hodnotu
ArkoseSessionToken
vygenerovanou front-endem. - Viz Pokyny na straně serveru.
- Volá ověřovací rozhraní API na straně serveru Arkose Labs, aby ověřilo hodnotu
- < > B2C_EXTENSIONS_APP_ID je ID aplikace používané Azure AD B2C k ukládání vlastních atributů v adresáři.
Přejděte na Registrace aplikací.
Vyhledejte b2c-extensions-app.
V podokně Přehled zkopírujte ID aplikace (klienta).
-
Odeberte znaky.
Nasazení aplikace na web
Nasaďte funkci Azure Functions do cloudu. Další informace najdete v dokumentaci k Azure Functions.
Zkopírujte webovou adresu URL koncového bodu funkce Azure Functions.
Po nasazení vyberte možnost Nahrát nastavení .
Proměnné prostředí se nahrají do nastavení aplikace služby App Service. Další informace najdete v tématu Nastavení aplikace v Azure.
Poznámka
Aplikaci funkcí můžete spravovat. Další informace o vývoji editoru Visual Studio Code pro Azure Functions najdete v tématu Nasazení souborů projektu.
Konfigurace a povolení konektoru rozhraní API
Vytvořte konektor rozhraní API. Viz Přidání konektoru rozhraní API do toku uživatele registrace.
Povolte ho pro tok uživatele.
- Adresa URL koncového bodu – adresa URL funkce, kterou jste zkopírovali při nasazování funkce Azure Functions.
- Uživatelské jméno – uživatelské jméno, které jste definovali.
- Heslo – heslo, které jste definovali
V nastavení konektoru rozhraní API pro tok uživatele vyberte konektor rozhraní API, který se má vyvolat v části Před vytvořením uživatele.
Rozhraní API ověří
ArkoseSessionToken
hodnotu.
Testování toku uživatele
- Otevřete tenanta Azure AD B2C.
- V části Zásady vyberte Toky uživatelů.
- Vyberte vytvořený tok uživatele.
- Vyberte Spustit tok uživatele.
- V části Aplikace vyberte zaregistrovanou aplikaci (příklad je JWT).
- Jako Adresa URL odpovědi vyberte adresu URL pro přesměrování.
- Vyberte Spustit tok uživatele.
- Proveďte tok registrace.
- Vytvořte účet.
- Odhlaste se.
- Proveďte tok přihlášení.
- Vyberte Pokračovat.
- Objeví se hádanka Arkose Labs.
Zdroje informací
-
Azure-Samples/active-directory-b2c-node-sign-up-user-flow-arkose
- Vyhledání toku uživatele registrace Azure AD B2C
- přehled vlastních zásad Azure AD B2C
- Kurz: Vytváření toků uživatelů a vlastních zásad v Azure Active Directory B2C