AEM as a cloud service からOracleデータベースに接続する方法

ここでは、Adobe Experience Manager(AEM) as a Cloud Service からOracleデータベースに接続する方法について説明します。

説明 description

環境

Adobe Experience Manager

問題/症状

AEM as a cloud service からOracleデータベースに接続する方法

解決策 resolution

AEM as a Cloud Service からOracleデータベースに接続するには、次の手順を実行します。

  • POM での Maven 依存関係の追加

  • Oracleデータベースに接続するためのAEM サービス

  • OSGi 設定

POM への Maven 依存関係の追加

手順 1: この Maven 依存関係をプロジェクトのメイン pom.xml ージに含める

<dependency>
 <groupId>com.oracle.database.jdbc</groupId>
 <artifactId>ojdbc-bom</artifactId>
 <version>21.5.0.0</version>
 <type>pom</type>
 <scope>import</scope>
 </dependency>

手順 2: 以下の Maven 依存関係を「コア」と「すべて」の両方の pom.xml に含めます。

<dependency>
 <groupId>com.oracle.database.jdbc</groupId>
 <artifactId>ojdbc8</artifactId>
 </dependency>
 <dependency>
 <groupId>com.oracle.database.jdbc</groupId>
 <artifactId>ucp</artifactId>
 </dependency>
 <dependency>
 <groupId>com.oracle.database.xml</groupId>
 <artifactId>xdb</artifactId>
 </dependency>

Oracleデータベースに接続するためのAEM サービス

AEM as a Cloud Service からデータベースに接続するためのサンプルサービスコード。 パス {0} に含めることができます

パス {0} » プロジェクトフォルダー» core » service

DatabaseService.java

package com.mysite.core.services;
public interface DatabaseService {
}

DatabaseServiceImpl.java

package com.mysite.core.services;
import com.day.commons.datasource.poolservice.DataSourcePool;
import org.osgi.service.component.annotations.Activate;
import org.osgi.service.component.annotations.Component;
import org.osgi.service.component.annotations.Reference;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import javax.sql.DataSource;
import java.sql.Connection;
@Component(
 service = DatabaseService.class,
 immediate = true
)
public class DatabaseServiceImpl implements DatabaseService {
 private final Logger LOGGER = LoggerFactory.getLogger(DatabaseService.class);
 @Reference
 private DataSourcePool dataSourcePool;
 @Activate
 public void activate() {
 try {
 DataSource dataSource = (DataSource) dataSourcePool.getDataSource("oracle");
 Connection connection = dataSource.getConnection();
 if (connection != null) {
 if (!connection.isClosed()) {
 LOGGER.info("Connected with connection #4");
 connection.close();
 }
 }
 else {
 LOGGER.info("Connection is null");
 }
 } catch (Exception ex) {
 LOGGER.error("It was not possible to get the data source: " + ex.getMessage(), ex);
 }
 }
}

OSGi 設定

手順 1: ローカルでAEM OSGi 設定(http://localhost:4502/system/console/configMgr)に移動します。

手順 2: 「JDBC 接続プール」を検索し、DB に関して以下の値を設定します(サンプル値のスクリーンショットを参照)

  • JDBC Driver クラス
  • JDBC 接続 URL
  • ユーザー名とパスワード
  • データソース名

手順 3: 以下のリンクの手順に従って、OSGi 設定を .cfg.json ファイルに変換し、AEMaaCS 標準に従ってプロジェクト設定に追加します。

https://experienceleague.adobe.com/docs/experience-manager-cloud-service/content/implementing/deploying/configuring-osgi.html?lang=ja#generating-osgi-configurations-using-the-aem-sdk-quickstart

recommendation-more-help
3d58f420-19b5-47a0-a122-5c9dab55ec7f