忍者ブログ

2025
01
18

[PR]

×

[PR]上記の広告は3ヶ月以上新規記事投稿のないブログに表示されています。新しい記事を書く事で広告が消えます。

2025/01/18 (Sat.)

2009
02
16

[Tomccat][SSO] Jossoデータベース管理化

基本的にはこれにならって修正する。


webapp/xxxに以下のようなcontext.xmlを置く。

<Context docbase="josso" path="josso" reloadable="true">
        <Resource
                name="jdbc/josso"
                auth="Container"
                type="javax.sql.DataSource"
                username="root"
                password=""
                driverClassName="org.gjt.mm.mysql.Driver"
                url="jdbc:mysql://localhost/josso"
                maxActive="4"
                maxWait="5000"
                maxIdle="2"
        />
</Context>




gateway install --persintence db でインストールしなかった場合は、josso-gateway-stores.xmlを以下のように修正する。



<?xml version="1.0" encoding="UTF-8"?>

<!--
  ~ JOSSO: Java Open Single Sign-On
  ~
  ~ Copyright 2004-2009, Atricore, Inc.
  ~
  ~ This is free software; you can redistribute it and/or modify it
  ~ under the terms of the GNU Lesser General Public License as
  ~ published by the Free Software Foundation; either version 2.1 of
  ~ the License, or (at your option) any later version.
  ~
  ~ This software is distributed in the hope that it will be useful,
  ~ but WITHOUT ANY WARRANTY; without even the implied warranty of
  ~ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  ~ Lesser General Public License for more details.
  ~
  ~ You should have received a copy of the GNU Lesser General Public
  ~ License along with this software; if not, write to the Free
  ~ Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
  ~ 02110-1301 USA, or see the FSF site: http://www.fsf.org.
  ~
  -->
<s:beans xmlns:s="http://www.springframework.org/schema/beans"
         xmlns:db-istore="urn:org:josso:db:identitystore"
         xmlns:memory-istore="urn:org:josso:memory:identitystore"
         xmlns:db-sstore="urn:org:josso:db:sessionstore"
         xmlns:memory-sstore="urn:org:josso:memory:sessionstore"
         xmlns:db-astore="urn:org:josso:db:assertionstore"
         xmlns:memory-astore="urn:org:josso:memory:assertionstore"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
        urn:org:josso:db:identitystore http://www.josso.org/schema/josso-db-identitystore.xsd
        urn:org:josso:memory:identitystore http://www.josso.org/schema/josso-memory-identitystore.xsd
        urn:org:josso:db:sessionstore http://www.josso.org/schema/josso-db-sessionstore.xsd
        urn:org:josso:memory:sessionstore http://www.josso.org/schema/josso-memory-sessionstore.xsd
        urn:org:josso:db:assertionstore http://www.josso.org/schema/josso-db-assertionstore.xsd
        urn:org:josso:memory:assertionstore http://www.josso.org/schema/josso-memory-assertionstore.xsd
        "
        >

    <!-- ===================================================================== -->
    <!-- JOSSO Identity Store, the id is very important because it is          -->
    <!-- referenced by the session manager and who knows where else            -->
    <!-- ===================================================================== -->
    <!--
    <db-istore:datasource-store id="josso-identity-store"
                      dsJndiName="java:/DefaultDS"
                      userQueryString="SELECT NAME FROM JOSSO_USER WHERE LOGIN = ?;"
                      rolesQueryString="SELECT ROLE FROM JOSSO_USER_ROLE WHERE LOGIN = ?;"
                      credentialsQueryString="SELECT LOGIN AS USERNAME, PASSWORD FROM JOSSO_USER WHERE LOGIN = ?;"
                      userPropertiesQueryString="SELECT NAME, VALUE FROM JOSSO_USER_PROPERTY WHERE LOGIN = ?;"
                      resetCredentialDml="UPDATE JOSSO_USER SET PASSWORD = ? WHERE LOGIN = ?;"
                      relayCredentialQueryString="SELECT LOGIN FROM JOSSO_USER WHERE #?# = ?;" />
    -->
    <db-istore:jdbc-store
                id="josso-identity-store"
                driverName="com.mysql.jdbc.Driver"
                connectionURL="jdbc:mysql://localhost:3306/josso"
                connectionName="root"
                connectionPassword=""
                userQueryString="SELECT LOGIN AS NAME FROM JOSSO_USER WHERE LOGIN = ?"
                rolesQueryString="SELECT NAME AS ROLE FROM JOSSO_USER_ROLE WHERE LOGIN = ?"
                credentialsQueryString="SELECT LOGIN AS USERNAME, PASSWORD FROM JOSSO_USER WHERE LOGIN = ?"
                userPropertiesQueryString="SELECT NAME, VALUE FROM JOSSO_USER_PROPERTY WHERE LOGIN = ?"
                resetCredentialDml="UPDATE JOSSO_USER SET PASSWORD = ? WHERE LOGIN = ?"
                relayCredentialQueryString="SELECT LOGIN FROM JOSSO_USER WHERE #?# = ?"
                />
    <!--
    <db-istore:jdbc-store
            id="josso-identity-store"
            driverName="org.hsqldb.jdbcDriver"
            connectionURL="jdbc:hsqldb:mem:jossodb"
            connectionName="sa"
            connectionPassword=""
            userQueryString="SELECT NAME FROM JOSSO_USER WHERE LOGIN = ?;"
            rolesQueryString="SELECT ROLE FROM JOSSO_USER_ROLE WHERE LOGIN = ?;"
            credentialsQueryString="SELECT LOGIN AS USERNAME, PASSWORD FROM JOSSO_USER WHERE LOGIN = ?;"
            userPropertiesQueryString="SELECT NAME, VALUE FROM JOSSO_USER_PROPERTY WHERE LOGIN = ?;"
            resetCredentialDml="UPDATE JOSSO_USER SET PASSWORD = ? WHERE LOGIN = ?;"
            relayCredentialQueryString="SELECT LOGIN FROM JOSSO_USER WHERE #?# = ?;"
            />
    -->

    <!--
    <memory-istore:memory-store id="josso-identity-store"
                            credentialsFileName="josso-credentials.xml"
                            usersFileName="josso-users.xml" s:scope="singleton" />
    -->


    <!-- ===================================================================== -->
    <!-- JOSSO Session Store, the id is very important because it is           -->
    <!-- referenced by the session manager and who knows where else            -->
    <!-- ===================================================================== -->
    <memory-sstore:memory-store id="josso-session-store"/>

    <!-- Chagne the store implementation if you want to use DB Assertion stores (useful for clustesr and failover) -->

    <!--
    <db-sstore:jdbc-store
            id="josso-session-store"
            driverName="org.hsqldb.jdbcDriver"
            connectionURL="jdbc:hsqldb:mem:jossodb"
            connectionName="sa"
            connectionPassword=""
            loadQuery="SELECT SESSION_ID, USERNAME, CREATION_TIME, LAST_ACCESS_TIME, ACCESS_COUNT, MAX_INACTIVE_INTERVAL, VALID FROM JOSSO_SESSION WHERE SESSION_ID = ?;"
            loadAllQuery="SELECT SESSION_ID, USERNAME, CREATION_TIME, LAST_ACCESS_TIME, ACCESS_COUNT, MAX_INACTIVE_INTERVAL, VALID FROM JOSSO_SESSION;"
            insertDml="INSERT INTO JOSSO_SESSION VALUES (?, ?, ?, ?, ?, ?, ?);"
            updateDml="UPDATE JOSSO_SESSION SET USERNAME = ?, CREATION_TIME = ?, LAST_ACCESS_TIME = ?, ACCESS_COUNT = ?, MAX_INACTIVE_INTERVAL = ?, VALID = ? WHERE SESSION_ID = ?;"
            sizeQuery="SELECT COUNT(1) FROM JOSSO_SESSION;"
            keysQuery="SELECT SESSION_ID FROM JOSSO_SESSION;"
            loadByUserNameQuery="SELECT SESSION_ID, USERNAME, CREATION_TIME, LAST_ACCESS_TIME, ACCESS_COUNT, MAX_INACTIVE_INTERVAL, VALID FROM JOSSO_SESSION WHERE USERNAME = ?;"
            loadByValidQuery="SELECT SESSION_ID, USERNAME, CREATION_TIME, LAST_ACCESS_TIME, ACCESS_COUNT, MAX_INACTIVE_INTERVAL, VALID FROM JOSSO_SESSION WHERE VALID = ?;"
            loadByLastAccessTimeQuery="SELECT SESSION_ID, USERNAME, CREATION_TIME, LAST_ACCESS_TIME, ACCESS_COUNT, MAX_INACTIVE_INTERVAL, VALID FROM JOSSO_SESSION WHERE LAST_ACCESS_TIME = ?;"
            deleteDml="DELETE FROM JOSSO_SESSION WHERE SESSION_ID = ?;"
            deleteAllDml="DELETE FROM JOSSO_SESSION;"
            />

    -->

    <!--
    <db-sstore:datasource-store
            id="josso-session-store"
            dsJndiName="java:/DefaultDS"
            loadQuery="SELECT SESSION_ID, USERNAME, CREATION_TIME, LAST_ACCESS_TIME, ACCESS_COUNT, MAX_INACTIVE_INTERVAL, VALID FROM JOSSO_SESSION WHERE SESSION_ID = ?;"
            loadAllQuery="SELECT SESSION_ID, USERNAME, CREATION_TIME, LAST_ACCESS_TIME, ACCESS_COUNT, MAX_INACTIVE_INTERVAL, VALID FROM JOSSO_SESSION;"
            insertDml="INSERT INTO JOSSO_SESSION VALUES (?, ?, ?, ?, ?, ?, ?);"
            updateDml="UPDATE JOSSO_SESSION SET USERNAME = ?, CREATION_TIME = ?, LAST_ACCESS_TIME = ?, ACCESS_COUNT = ?, MAX_INACTIVE_INTERVAL = ?, VALID = ? WHERE SESSION_ID = ?;"
            sizeQuery="SELECT COUNT(1) FROM JOSSO_SESSION;"
            keysQuery="SELECT SESSION_ID FROM JOSSO_SESSION;"
            loadByUserNameQuery="SELECT SESSION_ID, USERNAME, CREATION_TIME, LAST_ACCESS_TIME, ACCESS_COUNT, MAX_INACTIVE_INTERVAL, VALID FROM JOSSO_SESSION WHERE USERNAME = ?;"
            loadByValidQuery="SELECT SESSION_ID, USERNAME, CREATION_TIME, LAST_ACCESS_TIME, ACCESS_COUNT, MAX_INACTIVE_INTERVAL, VALID FROM JOSSO_SESSION WHERE VALID = ?;"
            loadByLastAccessTimeQuery="SELECT SESSION_ID, USERNAME, CREATION_TIME, LAST_ACCESS_TIME, ACCESS_COUNT, MAX_INACTIVE_INTERVAL, VALID FROM JOSSO_SESSION WHERE LAST_ACCESS_TIME = ?;"
            deleteDml="DELETE FROM JOSSO_SESSION WHERE SESSION_ID = ?;"
            deleteAllDml="DELETE FROM JOSSO_SESSION;"
            />
     -->

    <!-- ===================================================================== -->
    <!-- JOSSO Assertion Store, the id is very important because it is         -->
    <!-- referenced by the assertion manager and who knows where elese         -->
    <!-- ===================================================================== -->

    <!-- Chagne the store implementation if you want to use DB Assertion stores (useful for clustesr and failover) -->

    <memory-astore:memory-store id="josso-assertion-store"/>
    <!--
    <db-astore:datasource-store
            id="josso-assertion-store"
            dsJndiName="java:/DefaultDS"
            sizeQuery="SELECT COUNT(1) FROM JOSSO_ASSERTION;"
            keysQuery="SELECT ASSERTION_ID FROM JOSSO_ASSERTION;"
            loadAllQuery="SELECT ASSERTION_ID, SECURITY_DOMAIN_NAME, SSO_SESSION_ID, CREATION_TIME, VALID FROM JOSSO_ASSERTION;"
            loadQuery="SELECT ASSERTION_ID, SECURITY_DOMAIN_NAME, SSO_SESSION_ID, CREATION_TIME, VALID FROM JOSSO_ASSERTION WHERE ASSERTION_ID = ?;"
            deleteAllDml="DELETE FROM JOSSO_ASSERTION;"
            deleteDml="DELETE FROM JOSSO_ASSERTION WHERE ASSERTION_ID = ?;"
            insertDml="INSERT INTO JOSSO_ASSERTION VALUES (?, ?, ?, ?, ?);"
            />
    -->

</s:beans>

PR

2009/02/16 (Mon.) Trackback() Comment(0) 未選択

Comments

名前
メールアドレス
URL
コメント
PASS  Vodafone絵文字 i-mode絵文字 Ezweb絵文字

Trackback

Trackback for this entry:

カレンダー

12 2025/01 02
S M T W T F S
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31

リンク

カテゴリー

フリーエリア

最新CM

[08/09 VMAXON]

最新記事

最新TB

プロフィール

HN:
No Name Ninja
性別:
非公開

バーコード

RSS

ブログ内検索

アーカイブ

最古記事

アクセス解析

FX NEWS


-外国為替-

コガネモチ