Rainbow Engine

IT技術を分かりやすく簡潔にまとめることによる学習の効率化、また日常の気付きを記録に残すことを目指します。

OracleDB Tomcat

Tomcatを使ったフォーム認証でユーザ情報をデータベース管理する方法

投稿日:2021年4月29日 更新日:

<目次>

(1) Tomcatを使ったフォーム認証でユーザ情報をデータベース管理する方法
 (1-1) 前提条件
 (1-2) STEP1:context.xmlにコネクションプールを設定
 (1-3) STEP2:context.xmlにDB認証の設定を追記
 (1-4) STEP3:ユーザ管理用のテーブル作成
 (1-5) STEP4:web.xmlの設定
 (1-6) STEP5:ログイン/ログインエラーページの作成
 (1-7) STEP6:疎通確認

(1) Tomcatを使ったフォーム認証でユーザ情報をデータベース管理する方法

今回はJSP/ServeltにてTomcatを使ったフォーム認証をする際に、ユーザー情報(ID、パスワードなど)を「tomcat-users.xml」に保持するのではなく、DB内(のテーブル)にて保持したい場合の設定方法をご紹介します。

(1-1) 前提条件

●アプリケーションサーバの準備

・JDK、Eclipseのインストールが済んでいる
(手順)EclipseをCentOS7にインストールする手順

・Tomcatのインストールが済んでいる
(手順)TomcatをCentOS7にインストールする手順

●データベースサーバの準備

・データベースのインストールが済んでいる
 
・スキーマやユーザの登録が済んでいる
 

(1-2) STEP1:context.xmlにコネクションプールを設定

まず最初に、Tomcatのcontext.xmlにコネクションプールの設定を追記して、コネクションプールにプールされた接続からDBへのアクセスを可能にします。手順については下記の記事をご参照ください。

 
(図111)コネクションプール設定をしたcontext.xmlの例
 

(1-3) STEP2:context.xmlにDB認証の設定を追記

Tomcatにおいては認証におけるユーザ情報をどこで管理するか?を下表のいくつかのパターンから選択する事ができ、DBにユーザー情報を格納する場合は「JDBCRealm」や「DataSourceRealm」といった方式を選択していく事になります。

(表)Tomcatで選択可能な認証方法

方式 説明
MemoryRealm XML形式のユーザ定義ファイル(tomcat-users.xmlなど)で管理する方式です。何も指定しなかったデフォルト時はこの「MemoryRealm」が適用されます。
JDBCRealm データベースのテーブルにて認証情報を保持する方式です。JDBCドライバを介してアクセスを行います。
DataSourceRealm データベースのテーブルにて認証情報を保持する方式です。データソースを介してアクセスを行います。
JNDIRealm LDAPサーバで管理する方式です。JDNIのプロバイダを介してアクセスします。
(参考)JNDIとは?JDBCとの違いやメリット・デメリットについてもご紹介

では早速、追記の手順を確認していきます。

(1-3-1) DB認証の設定追記

認証方法を定義するためにはcontext.xml内に要素を追記していきます。

(構文)

<Realm className="org.apache.catalina.realm.DataSourceRealm"
	dataSourceName="jdbc/LoginTemplate"
	localDataSource="true"
	roleNameCol="ROLE"
	userCredCol="PASSWORD"
	userNameCol="USER_ID"
	userRoleTable="USER_ROLE"
	userTable="USER_MASTER">
	<CredentialHandler
		className="org.apache.catalina.realm.MessageDigestCredentialHandler"
		algorithm="MD5" />
</Realm>

 

(各項目の説明)

className 認証方式を実装したクラスを指定します。今回は「DataSourceRealm」を使うため「org.apache.catalina.realm.DataSourceRealm」を指定します。
dataSourceName データソースの名前を指定します。コネクションプール設定の時に追記した<Resource>要素のname属性と一致させる必要があります。
localDataSource 「META-INF/context.xml」配下の<Resource>要素を使用する場合はこの値を「true」に指定します。
userTable ユーザー情報を保持するテーブル名(テーブル定義は後述)を指定します。
userCredCol userTableで指定したテーブルのうち、パスワード情報を保持するカラムの名前を指定します。
userNameCol userTableで指定したテーブルのうち、ユーザID情報を保持するカラムの名前を指定します。
userRoleTable ロール情報を保持するテーブル名(テーブル定義は後述)を指定します。
roleNameCol userRoleTableで指定したテーブルのうち、ユーザに紐づくロール情報を保持するカラムの名前を指定します。
<CredentialHandler>要素 パスワードの暗号化のアルゴリズムを指定するための要素で、<Realm>内に入れ子にして記述します。次は「MD5」方式を指定した例です。

<CredentialHandler
className=”org.apache.catalina.realm.MessageDigestCredentialHandler”
algorithm=”MD5″ />

context.xml全体としては、前回のデータソース(<Resouce>要素)の追記をした後から、次のようになっています。
 
(全体)
<?xml version="1.0" encoding="UTF-8"?>
<Context displayName="Sample DataSource" docBase="LoginTemplate"
  path="/LoginTemplate" reloadable="true" >

  <Realm className="org.apache.catalina.realm.DataSourceRealm"
    dataSourceName="jdbc/LoginTemplate"
    localDataSource="true"
    roleNameCol="ROLE"
    userCredCol="PASSWORD"
    userNameCol="USER_ID"
    userRoleTable="USER_ROLE"
    userTable="USER_MASTER">
    <CredentialHandler
      className="org.apache.catalina.realm.MessageDigestCredentialHandler"
      algorithm="MD5" />
  </Realm>
  <Resource  name="jdbc/[ご自身のデータソース名]"
        auth="Container"
        type="javax.sql.DataSource"
        username="[ご自身のDBユーザ名]"
        password="[ご自身のDBパスワード]"
        driverClassName="oracle.jdbc.OracleDriver"
        url="jdbc:oracle:thin:@[ホスト名]:[ポート番号]:[SID]"
        maxWait="5000"
        maxIdle="2"
        validationQuery="[バリデーション用のSQL]" />
</Context>

(図122)

目次にもどる

(1-4) STEP3:ユーザ管理用のテーブル作成

次にユーザ情報(ID、パスワード等)を管理するためのテーブルをデータベースに作成します。

(1-4-1) ユーザ情報テーブルをCREATE

<Realm>要素の「userTable」属性で指定したテーブルを作成します。テーブルの名称やカラムの名前はcontext.xmlとしっかり一致していれば、任意の名前に変更が可能です。以下はテーブル構造の例です。

・テーブル構造
(表)

論理名 物理名 PK NotNull データ型 桁数 バイト数
ユーザID user_id Y Y VARCHAR2 10
パスワード password N Y CHAR 32 32
ユーザ名 user_name N Y VARCHAR2 50

以下はOracleDBにテーブル作成したDDLの例をご紹介します。

・DDL

CREATE TABLE USER_MASTER
(
  user_id VARCHAR2(10)
  ,password CHAR(32) NOT NULL
  ,user_name VARCHAR2(50) NOT NULL
  ,CONSTRAINT PK_ USER_MASTER PRIMARY KEY (user_id)
) TABLESPACE TWITTERTOOLTBS;

(図131)

(1-4-2) ユーザ情報テーブルにINSERT

テーブルを作成したら、ご自身のユーザ情報もINSERTしていきます。

(図132)

注意点として、今回はパスワードの暗号化方式として「MD5」を指定しているため、例えば「12345」なら「827ccb0eea8a706c4c34a16891f84e7b」と登録する必要があります。
 
この「平文」⇒「MD5 ハッシュ」への変換には色々なやり方があり、変換してくれるWebサイトもあれば、VBA等で変換を実装する事も出来るので、お好みの方法で変換をして頂けたらと思います。例として、平文⇒MD5ハッシュの変換サイトをご紹介します。
 
●md5ハッシュ生成Webツール
 

(1-4-3) ロール情報テーブルをCREATE

<Realm>要素の「userRoleTable」属性で指定したテーブルを作成します。テーブルの名称やカラムの名前はcontext.xmlとしっかり一致していれば、任意の名前に変更が可能です。以下はテーブル構造の例です。

●テーブル構造
(表)

論理名 物理名 PK NotNull データ型 桁数 バイト数
ユーザID user_id Y Y VARCHAR2 10
ロール名 role Y Y VARCHAR2 50
以下はOracleDBにテーブル作成したDDLの例をご紹介します。
 
●DDL
CREATE TABLE USER_ROLE
(
  user_id VARCHAR2(10)
  ,role VARCHAR2(50)
  ,CONSTRAINT PK_ USER_ROLE PRIMARY KEY (user_id,role)
) TABLESPACE TWITTERTOOLTBS;
 
(図133)

目次にもどる

(1-4-4) ロール情報テーブルにINSERT

テーブルを作成したら、ご自身のユーザー情報もINSERTしていきます。

(図134)
 

目次にもどる

(1-5) STEP4:web.xmlの設定

web.xmlについてはForm認証時の設定をした際のものをそのまま利用できます(特に変更の必要なし)。記述内容については下記の記事にてご紹介していますので、ご参照頂けたらと思います。

(手順)Form認証のweb.xml設定

目次にもどる

(1-6) STEP5:ログイン/ログインエラーページの作成

web.xmlで指定したログインページ&ログインエラーページについても、Form認証で作成したものをそのまま利用できます。以下の別記事にて、それぞれのサンプルプログラムをご紹介しているので、ご参照頂けたらと思います。

・ログインページ(サンプル付き)
https://rainbow-engine.com/create-logon-form-java/#title2-3

・ログインエラーページ(サンプル付き)
https://rainbow-engine.com/create-logon-form-java/#title2-4

目次にもどる

(1-7) STEP6:疎通確認

実際に認証が必要なページにアクセスし、ログインページが表示される事、またDBに登録したユーザでログインできる事の確認を行います。

目次にもどる

Adsense審査用広告コード


Adsense審査用広告コード


-OracleDB, Tomcat

執筆者:


comment

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

関連記事

JSP Servletでセッションの有効期限を設定する方法

<目次> (1) JSP Servletでセッションの有効期限を設定する方法  (1-1) セッションの有効期限設定の概要  (1-2) 方法1:web.xmlに追記する方法  (1-3) 方法2:プ …

JavaのJDBC接続でjava.sql.SQLRecoverableException: Closed Connectionが発生した時の解決メモ

(0)目次&概説 (1) エラー事象の概要  (1-1) エラーの発生状況  (1-2) エラーメッセージ全文 (2) エラーの原因 (3) エラーの対処方法  (3-1) エラーの修正内容  (3- …

CATALINA_HOMEが設定されない時の想定原因と対処法

<目次> (1) CATALINA_HOMEが設定されない時の想定原因と対処法  (1-1) 発生状況・エラーメッセージ  (1-2) 原因  (1-3) 対処法 (1) CATALINA_HOMEが …

JSPのコンパイル済ファイルの格納場所(Tomcat単体の場合、Eclipse連携の場合)

<目次> (1) JSPのコンパイル済ファイルの格納場所(Tomcat単体の場合、Eclipse連携の場合)  (1-1) Tomcatを単体で使用している場合  (1-2) Eclipseとアプリケ …

Tomcatの起動時のエラー「アドレスは既に使用中です」や「必要な幾つかのポートがすでに使用中です」の対処方法

<目次> (1) Tomcatの起動時のエラー「アドレスは既に使用中です」や「必要な幾つかのポートがすでに使用中です」の対処方法  (1-1) 発生状況  (1-2) 原因  (1-3) 対処方法 ( …

  • English (United States)
  • 日本語
Top