Jetty の接続プールから LDAP Objects に接続

Jerod Johnson
Jerod Johnson
Senior Technology Evangelist
LDAP JDBC Driver は接続プールをサポートしています。この記事では、Jetty の Web アプリから LDAP objects に高速に接続する方法を説明します。

CData JDBC Driver for LDAP は、Java Web アプリケーションへの統合が簡単です。この記事では、接続プールを設定することで Jetty から LDAP objects に効率的に接続する方法を説明します。Jetty で LDAP 用の JNDI リソースを設定していきましょう。

Salesforce 用の JDBC Driver を JNDI データソースとして設定

以下のステップで Jetty から Salesforce に接続します。

  1. Jetty ベースで JNDI モジュールを有効にします。次のコマンドは、コマンドラインから JNDI を有効にします。

    java -jar ../start.jar --add-to-startd=jndi
    
  2. インストールディレクトリの lib サブフォルダにある CData およびライセンスファイルを、コンテキストパスの lib サブフォルダに追加します。
  3. リソースとそのスコープを宣言します。リソース宣言に必要な接続プロパティを入力します。次の例では、WEB-INF\jetty-env.xml に Web アプリレベルで LDAP データソースを宣言しています。

    
    <Configure id='ldapdemo' class="org.eclipse.jetty.webapp.WebAppContext">
        <New id="ldapdemo" class="org.eclipse.jetty.plus.jndi.Resource">
        <Arg><Ref refid="ldapdemo"/></Arg>
        <Arg>jdbc/ldapdb</Arg>
        <Arg>
          <New class="cdata.jdbc.ldap.LDAPDriver">
            <Set name="url">jdbc:ldap:</Set>
            <Set name="User">Domain\BobF</Set>
            <Set name="Password">bob123456</Set>
            <Set name="Server">10.0.1.1</Set>
            <Set name="Port">389</Set>
          </New>
        </Arg>
      </New>
    </Configure>
    

    リクエストを認証するには、User およびPassword プロパティを有効なLDAP クレデンシャル(例えば、User を"Domain\BobF" または"cn=Bob F,ou=Employees,dc=Domain")に設定します。 CData 製品は、デフォルトでプレーンテキスト認証を使用します。これは、CData 製品がサーバーとTLS/SSL のネゴシエーションを試みるためです。 AuthMechanism を使って別の認証方法を指定できます。 TLS/SSL コンフィギュレーションについて詳しくは、ヘルプドキュメントの「高度な設定」を参照してください。

      基本接続には、Server およびPort を設定します。さらに、次のように接続を微調整できます。
    • FollowReferrals:設定すると、CData 製品は参照サーバーのデータもビューとして表示します。参照サーバー上のデータを変更するには、このサーバーをServer およびPort で指定する必要があります。
    • LDAPVersion:サーバーが実装するプロトコルのバージョンに設定します。デフォルトでは、CData 製品はversion 2 を使用します。
    • BaseDN は、LDAP 検索の範囲を指定された識別名の高さに限定します。BaseDN の範囲を絞ることはパフォーマンスを劇的に向上させます。例えば、"cn=users,dc=domain" の値は、"cn=users" およびその子に含まれる結果のみを返します。
    • Scope:このプロパティを使用すると、サブツリーから返されるデータをより細かく制御できます。
  4. Web.xml でリソースを設定します。

    
      jdbc/ldapdb
      javax.sql.DataSource
      Container
    
    
  5. これで、java:comp/env/jdbc/ldapdb をルックアップして LDAP にアクセスできます。

    InitialContext ctx = new InitialContext();
    DataSource myldap = (DataSource)ctx.lookup("java:comp/env/jdbc/ldapdb");
    

Jetty 統合の詳細

上記のステップでは、シンプルな接続プールのシナリオでドライバーを設定する方法を説明しました。その他のユースケースや詳細については、Jetty ドキュメントのWorking with Jetty JNDI の章を参照してください。

はじめる準備はできましたか?

LDAP Driver の無料トライアルをダウンロードしてお試しください:

 ダウンロード

詳細:

LDAP Icon LDAP JDBC Driver お問い合わせ

LDAP ディレクトリサービスを組み込んだパワフルなJava アプリケーションを短時間・低コストで作成して配布できます。