MSAL kullanarak Android'de uygulamalar arası SSO'ları etkinleştirme
Çoklu oturum açma (SSO), kullanıcıların kimlik bilgilerini yalnızca bir kez girmesini ve bu kimlik bilgilerinin uygulamalar arasında otomatik olarak çalışmasını sağlar. Kullanıcı deneyimini geliştirir ve kullanıcıların yönetmesi gereken parola sayısını azaltarak güvenliği artırır ve parola yorgunluğu ve ilişkili güvenlik açıkları riskini azaltır.
Microsoft kimlik platformu ve Microsoft Kimlik Doğrulama Kitaplığı (MSAL), uygulama paketinizde SSO'nun etkinleştirilmesine yardımcı olur. Aracı özelliğini etkinleştirerek SSO'yi tüm cihaz genelinde genişletebilirsiniz.
Bu nasıl yapılır makalesinde, müşterilerinize SSO sağlamak için uygulamanız tarafından kullanılan SDK'ları yapılandırmayı öğreneceksiniz.
Önkoşullar
Bu kılavuz, sizin bildiğinizi varsayar:
- Uygulamanızı sağlayın. Daha fazla bilgi için Android öğreticisinde uygulama oluşturma yönergelerine bakın
- Uygulamanızı Android için MSAL ile tümleştirme
SSO yöntemleri
Android için MSAL kullanan uygulamaların SSO'ya ulaşmanın iki yolu vardır:
Sistem tarayıcısı aracılığıyla
Cihaz genelinde SSO, hesap yönetimi ve Koşullu Erişim gibi avantajlar için bir aracı uygulaması kullanmanız önerilir. Ancak, kullanıcılarınızın ek uygulamaları indirmesini gerektirir.
Aracılı kimlik doğrulaması aracılığıyla SSO
Cihaz genelinde SSO'ya katılmak ve kurumsal Koşullu Erişim ilkelerini karşılamak için Microsoft'un kimlik doğrulama aracılarından birini kullanmanızı öneririz. Bir aracıyla tümleştirmek aşağıdaki avantajları sağlar:
- Cihaz SSO
- Koşullu Erişim:
- Intune Uygulama Koruması
- Cihaz Kaydı (Çalışma Alanına Katılma)
- Mobil Cihaz Yönetimi
- Cihaz Genelinde Hesap Yönetimi
- Android AccountManager ve Hesap Ayarları aracılığıyla
- "İş Hesabı" - özel hesap türü
Android'de Microsoft Kimlik Doğrulama Aracısı, Microsoft Authenticator, Intune Şirket Portalı ve Windows Bağlantısı uygulamalarında bulunan bir bileşendir.
Aşağıdaki diyagramda uygulamanız, MSAL ve Microsoft'un kimlik doğrulama aracıları arasındaki ilişki gösterilmektedir.
Aracılık faaliyeti yürüten uygulamaları yükleme
Aracı barındırma uygulamaları, cihaz sahibi tarafından herhangi bir zamanda uygulama mağazasından (genellikle Google Play Store) yüklenebilir. Ancak, bazı API'ler (kaynaklar) cihazların şunlar olmasını gerektiren Koşullu Erişim İlkeleri ile korunur:
- Kayıtlı (çalışma alanına katılmış) ve/veya
- Cihaz Yönetimine Kaydolundu veya
- Intune Uygulama Koruması'nda kayıtlı
Yukarıda belirtilen gereksinimlere sahip cihazda yüklü bir aracı uygulaması yoksa MSAL, uygulama etkileşimli olarak belirteç almaya çalıştığında kullanıcıya bir aracı uygulaması yüklemesini bildirir. Ardından uygulama, cihazı gerekli ilkeyle uyumlu hale getirme adımlarını izleyerek kullanıcıya yol gösterir. İlke gereksinimi yoksa veya kullanıcı Microsoft hesabıyla oturum açıyorsa Aracı uygulaması yüklemesi gerekli değildir.
Aracı yükleme ve kaldırmanın etkileri
Bir aracı yüklendiğinde
Bir aracı bir cihaza yüklendiğinde, ardışık tüm etkileşimli belirteç istekleri (acquireToken()
çağrılarına) MSAL tarafından yerel olarak değil, aracı tarafından işlenir. Daha önce MSAL'de mevcut olan herhangi bir SSO durumu aracı yazılım tarafından kullanılamaz. Sonuç olarak, kullanıcının yeniden kimlik doğrulaması yapması veya cihaz tarafından bilinen mevcut hesap listesinden bir hesap seçmesi gerekir.
Aracı yüklemek için kullanıcının yeniden oturum açması gerekmez. Yalnızca kullanıcının bir MsalUiRequiredException
sorunu çözmesi gerektiğinde bir sonraki istek aracıya gider.
MsalUiRequiredException
çeşitli nedenlerle atılabilir ve etkileşimli olarak çözülmesi gerekir. Örneğin:
- Kullanıcı hesabıyla ilişkili parolayı değiştirdi.
- Kullanıcının hesabı artık koşullu erişim ilkesini karşılamıyor.
- Kullanıcı, uygulamanın hesabıyla ilişkilendirilmesine ilişkin onayını iptal etti.
Birden çok aracı - Bir cihaza birden çok aracı yüklenirse, MSAL kimlik doğrulama işlemini tamamlamak için etkin aracıyı kendi başına tanımlar
Aracının kaldırıldığında
Yalnızca bir aracı barındırma uygulaması yüklüyse ve uygulama kaldırıldıysa kullanıcının yeniden oturum açması gerekir. Etkin aracı kaldırılarak hesap ve ilişkili belirteçler cihazdan kaldırılır.
Microsoft Authenticator, Intune Şirket Portalı veya Windows Bağlantısı kaldırılırsa, kullanıcıdan yeniden oturum açması istenebilir.
Bir aracı ile tümleştirme
Aracı için yeniden yönlendirme URI'si oluşturun
Broker ile uyumlu bir yönlendirme URI'si kaydetmeniz gerekir. Aracı için yeniden yönlendirme URI'sinde uygulamanızın paket adı ve uygulamanızın imzasının Base64 ile kodlanmış gösterimi bulunmalıdır.
Yeniden yönlendirme URI'sinin biçimi: msauth://<yourpackagename>/<base64urlencodedsignature>
Keytool kullanarak uygulamanızın imzalama anahtarlarını kullanarak Base64 kodlu imza karması oluşturabilir ve ardından bu karmayı kullanarak yeniden yönlendirme URI'nizi oluşturabilirsiniz.
Linux ve macOS:
keytool -exportcert -alias androiddebugkey -keystore ~/.android/debug.keystore | openssl sha1 -binary | openssl base64
Windows:
keytool -exportcert -alias androiddebugkey -keystore %HOMEPATH%\.android\debug.keystore | openssl sha1 -binary | openssl base64
Keytool ile imza karması oluşturduktan sonra Azure portalını kullanarak yeniden yönlendirme URI'sini oluşturun:
- Microsoft Entra yönetim merkezinde en az bir Bulut Uygulaması Yöneticisi olarak oturum açın.
- Birden çok kiracıya erişiminiz varsa, Üst menüdeki Ayarlar
simgesini kullanarak Dizinler + abonelikler menüsünden uygulama kaydını içeren kiracıya geçin.
- Kimlik>Uygulamalara>Uygulama kayıtlarına göz atın.
- Uygulamanızı seçin ve ardından Kimlik Doğrulaması>Platform Ekle>Android seçin.
- Açılan Android uygulamanızı yapılandırın bölmesinde, daha önce oluşturduğunuz İmza karması ve bir Paket adı girin.
- Yapılandır düğmesini seçin.
Yeniden yönlendirme URI'si sizin için oluşturulur ve Android yapılandırma bölmesinin Yeniden Yönlendirme URI'si alanında görüntülenir.
Uygulamanızı imzalama hakkında daha fazla bilgi için bkz . Android Studio Kullanıcı Kılavuzu'nda uygulamanızı imzalama.
MSAL'yi aracı kullanacak şekilde yapılandırma
Uygulamanızda bir aracı kullanmak için aracı yeniden yönlendirme işleminizi yapılandırdığınızı onaylamanız gerekir. Örneğin, MSAL yapılandırma dosyanıza aşağıdaki ayarları ekleyerek hem aracı etkin yeniden yönlendirme URI'nizi ekleyin hem de kaydettiğinizi belirtin:
"redirect_uri" : "<yourbrokerredirecturi>",
"broker_redirect_uri_registered": true
Aracıyla ilgili istisnalar
MSAL aracıyla iki şekilde iletişim kurar:
- Aracı bağlı hizmeti
- Android Hesap Yöneticisi
MSAL ilk olarak aracıya bağlı hizmeti kullanır çünkü bu hizmeti çağırmak herhangi bir Android izni gerektirmez. bağlı hizmete bağlama başarısız olursa, MSAL Android AccountManager API'sini kullanır. MSAL, uygulamanıza zaten "READ_CONTACTS"
izni verilmişse bunu yapar.
Eğer MsalClientException
hata kodu ile bir "BROKER_BIND_FAILURE"
alırsanız, iki seçenek vardır:
- Kullanıcıdan Microsoft Authenticator uygulaması ve Intune Şirket Portalı için güç iyileştirmesini devre dışı bırakmasını isteyin.
- Kullanıcıdan
"READ_CONTACTS"
iznini vermesini isteyin
Aracı entegrasyonunu doğrula
Aracı entegrasyonunun çalışıp çalışmadığı hemen belli olmayabilir, ancak kontrol etmek için aşağıdaki adımları kullanabilirsiniz.
- Android cihazınızda aracıyı kullanarak bir isteği tamamlayın.
- Android cihazınızdaki ayarlarda, kimlik doğrulaması yaptığınız hesaba karşılık gelen yeni oluşturulan bir hesabı arayın. Hesap İş hesabı türünde olmalıdır.
Testi tekrarlamak istiyorsanız hesabı ayarlardan kaldırabilirsiniz.
Sistem tarayıcısı aracılığıyla SSO
Android uygulamaları kimlik doğrulaması kullanıcı deneyimi için , sistem tarayıcısını veya Chrome Özel Sekmelerini kullanma WEBVIEW
seçeneğine sahiptir. Uygulama aracılı kimlik doğrulaması kullanmıyorsa, SSO'ya ulaşmak için yerel web görünümü yerine sistem tarayıcısını kullanması gerekir.
Yetkilendirme aracıları
Yetkilendirme aracıları için belirli bir strateji seçmek önemlidir ve uygulamaların özelleştirebileceği ek işlevleri temsil eder. 'WEBVIEW' kullanmanızı öneririz. Diğer yapılandırma değerleri hakkında daha fazla bilgi edinmek için (bkz. Android MSAL yapılandırma dosyasını anlama.
MSAL, bir WEBVIEW
veya sistem tarayıcısı kullanarak yetkilendirmeyi destekler. Aşağıdaki resimde, WEBVIEW
kullanarak, Özel Sekmeler ile veya Özel Sekmeler olmadan sistem tarayıcısının nasıl göründüğü gösterilmektedir.
SSO etkileri
Uygulama, aracılı kimlik doğrulaması ile uygulamayla tümleştirme yapmadan bir WEBVIEW
strateji kullanıyorsa, kullanıcılar cihazda veya yerel uygulamalarla web uygulamaları arasında çoklu oturum açma deneyimine sahip olmaz.
Uygulamalar, BROWSER
kullanarak yetkilendirme sağlamak için MSAL ile entegre edilebilir. WEBVIEW'den farklı olarak, BROWSER
çerez deposunu varsayılan sistem tarayıcısıyla paylaşır ve bu, web veya Özel Sekmelerle tümleştirilmiş diğer yerel uygulamalarla daha az oturum açmayı mümkün kılar.
Uygulama MSAL'yi Microsoft Authenticator, Intune Şirket Portalı veya Windows Bağlantısı gibi bir aracıyla kullanıyorsa, kullanıcılar uygulamalardan biriyle etkin oturum açmaları durumunda uygulamalar arasında SSO deneyimine sahip olabilir.
Not
Aracılı MSAL, WebView kullanır ve MSAL kitaplığını kullanan ve aracılı kimlik doğrulamasına katılan tüm uygulamalar için Çoklu Oturum Açma (SSO) sağlar. Aracıdan gelen SSO durumu, MSAL kullanmayan diğer uygulamalara genişletilmemiştir.
Web Görüntüleyici
Uygulama içi WebView'ı kullanmak için, MSAL'ye geçirilen uygulama yapılandırması JSON'sine aşağıdaki satırı yerleştirin:
"authorization_user_agent" : "WEBVIEW"
Kullanıcı, uygulama içinde WEBVIEW
kullanırken doğrudan uygulamada oturum açar. Belirteçler uygulamanın korumalı alanında tutulur ve uygulamanın çerez kutusunun dışında kullanılamaz. Sonuç olarak, uygulamalar Microsoft Authenticator uygulaması, Intune Şirket Portalı veya Windows Bağlantısı ile tümleştirilmediği sürece kullanıcı uygulamalar arasında SSO deneyimine sahip olamaz.
Ancak, WEBVIEW
oturum açma kullanıcı arabirimi için genel görünümü özelleştirme özelliği sağlar. Bu özelleştirmeyi yapma hakkında daha fazla bilgi için bkz . Android WebViews .
Tarayıcı
WebVIEW kullanmanızı öneririz, ancak tarayıcı ve özel sekme stratejisi kullanma seçeneği sunuyoruz. Özel yapılandırma dosyasında aşağıdaki JSON yapılandırmasını kullanarak bu stratejiyi açıkça belirtebilirsiniz:
"authorization_user_agent" : "BROWSER"
Cihazın tarayıcısı aracılığıyla SSO deneyimi sağlamak için bu yaklaşımı kullanın. MSAL, diğer yerel uygulamaların veya web uygulamalarının, MSAL tarafından ayarlanan kalıcı oturum tanımlama bilgisini kullanarak cihazda SSO gerçekleştirmesine olanak tanıyan paylaşılan bir cookie jar kullanır.
Tarayıcı seçimi yöntemi
MSAL'nin geniş Android telefon dizisinin her birinde kullanılacak tam tarayıcı paketini belirtmesi mümkün olmadığından, MSAL en iyi cihazlar arası SSO'ları sağlamaya çalışan bir tarayıcı seçimi buluşsal özelliği uygular.
MSAL öncelikle paket yöneticisinden varsayılan tarayıcıyı alır ve test edilmiş bir güvenli tarayıcı listesinde olup olmadığını denetler. Aksi takdirde MSAL, güvenli listeden varsayılan olmayan başka bir tarayıcı başlatmak yerine Webview'ı kullanmaya geri döner. Özel sekmeleri destekleyip desteklemediğinden bağımsız olarak varsayılan tarayıcı seçilir. Tarayıcı Özel Sekmeleri destekliyorsa, MSAL Özel Sekme'yi başlatır. Özel Sekmeler, uygulama WebView
içi bir görünüme ve kullanıma daha yakındır ve temel kullanıcı arabirimi özelleştirmesine izin verir. Daha fazla bilgi edinmek için bkz . Android'de Özel Sekmeler.
Cihazda tarayıcı paketi yoksa, MSAL WebView
uygulama içini kullanır. Cihaz varsayılan ayarı değiştirilmezse, SSO deneyiminden emin olmak için her oturum açma için aynı tarayıcı başlatılmalıdır.
Test Edilmiş Tarayıcılar
Aşağıdaki tarayıcılar, yapılandırma dosyasında belirtilene doğru şekilde yeniden yönlendirilip yönlendirilmediğini görmek için "redirect_uri"
test edilmiştir:
Cihaz | Yerleşik Tarayıcı | Chrome | Opera | Microsoft Edge | UC Browser | Firefox |
---|---|---|---|---|---|---|
Nexus 4 (API 17) | geçmek | geçmek | uygulanamaz | uygulanamaz | uygulanamaz | uygulanamaz |
Samsung S7 (API 25) | 1'i geç | geçmek | geçmek | geçmek | Başarısızlık | geçmek |
Vivo (API 26) | geçmek | geçmek | geçmek | geçmek | geçmek | Başarısız olmak |
Piksel 2 (API 26) | geçmek | geçmek | geçmek | geçmek | Başarısız | geçmek |
Oppo | geçmek | uygulanamaz2 | uygulanamaz | uygulanamaz | uygulanamaz | uygulanamaz |
OnePlus (API 25) | geçmek | geçmek | geçmek | geçmek | Başarısız olmak | geçmek |
Nexus (API 28) | geçmek | geçmek | geçmek | geçmek | Başarısızlık | geçmek |
MI | geçmek | geçmek | geçmek | geçmek | Başarısız | geçmek |
1Samsung'un yerleşik tarayıcısı Samsung Internet'tir.
2Varsayılan tarayıcı Oppo cihaz ayarı içinde değiştirilemez.
Sonraki adımlar
Android cihazlar için paylaşılan cihaz modu, birden çok çalışan tarafından kolayca paylaşılabilmesi için bir Android cihazı yapılandırmanıza olanak tanır.
Aracı uygulamaları hakkında daha fazla bilgi için aşağıdaki sayfalara gidin: