ColdFusion から Webflow のデータにクエリ

Jerod Johnson
Jerod Johnson
Director, Technology Evangelism
ColdFusion の標準データアクセスコードで Webflow のデータ に接続。



CData JDBC ドライバーを使用すると、ColdFusion の高速開発ツールを使って Webflow のデータ にシームレスに接続できます。本記事では、ColdFusion から Webflow のデータ に接続し、Webflow テーブルにクエリを実行する方法を説明します。

ColdFusion で Webflow 用JDBC データソースを作成

JDBC データソースを設定すると、cfquery タグや executeQuery などのCFScript から標準SQL を実行できるようになります。

  1. インストールディレクトリから、ドライバーのJAR ファイルと.lic ファイルをColdFusion のクラスパスにコピーします。例えば、C:\MyColdFusionDirectory\cfusion\wwwroot\WEB-INF\lib にコピーします。または、ColdFusion Administrator の[Java と JVM]ページで、[ColdFusion Class Path]ボックスにファイルへのパスを入力します。

    ドライバーのJAR ファイルとライセンスファイルは、インストールディレクトリの lib サブフォルダにあります。

    この手順の後、サーバーを再起動してください。

  2. ドライバーをデータソースとして追加します。

    ColdFusion Administrator 画面で、[データ&サービス]ノードを展開し、[データソース]をクリックします。[新しいデータソースの追加]セクションで、データソースの名前を入力し、[ドライバー]メニューから[Other]を選択します。

  3. ドライバーのプロパティを設定します。

    • JDBC URL:JDBC URL に接続プロパティを入力します。JDBC URL は jdbc:api: で始まり、その後にセミコロン区切りで name=value 形式の接続プロパティを指定します。

      認証

      Webflow は、サイト、CMS コレクション、e コマースデータ、その他のリソースへの安全なアクセスを確保するために、OAuth 2.0 認証を使用します。この認証方式により、Webflow ワークスペースに安全に接続し、適切な認可のもとでリソースを管理できます。

      OAuth 2.0 のセットアップと設定

      ステップ 1:Webflow OAuth アプリケーションの作成

      OAuth 認証をセットアップするには、以下のステップで進めます:

      1. Webflow Developer Portal にアクセスします
      2. Webflow アカウントの「Apps & Integrations」に移動します
      3. 「Register an App」をクリックして新しい OAuth アプリケーションを作成します
      4. アプリケーション名、説明、リダイレクト URI(CallbackURL)を設定します
      5. 接続で使用する Client ID と Client Secret をコピーします

      必須の接続プロパティ

      • AuthScheme:OAuth に設定します(必須)
      • OAuthClientId:Webflow OAuth アプリケーションの Client ID(必須)
      • OAuthClientSecret:Webflow OAuth アプリケーションの Client Secret(必須)
      • CallbackURL:OAuth アプリケーションで指定したリダイレクト URI(必須)
      • InitiateOAuth:トークンを自動管理するには GETANDREFRESH に設定します(推奨)

      必須の OAuth スコープ

      Webflow API プロファイルでは、以下の OAuth スコープが必要です:

      • sites:read - サイト情報および設定への読み取りアクセス
      • pages:read - サイトページへの読み取りアクセス
      • cms:read - CMS コレクションおよびアイテムへの読み取りアクセス
      • forms:read - フォームおよびフォーム送信への読み取りアクセス
      • assets:read - メディアアセットおよびフォルダーへの読み取りアクセス
      • ecommerce:read - 製品、注文、在庫への読み取りアクセス
      • authorized_user:read - 認可されたユーザーへの読み取りアクセス

      組み込みの接続文字列デザイナー

      JDBC URL の構築には、Webflow JDBC ドライバーに組み込まれた接続文字列デザイナーをご利用ください。JAR ファイルをダブルクリックするか、コマンドラインから実行します。

      java -jar cdata.jdbc.api.jar
      

      接続プロパティを入力し、接続文字列をクリップボードにコピーします。

      一般的なJDBC URL は次のようになります。

      jdbc:api:Profile=C:\profiles\Webflow.apip;AuthScheme=OAuth;InitiateOAuth=GETANDREFRESH;OAuthClientId=your_client_id;OAuthClientSecret=your_client_secret;CallbackUrl=your_callback_url;
    • Driver Class:ドライバークラスを入力します。ドライバークラスは cdata.jdbc.api.APIDriver です。
    • Driver Name:ドライバーのユーザー定義名を入力します。
    • Username:認証に使用するユーザー名を入力します。
    • Password:認証に使用するパスワードを入力します。

これで、[操作]列で CData Webflow データソースを有効にして接続をテストできます。ステータスがOK と表示されたら、Webflow データソースの準備完了です。

クエリの実行

cfquery タグで Webflow にSQL ステートメントを送信できます。cfqueryparam タグを使用して、パラメータ化クエリを作成し、クエリ文字列によるSQL インジェクションを防止します。

注意cfquerycfscript を使用するには、.cfm ファイルを作成します。その.cfm ファイル内に、クエリを実行するコードを記述します(下記参照)。ファイルをWeb サーバーのルートディレクトリ(Adobe ColdFusion の場合はwwwroot など)に直接配置します。変更を反映するには、ファイル配置後にサービスを再起動してください。


<cfquery name="APIQuery" dataSource="CDataAPI">
  SELECT * FROM Sites WHERE Id = <cfqueryparam value="#Id#" cfsqltype="cf_sql_varchar">
</cfquery>
<cfdump var="#APIQuery#">

CFScript で記述すると以下のようになります。


<cfscript>
result = queryExecute(
  "SELECT * FROM Sites WHERE Id = ?",
  [
    { value="your_site_id", cfsqltype="cf_sql_varchar" }
  ],
  { datasource="CDataAPI" }
);

writeDump( var= result );
</cfscript>

その後、以下のように.cfm ファイルにリクエストを送信できます。

http://MyServer:8500/query.cfm?Id=your_site_id

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

API Driver で Webflow のライブデータに接続

Webflow に接続