各製品の資料を入手。
詳細はこちら →ColdFusion にリアルタイムAdobe Analytics のデータをインポートしてアプリケーションを構築
CData JDBC ドライバを使ってColdFusion にAdobe Analytics のデータをインポートして使用します。
最終更新日:2023-02-02
この記事で実現できるAdobe Analytics 連携のシナリオ
こんにちは!ドライバー周りのヘルプドキュメントを担当している古川です。
Adobe ColdFusion は、Web アプリケーションおよびモバイルアプリケーション開発プラットフォームです。独自のスクリプト言語であるColdFusion Markup Language(CFML)を使用し、データドリブンなWeb サイトを作成したり、REST などのリモートサービスを生成したりすることができます。
ColdFusion とCData JDBC Driver for AdobeAnalytics を組み合わせると、ColdFusion のWeb アプリケーションやモバイルアプリケーションを、運用中のAdobe Analytics のデータにリンクできます。 これにより、アプリケーションの堅牢性と完成度を高めることができます。この記事では、JDBC ドライバーを使ってColdFusion マークアップファイルからAdobe Analytics のデータを入力したテーブルを作成する方法について詳しく説明します。
最適化されたデータ処理が組み込まれたCData JDBC ドライバは、リアルタイムAdobe Analytics のデータを扱う上で高いパフォーマンスを提供します。 Adobe Analytics にSQL クエリを発行すると、CData ドライバーはフィルタや集計などのAdobe Analytics 側でサポートしているSQL 操作をAdobe Analytics に直接渡し、サポートされていない操作(主にSQL 関数とJOIN 操作)は組み込みSQL エンジンを利用してクライアント側で処理します。 組み込みの動的メタデータクエリを使用すると、ネイティブのデータ型を使ってAdobe Analytics のデータを操作および分析できます。
Adobe Analytics への接続を設定する
Coldfusion とAdobe Analytics の接続を確立するには、JDBC 接続文字列が必要です。
Adobe Analytics への接続
Adobe Analytics に接続するには、GlobalCompanyId およびRSID を識別する必要があります。デフォルトで、ドライバーは会社とレポートスイートの識別を自動で試みますが、これらの値を明示的に指定することもできます。方法はヘルプドキュメントの「Adobe Analytics への接続」セクションを参照してください。
Adobe Analytics への認証
Adobe Analytics はOAuth 認証標準を利用しています。 OAuth またはサービスアカウントで認証できます。
ユーザーアカウント(OAuth)
すべてのユーザーアカウントフローでAuthScheme をOAuth に設定する必要があります。OAuth 経由のAdobe 認証では、2週間ごとにリフレッシュトークンを更新する必要があります。詳しい認証方法については、ヘルプドキュメントの「Adobe Analytics への認証」セクションを参照してください。
サービスアカウント
サービスアカウントにはサイレント認証があり、ブラウザでのユーザー認証は必要ありません。このフローでは、アプリケーションを作成する必要があります。アプリケーションの作成および認可については、ドキュメントの「カスタムOAuth アプリの作成」を参照してください。これでサービスアカウントにアクセス権があるAdobe Analytics データに接続できます。
サービスアカウントを使用したServer-to-Server OAuthで認証するには、AuthScheme をOAuthClient に設定します。接続するには次のプロパティを設定します。
- InitiateOAuth:GETANDREFRESH に設定。
- OAuthClientId:アプリケーション設定のクライアントId に設定。
- OAuthClientSecret:アプリケーション設定のクライアントシークレットに設定。
接続すると、本製品 はサービスアカウントでのOAuth フローを完了します。
- クライアントクレデンシャルOAuth フローで指定されたOAuthClientId およびOAuthClientSecret を使用して、アクセストークンを取得します。
- OAuthSettingsLocation にOAuth 値を保存し、接続間で永続化されるようにします。
- トークンが期限切れになった際に、新しいアクセストークンを要求します。
組み込みの接続文字列デザイナー
JDBC URL の作成の補助として、Adobe Analytics JDBC Driver に組み込まれている接続文字列デザイナーが使用できます。JAR ファイルをダブルクリックするか、コマンドラインからjar ファイルを実行します。
java -jar cdata.jdbc.adobeanalytics.jar

データソースを追加してテーブルを作成する
接続を設定したのち、次の手順に従ってはじめにCData JDBC ドライバをColdFusion のlib ディレクトリに追加し、続けて新しいデータソースを追加、接続をテスト、ColdFusion マークアップファイルを作成し、最後にAdobe Analytics のデータとリアルタイム接続してColdFusion Markup Language(CFML)で記述されるテーブルに表示します。
-
JDBC Driver for AdobeAnalytics およびlic ファイルを"C:\Program Files\CData\CData JDBC Driver for AdobeAnalytics\lib" から"C:\ColdFusion2021\cfusion\wwwroot\WEB-INF\lib"にコピーします。
cdata.jdbc.adobeanalytics.jar cdata.jdbc.adobeanalytics.lic
Note:.lic ファイルをjar ファイルとともにコピーしないと、有効なライセンスがインストールされていないことを示すライセンスエラーが表示されます。 これは評価版、製品版ともに同様です。
-
ColdFusion Administrator インターフェースで「データとサービス」を選択します。
-
「新規のデータソースの追加」を行います。データソース名は、ColdFusion の変数命名規則に従っていればどのような名前でもかまいません。
JDBC ドライバーの場合は、「その他」を選択して「追加」ボタンをクリックします。
-
次に、ドライバーのプロパティを入力します。
- 「JDBC URL」は、次のような形式である必要があります: jdbc:adobeanalytics:|connectionString|
- 典型的な接続文字列は次のようになります:
jdbc:adobeanalytics:GlobalCompanyId=myGlobalCompanyId; RSID=myRSID; OAuthClientId=myOauthClientId; OauthClientSecret=myOAuthClientSecret; CallbackURL=myCallbackURL;
- 「ドライバクラス」は次のようになります:cdata.jdbc.adobeanalytics.AdobeAnalyticsDriver
- 「ドライバ名」の入力は任意で、これは単にColdFusion Administrator コンソールでデータソースを認識するために使われます。
-
ここで、作成したCDataAdobe AnalyticsJDBC データソースの左側にあるチェックマークをクリックして、接続をテストしてください。
データソースのステータスが「OK」になると、使用可能な状態です。
-
次に、ColdFusion Markup ファイル(.cfm)を新規作成し、ColdFusion のwwwroot ディレクトリ("C:\ColdFusion2021\cfusion\wwwroot")に配置します。
次のコードは、データソースにクエリを実行します。
<cfquery name="Adobe AnalyticsQuery" dataSource="CDataAdobe AnalyticsJDBC"> SELECT * FROM AdsReport </cfquery>
CFTable を使用すると、HTML で素早くテーブルを出力できます。<cftable query = "Adobe AnalyticsQuery" border = "1" colHeaders colSpacing = "2" headerLines = "2" HTMLTable maxRows = "500" startRow = "1"> <cfcol header="<b>Page</b>" align="Left" width=2 text="Page"/> <cfcol header="<b>PageViews</b>" align="Left" width=15 text="PageViews"/> ... </cftable>
HTML 部分を含むコード全体を以下に掲載します。<html> <head><title>CData Software | Adobe Analytics AdsReport Table Demo </title></head> <body> <cfoutput>#ucase("Adobe Analytics AdsReport Table Demo")#</cfoutput> <cfquery name="Adobe AnalyticsQuery" dataSource="CDataAdobe AnalyticsJDBC"> SELECT * FROM AdsReport </cfquery> <cftable query = "Adobe AnalyticsQuery" border = "1" colHeaders colSpacing = "2" headerLines = "2" HTMLTable maxRows = "500" startRow = "1"> <cfcol header="<b>Page</b>" align="Left" width=2 text="Page"/> <cfcol header="<b>PageViews</b>" align="Left" width=15 text="PageViews"/> ... </cftable> </body> </html>
-
最後に、デフォルトのポート8500のブラウザでコードをローカルに実行します。これでAdobe Analytics のデータが入力されたテーブルが作成されました!
なお、CData JDBC ドライバはcfqueryparam 要素を使用したパラメータ化クエリもサポートしています。
次に例を示します。
SELECT * FROM Account WHERE name =
今日からはじめましょう
CData JDBC Driver for AdobeAnalytics の 30日間無償トライアル をダウンロードして、Adobe ColdFusion でAdobe Analytics と連携したアプリケーションの作成をはじめましょう!ご不明な点があれば、サポートチームにお問い合わせください。