data:image/s3,"s3://crabby-images/63c2c/63c2ca9e17c661ff3f1c48056a91054955909470" alt="見出し画像"
プリザンター.NET Core版×AppServiceでSAML認証してみる(SAML設定編)
よーやくここまでこれました。
プリザンターがSSL化できたのでAzure ADとSAMLの設定をしていきたいと思います。この記事もようやく終わりです。
終わるにあたりSAMLの設定自体はすぐ終わるんですが、それまでの準備が結構かかるなぁーという印象でした。
前回までの記事はこちら
参考にさせていただいたもの
感謝です。
■プリザンター(.NET Framework)にSAML認証機能を追加する(公式)
https://pleasanter.org/manual/saml-net-framework
■プリザンター(.NET Core版)でSAML認証する
https://qiita.com/tatsuya_info/items/19c33558a853501e68b0
Azure ADにアプリケーションの登録
1.「AzureAD」→「エンタープライズアプリケーション(全てのアプリケーション)」→「新しいアプリケーション」をクリックします
data:image/s3,"s3://crabby-images/b73d7/b73d7d4d69181f4f83bfb7bb7f4b5dfb49f80910" alt="スクリーンショット 2022-02-22 21.32.36"
2.「独自のアプリケーション」の作成を選択し、「アプリの名前」を入力した後、「ギャラリーに見つからないその他アプリケーションを作成します」を選択して「作成」ボタンをクリックします。
data:image/s3,"s3://crabby-images/2163b/2163b28a7a420e19f2917c5bc5e02a96731bc146" alt="スクリーンショット 2022-02-22 21.36.24"
作成したアプリケーションの設定
1.作成したpleasanterアプリケーションに遷移するので「ユーザーとグループの割り当て」をクリックします。
data:image/s3,"s3://crabby-images/5d994/5d9941ea91d95121627ce5492ccf25a3169513ba" alt="スクリーンショット 2022-02-22 21.40.17"
2.「ユーザーとグループ」からプリザンターにアクセスさせたいユーザーを「選択」し「割り当て」をクリックします。
data:image/s3,"s3://crabby-images/29ffc/29ffcdf6aa614bc4f13774ecae28f615414f7fdb" alt="スクリーンショット 2022-02-22 21.43.45"
3.pleasanterアプリケーションに戻り「シングルサインオンの設定」をクリックし遷移した画面で「SAML」をクリックします。
data:image/s3,"s3://crabby-images/b71d3/b71d33ad2059cefc3cb8f39047c43760f0853658" alt="スクリーンショット 2022-02-22 21.46.45"
data:image/s3,"s3://crabby-images/f82eb/f82eb8c2e54e95dc22ba7dbb13744e408a71c306" alt="スクリーンショット 2022-02-22 21.48.25"
4.基本的なSAML構成の右上の「編集」をクリックします。
data:image/s3,"s3://crabby-images/0462b/0462b0207e7eb4dbb09b213e565f35c5175ecc1f" alt="スクリーンショット 2022-02-22 21.49.29"
5.「基本的なSAML構成」で、下記パラメータ入力し「保存」をクリックします。
識別子:https://プリザンターのURL/Saml2
応答URL:https://プリザンターのURL/Saml2/Acs
data:image/s3,"s3://crabby-images/cf767/cf76726af4a37a78e3a2804103939301407516ba" alt="スクリーンショット 2022-02-22 22.03.12"
6.「属性とクレーム」の右上の「編集」をクリックします。
data:image/s3,"s3://crabby-images/01cd1/01cd171d4d39c3ab90085b76188e672065de2e62" alt="スクリーンショット 2022-02-22 22.05.36"
7.「新しいクレームの追加」をクリックします。
data:image/s3,"s3://crabby-images/ad2b6/ad2b6c0c2d5722117a78200d076aa2a339827bc1" alt="スクリーンショット 2022-02-22 22.09.00"
8.「要求の管理」の画面で「名前」と「ソース属性」に下記パラメータを入力し「保存」をクリックします。
名前:Name
ソース属性:user.displayname
data:image/s3,"s3://crabby-images/0cb12/0cb127c9cb35ed40cc2d7e0c9020d94434dcfe4c" alt="スクリーンショット 2022-02-22 22.15.18"
SAMLパラメータの確認
プリザンターに設定するためのSAMLパラメータを確認します。
「SAML 署名証明書」の項目の中から「拇印」のパラメータをコピーし「証明書(Base64)」の証明書をダウンロードします。
data:image/s3,"s3://crabby-images/94628/9462813606835d2d7dd3725b31c8ca35b2b58378" alt="スクリーンショット 2022-02-22 22.18.48"
「Pleasnter のセットアップ」の項目の中から「ログイン URL」と「Azure AD 識別子」のパラメータをコピーします。
data:image/s3,"s3://crabby-images/4d02d/4d02df17048b657c2a74da2030f5d7ef3772c875" alt="スクリーンショット 2022-02-22 22.26.33"
AppServiceへのSAML署名証明書の追加
1.先ほどダウンロードした「証明書(Base64)」をAppServiceへ追加します。
「AppService」→TLS/SSL証明書」→「公開キー証明書」のアップロードを選択し「名前」に適当な名前を入力しダウンロードした証明書(Base64)の「CER証明書ファイル」をアップロードした後「アップロード」をクリックします。
data:image/s3,"s3://crabby-images/18996/18996b90411586d8b977ab687b45e18f51a6166d" alt="スクリーンショット 2022-02-22 23.39.59"
data:image/s3,"s3://crabby-images/16d03/16d03270ef59d32c3b833735177df4b9681f9589" alt="スクリーンショット 2022-02-22 23.46.29"
2.SAML署名証明書のストアが終わったら念の為AppServiceを再起動します。
「AppService」→「概要」→「再起動」をクリックしてアプリケーションの再起動を行います。
data:image/s3,"s3://crabby-images/aadbb/aadbb4d1d7e6c131ddea6e2a953bb233a18803f5" alt="スクリーンショット 2022-02-22 23.48.23"
プリザンターのSAML設定
1.VisalStudio2019を起動し「Implem.Pleasanter/App_Data/Parameters/Authentication.json」
のファイルを書き換えます。
data:image/s3,"s3://crabby-images/64d9b/64d9b8befe0f23fb955b372376a50eb621a57e86" alt="スクリーンショット 2022-02-22 23.27.22"
data:image/s3,"s3://crabby-images/2d635/2d6355bf16c88c5150416419b208a0a7f92a6e41" alt="スクリーンショット 2022-02-22 23.20.10"
{
//ProviderをSAMLに書き換えます
"Provider": "SAML",
"ServiceId": null,
"ExtensionUrl": null,
"RejectUnregisteredUser": false,
"LdapParameters": [
{
"LdapSearchRoot": null,
"LdapSearchProperty": "sAMAccountName",
"LdapSearchPattern": null,
"LdapLoginPattern": null,
"LdapAuthenticationType": null,
"NetBiosDomainName": null,
"LdapTenantId": 1,
"LdapDeptCode": null,
"LdapDeptCodePattern": null,
"LdapDeptName": null,
"LdapDeptNamePattern": null,
"LdapUserCode": null,
"LdapUserCodePattern": null,
"LdapFirstName": "givenName",
"LdapFirstNamePattern": null,
"LdapLastName": "sn",
"LdapLastNamePattern": null,
"LdapMailAddress": "mail",
"LdapMailAddressPattern": null,
"LdapSyncPageSize": 0,
"LdapSyncPatterns": [
"(&(ObjectCategory=User)(ObjectClass=Person))"
],
"LdapExcludeAccountDisabled": false,
"AutoDisable": false,
"AutoEnable": false,
"LdapSyncUser": null,
"LdapSyncPassword": null
}
],
"SamlParameters": {
"Attributes": {
"Name": "Name",
"UserCode": "UserCode",
"Birthday": "Birthday",
"Gender": "Gender",
"Language": "Language",
"TimeZone": "TimeZone",
"TenantManager": "TenantManager",
"DeptCode": "DeptCode",
"Dept": "Dept",
"Body": "Body",
"MailAddress": "{NameId}"
},
"SamlTenantId": 1,
"DisableOverwriteName": false,
"SPOptions": {
//SPOptionsのEntityIdをhttps://プリザンターのURL/Saml2に書き換えます。
"EntityId": "https://pleasanter.goetan.work/Saml2",
//SPOptionsのReturnUrlをhttps://プリザンターのURL/Users/SamlLoginに書き換えます。
"ReturnUrl": "https://pleasanter.goetan.work/Users/SamlLogin",
"AuthenticateRequestSigningBehavior": "IfIdpWantAuthnRequestsSigned",
"OutboundSigningAlgorithm": "http://www.w3.org/2001/04/xmldsig-more#rsa-sha256",
"MinIncomingSigningAlgorithm": "http://www.w3.org/2001/04/xmldsig-more#rsa-sha256",
"IgnoreMissingInResponseTo": false,
"PublicOrigin": null,
"ServiceCertificates": []
},
"IdentityProviders": [
{
//IdentityProvidersのEntityIdをAzure AD 識別子に書き換えます。
"EntityId": "https://sts.windows.net/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX/",
//IdentityProvidersのSignOnUrlをログインURLに書き換えます。
"SignOnUrl": "https://login.microsoftonline.com/XXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX/saml2",
"LogoutUrl": null,
"AllowUnsolicitedAuthnResponse": true,
"Binding": "HttpPost",
"WantAuthnRequestsSigned": false,
"DisableOutboundLogoutRequests": true,
"LoadMetadata": false,
"MetadataLocation": null,
"SigningCertificate": {
"StoreName": "CurrentUser",
"StoreLocation": "My",
"X509FindType": "FindByThumbprint",
//IdentityProvidersのSigningCertificateのFindValueを拇印に書き換えます。
"FindValue": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX"
}
}
]
}
}
2.書き換えが終わったら保存して一番上のメニューから「ビルド」→「ソリューションのリビルト」を選択しリビルドを行います。
data:image/s3,"s3://crabby-images/44d5c/44d5cdfc9ab84090918c1235ac53bfe25d30b354" alt="スクリーンショット 2022-02-22 23.28.45"
3.「Implem.Pleasanter.Parameter.NetCore」を右クリックして「発行」を選択します。
data:image/s3,"s3://crabby-images/3fdbc/3fdbc758ebfb357866059f6c53f61270dbaab1e2" alt="スクリーンショット 2022-02-22 23.30.47"
4.「発行」をクリックしてAzure AppServiceに公開します。
data:image/s3,"s3://crabby-images/b0af4/b0af44c192bf6afb1c2667dce488f5433d4782bb" alt="スクリーンショット 2022-02-22 23.32.45"
プリザンター側にユーザーを追加
ログイン画面にSSOログインのボタンが表示されているかと思います。そのままではSSOログインできないのでプリザンター側にユーザーを作成します。
1.Administratorの権限でログインしてください。
data:image/s3,"s3://crabby-images/207f6/207f6056df56f7e349c9c6733ff3b21d32084581" alt="スクリーンショット 2022-02-22 23.55.50"
2.プリザンターにログインし「管理」→「ユーザの管理」をクリックします。
data:image/s3,"s3://crabby-images/810bc/810bc949e419fd4ec540fd51b7e8798b5c769a63" alt="スクリーンショット 2022-02-22 23.57.34"
3.ユーザ-新規作成の画面で「新規作成」をクリックします。
「ログインID」「パスワード」「名前」「再入力」の項目を入力して「作成」をクリックします。
data:image/s3,"s3://crabby-images/6bd9a/6bd9a6d411fc3b6cdc058094cf13691c44f80fc8" alt="スクリーンショット 2022-02-23 0.00.57"
4.ログアウトして再度「SSOログイン」からログインするとAzure ADのクレデンシャルを利用してログインができます。
data:image/s3,"s3://crabby-images/e4036/e40365187869cd3da8d53ee70c48cdfccd9feca0" alt="スクリーンショット 2022-02-23 0.07.55"
検証
こんな感じでログインできます。
プリザンターにSSOログインできるよーになったー。
— GOETAN(小さな粒) (@GOETAN_GOETAN) February 13, 2022
AppService+Azure SQLで爆速構築
まぁハマりまくって2日かかったけどw pic.twitter.com/LBwWXVo4wq