開発Blog

intra-martでのシングルサインオン(SSO)について

投稿日:2010-02-10 更新日:

こんにちは、開発本部の大西です。

最近、非常にご質問の多い、シングルサインオン(SSO)の対応方法について、お話したいと思います。

個人的には、XSSやSQLインジェクションなどの脆弱性などのセキュリティに関して、いろいろと非常にうるさい世の中の癖に、一番重要なはずのログイン認証、特に、SSOに関しては、非常に緩く、SSOぐらい当たり前というのが納得がいかない、きょう、この頃です・・・。 

そんなことは置いておいて、intra-martには、SSO認証対応として、認証およびユーザ情報を外部で管理した場合に、ログイン認証処理を省略することが可能になる仕組みがあります。(Ver5.0以降)
つまり、intra-martでは、他システムで認証された情報を元に自動的にログインさせるということが可能になっています。

SSOにて、外部で認証した場合のイメージが、以下の図になります。
sso.png
ただし、以下の条件が必須になります。

    ・intra-martに対するリクエスト情報(「リクエスト・パラメータ」、「リクエスト・ヘッダ」「httpクッキー」など)として、「ユーザID」が必要。
    ・外部のシステムとintra-mart間でユーザIDが同じ
    ・以下の方法の場合、URIとログイングループが等しい。

このような場合、intra-martでの認証シーケンスのうち、下記の図にある赤丸のリクエストパラメータ解析を行っている部分を標準のものから、別のリクエスト情報を読取り、「ユーザID」を取得し、強制的にログインをさせるものに置き換えることで対応が可能です。


対応方法

(以下、intra-martがインストールされているディレクトリを<imart>とします。) 

1. access-security.xmlの変更

intra-martのServerManagerがインストールされているサーバの
<imart>/conf/access-security.xml を
[code:xml]

jp.co.intra_mart.foundation.security.certification.StandardRequestAnalyzer

jp.co.intra_mart.foundation.security.certification.StandardRequestAnalyzer

[/code]

から
[code:xml]

jp.co.intra_mart.foundation.security.certification.SSORequestAnalyzer

jp.co.intra_mart.foundation.security.certification.SSORequestAnalyzer

[/code]

に変更してください。

2. SSORequestAnalyzerの作成

以下のサンプルを参考に、<imart>doc/imart/WEB-INF/classes/jp/co/intra_mart/foundation/security/certification/SSORequestAnalyzer を作成してください。
[code:java]
public LoginRequestInfo parseRequest(LoginRequestInfo loginInfo, HttpServletRequest request) {
// 情報初期化
//loginInfo.setUser(StringUtil.EMPTY_STRING);
loginInfo.setPassword(StringUtil.EMPTY_STRING);
Cookie[] cookies = request.getCookies();
String cookie = null;
for (int i = 0; cookies != null && i 0) {
loginInfo.setUser(comids[0]);
}
if (comids.length > 1) {
loginInfo.setLoginGroup(comids[1]);
}
// ここに来れば認証は終了しています。
loginInfo.setDoneCertification(true);
// SSOログアウトURLが存在するなら、初期URLに設定します。
if(this.ssoLogoutUrl.length() > 0) {
loginInfo.setInitialUrl(this.ssoLogoutUrl);
}
break;
}
}
return loginInfo;
}
[/code]
上記サンプルは、IM-SSOを利用時のサンプルコードで、この場合、クッキー情報から「ユーザーID」を取得して、UserInfo情報へ「ユーザID」を設定します。(5行目~32行目まで)

認証元のシステムから「ユーザID」が「httpクッキー」で送られてくる場合は、上記処理を参考に修正してください。
「リクエスト・パラメータ」の場合は、request.getParamter()で「ユーザID」を取得して、UserInfo情報へ「ユーザID」を設定してください。
「リクエスト・ヘッダ」の場合は、request.getHeader()で「ユーザID」を取得して、UserInfo情報へ「ユーザID」を設定してください。

※上記サンプルは、製品情報ダンロードページの「アクセスセキュリティ機能のソース」に含まれています。

このように、SSO認証用の専用のモジュールに置き換えることにより、SSO対応ができるようになります。ログイン認証の処理は、いろいろと工夫することにより、SSOだけでなく、各システムのいろいろな要件に対応することができますので、いろいろと試してみてください。

-開発Blog
-

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

no image

Forma関数で条件式を書く

IM-FormaDesignerの画面アイテム「関数」を利用して式を記述できますが、まもなくリリース予定のパッチ2よりAND演算・OR演算の論理演算関数や比較演算子を使えるようになります。 これにより …

no image

EWS2017 「業務への適用イメージがすぐに湧く!  魔法の業務ロジック作成ツール『IM-LogicDesigner』実用例 10本勝負!」講演内容のご紹介

この記事では、EWS2017 Technology Track「業務への適用イメージがすぐに湧く!  魔法の業務ロジック作成ツール『IM-LogicDesigner』実用例 10本勝負!」での講演内容 …

no image

Accel Platformのつくりかた。

先日開催させていただきました弊社イベントEnterprise Web Solution 2013のテクニカルセッションにおいて、「Accel Platformのつくりかた。」という題名で、i …

no image

[IM-Workflow Version 7.2 Patch01] をリリースしました。

2010年7月30日に、[IM-Workflow Version 7.2 Patch01] をリリースしました。 通常、パッチリリースは不具合等の修正を目的としています。 そのため、パッチで …

no image

第4回Solr勉強会 資料公開しました

開発本部の清(せい)です。 11/19に開催された、第4回Solr勉強会の資料です。 Solrを利用したIM-ContentsSearchの製品紹介と、コンサルティンググループ所属時に導入したお客様の …

まだデータがありません。

RSSRSSRSSRSS