Web SDK 統合ガイド
このページでは、Rokt Ads の Web SDK を実装して、コンバージョンをキャンペーンにリンクすることでループを閉じる方法を説明します。コンバージョンを Ads エンゲージメントにリンクすることで、より正確なアトリビューション、リアルタイムの最適化、およびキャンペーンの測定が可能になります。
専任のアカウント担当者が、Web SDK のためにあなたの アカウントを設定するのを手伝います。彼らは、SDK を初期化するために必要な API キー と、顧客に最も関連性の高いエクスペリエンスを提供するために必要な追加リソースを提供します。
以下の指示を完了するには開発リソースが必要です。追加の支援が必要な場合は、Rokt のアカウントマネージャーにお問い合わせください。
まず開発環境で SDK を実装するために、Rokt のアカウントマネージャーと協力してください。これにより、本番環境でリリースする前に、統合を徹底的にテストし、トラブルシューティングすることができます。
ファーストパーティドメインの設定ファーストパーティドメインの設定 への直接リンク
Roktは、SDKをサイトに統合する際にファーストパーティドメインを使用することを推奨しています。これにより、Rokt SDKがRoktのAPIへの呼び出しを行う際に自社のドメインを使用し、顧客にシームレスな体験を提供し、コンテンツがブロックされるリスクを最小限に抑えることができます。
SDK統合のためのファーストパーティドメインの設定方法については、ファーストパーティドメイン統合を参照してください。
1. Rokt SDKの初期化1. Rokt SDKの初期化 への直接リンク
SDKを初期化するには、SDK初期化スクリプトをサイトにコピーして貼り付けます。
各サイトは異なりますが、RoktはすべてのページにSDKスクリプトを含めることを推奨しています。これにより、オファー配信の遅延が最小限になり、ユーザー識別の精度が最大化されます。
- シングルページアプリケーション (SPA): ウェブサイトがSPAの場合、初期化スクリプトをメインの
index.htmlページの<head>、または他のコンテンツがレンダリングされる主要な場所に挿入します。 - マルチページアプリケーション (MPA): ウェブサイトがMPAでテンプレートベースのレンダリングシステムを使用している場合(最も一般的)、初期化スクリプトを主要な共有レイアウトファイルに配置します。テンプレートベースのレンダリングシステムを使用していない場合は、ウェブサイトの各HTMLファイルにスクリプトを配置します。
各ページにスクリプトを含めることができますが、ブラウザのキャッシュにより、SDKはデフォルトでキャッシュから読み込まれ、ウェブサイトの各ページロード時に再度読み込まれることはありませんのでご注意ください。
SDK 初期化スクリプトSDK 初期化スクリプト への直接リンク
<script type="text/javascript">
// Rokt APIキーを入力してください
const API_KEY = "YOUR_API_KEY";
// ファーストパーティドメイン設定を使用している場合は、カスタムサブドメインを入力してください(オプション)
const ROKT_DOMAIN = "https://apps.rokt-api.com";
window.mParticle = {
config: {
// データ環境を設定します:
// 統合をテストしている場合は、isDevelopmentModeをtrueに設定します。
// 統合が本番データの準備ができている場合は、isDevelopmentModeをfalseに設定します。
isDevelopmentMode: true,
// 現在のユーザーを識別します:
// ユーザーのメールアドレスがない場合は、null値を渡すことができます
identifyRequest: {
userIdentities: {
// ハッシュされていないメールアドレスを使用している場合は、'email'に設定します。
email: 'j.smith@example.com',
// ハッシュされたメールアドレスを使用している場合は、`email`ではなく'other'に設定します。
other: 'sha256 hashed email goes here'
}
}
},
// ユーザーがメールアドレスで識別されている場合は、追加のユーザー属性を設定します。
identityCallback: function(result) {
if (result.getUser()) {
result.getUser().setUserAttribute('attribute-key', 'attribute-value');
}
}
};
// SDKをロードします
(function(e) { window.mParticle = window.mParticle || {}; window.mParticle.EventType = { Unknown: 0, Navigation: 1, Location: 2, Search: 3, Transaction: 4, UserContent: 5, UserPreference: 6, Social: 7, Other: 8, Media: 9 }; window.mParticle.eCommerce = { Cart: {} }; window.mParticle.Identity = {}; window.mParticle.Rokt = {}; window.mParticle.config = window.mParticle.config || {}; window.mParticle.config.rq = []; window.mParticle.config.snippetVersion = 2.8; window.mParticle.ready = function(e) { window.mParticle.config.rq.push(e); }; ["endSession", "logError", "logBaseEvent", "logEvent", "logForm", "logLink", "logPageView", "setSessionAttribute", "setAppName", "setAppVersion", "setOptOut", "setPosition", "startNewSession", "startTrackingLocation", "stopTrackingLocation"].forEach(function(e) { window.mParticle[e] = function() { var t = Array.prototype.slice.call(arguments); t.unshift(e); window.mParticle.config.rq.push(t); }; }); ["setCurrencyCode", "logCheckout"].forEach(function(e) { window.mParticle.eCommerce[e] = function() { var t = Array.prototype.slice.call(arguments); t.unshift("eCommerce." + e); window.mParticle.config.rq.push(t); }; }); ["identify", "login", "logout", "modify"].forEach(function(e) { window.mParticle.Identity[e] = function() { var t = Array.prototype.slice.call(arguments); t.unshift("Identity." + e); window.mParticle.config.rq.push(t); }; }); ["selectPlacements","hashAttributes","hashSha256","setExtensionData","use","getVersion","terminate"].forEach(function(e) { window.mParticle.Rokt[e] = function() { var t = Array.prototype.slice.call(arguments); t.unshift("Rokt." + e); window.mParticle.config.rq.push(t); }; }); var t = window.mParticle.config.isDevelopmentMode ? 1 : 0, n = "?env=" + t, a = window.mParticle.config.dataPlan; if (a) { var o = a.planId, r = a.planVersion; o && (r && (r < 1 || r > 1e3) && (r = null), n += "&plan_id=" + o + (r ? "&plan_version=" + r : "")); } var i = window.mParticle.config.versions, s = []; i && Object.keys(i).forEach(function(e) { s.push(e + "=" + i[e]); }); var c = document.createElement("script"); c.type = "text/javascript"; c.async = !0; window.ROKT_DOMAIN = ROKT_DOMAIN || 'https://apps.rokt-api.com'; mParticle.config.domain = ROKT_DOMAIN.split('//')[1]; c.src = ROKT_DOMAIN + "/js/v2/" + e + "/app.js" + n + "&" + s.join("&"); var l = document.getElementsByTagName("script")[0]; l.parentNode.insertBefore(c, l); })(API_KEY);
</script>
サイトに初期化スクリプトを挿入する際には、次の設定を構成してください:
1.1 Rokt APIキーを入力1.1 Rokt APIキーを入力 への直接リンク
API_KEY を、専任のRoktアカウントマネージャーから提供されたRokt APIキーに設定します。
Rokt APIキーは、Roktアカウント担当者から提供される一意の資格情報であり、サイトがRokt SDKと安全に接続および対話することを可能にします。
1.2 カスタムサブドメインを入力(オプション)1.2 カスタムサブドメインを入力(オプション) への直接リンク
SDKを独自のドメイン経由でルーティングしたい場合は、ファーストパーティドメインの設定の指示に従い、ROKT_DOMAIN を作成したサブドメインに設定します。
カスタムサブドメインを使用することで、Rokt SDKを独自のドメイン経由でルーティングし、ブラウザや広告ブロッカーによる広告やデータのブロックのリスクを軽減できます。
このステップはオプションです。ROKT_DOMAIN を https://apps.rokt-api.com に設定したままにすることもできますが、その場合、Rokt SDKへのリクエストは apps.rokt-api.com を経由してルーティングされます。
1.3 データ環境の設定1.3 データ環境の設定 への直接リンク
Roktは2つのデータ環境を維持しています。テスト目的でデータをラベリングおよび保存するための開発環境と、実際の顧客活動を収集するための本番環境です。
Rokt SDKをまだテストしている場合は、isDevelopmentModeをtrueに設定してください。
テストが完了し、実際の顧客活動の収集を開始したい場合は、isDevelopmentModeをfalseに設定してください。
1.4 ユーザーの識別1.4 ユーザーの識別 への直接リンク
SDKが初期化されると、現在のユーザーを識別できるようになり、収集されたデータが正しくそのユーザーに帰属され、ユーザーの行動に基づいて最も関連性の高い広告が表示されるようになります。
SDKの初期化スクリプトには、identifyRequestというオブジェクトが含まれています:
identifyRequest: {
userIdentities: {
// ユーザーの生のメールアドレスを'email'に設定
email: 'j.smith@example.com',
// ユーザーのハッシュ化されたメールアドレスを'other'に設定
other: 'sha256 hashed email goes here'
}
}
identifyRequest内では、ユーザーのメールアドレスをハッシュ化されていない場合はemailフィールドに、SHA256でハッシュ化されている場合はotherフィールドに渡します。
初期化時にユーザーのメールアドレスがなくても、必ずidentifyRequestを初期化スクリプトに含めてください。
ユーザーのメールアドレスがない場合は、null値を渡してください。SDKはそれでも初期化され、後で2. ユーザーの識別の指示に従ってユーザーを識別できます。
1.5 追加のユーザ ー属性を設定する1.5 追加のユーザー属性を設定する への直接リンク
初期化スクリプトには、ユーザーがメールアドレスで正常に識別された場合に、追加のユーザー属性を設定するためのコールバック関数が含まれています:
// identityCallbackはidentifyRequestが成功したかどうかを判断します。
identityCallback: function(result) {
if (result.getUser()) {
// ユーザーが識別された場合、setUserAttributeで追加のユーザー属性を設定します。
result.getUser().setUserAttribute('attribute-key', 'attribute-value');
}
}
ユーザーに対して収集することをRoktが推奨する属性のリストについては、推奨ユーザー属性を参照してください。
2. ユーザーを識別する2. ユーザーを識別する への直接リンク
初期化中に、SDKはユーザーのメールアドレスを使用してRoktにidentifyRequestを送信し、現在のユーザーを識別します。
初期化時にユーザーを識別することに加えて、SDKが初期化された後にユーザーがメールアドレスを提供するたびに(例: ログインや購入時)、identifyメソッドを呼び出してメールをRoktに渡す必要があります。これにより、データが現在のユーザーに正しく帰属されることが保証されます。
ユーザーを識別するには、まずユーザーのメールアドレスを含むidentifyRequestオブジェクトを作成します。
ハッシュ化されていないメールアドレスを提供する場合は、次を使用します:
const identifyRequest = {
userIdentities: {
email: 'j.smith@example.com'
}
};
ハッシュ化されたメールアドレスを提供する場合は、次を使用します:
const identifyRequest = {
userIdentities: {
other: 'sha256 hashed email goes here'
}
};
次に、ユーザーを識別する際に追加のユーザー属性を設定するオプションとして、コールバック関数を作成します。identifyRequestが成功した場合、setUserAttributeで設定したユーザー属性がユーザーに割り当てられます。
const identityCallback = function(result) {
if (result.getUser()) {
result.getUser().setUserAttribute('attribute-key', 'attribute-value');
}
};
ユーザーに対して収集することをRoktが推奨する属性のリストについては、推奨ユーザー属性を参照してください。
最後に、identifyRequestとidentityCallbackを作成した後、追加の属性を設定するために、作成したidentifyRequestとidentityCallbackオブジェクトを渡してidentifyメソッドを呼び出します:
mParticle.Identity.identify(identifyRequest, identityCallback);
例えば、Jane Smithという名前のユーザーをメールアドレスj.smith@example.comで識別する場合(メールアドレスをハッシュする必要がない場合)、次のように使用します。
const identifyRequest = {
userIdentities: {
email: 'j.smith@example.com'
}
};
const identityCallback = function(result) {
if (result.getUser()) {
result.getUser().setUserAttribute('firstname', 'Jane');
result.getUser().setUserAttribute('lastname', 'Smith');
}
};
mParticle.Identity.identify(identifyRequest, identityCallback);
3. ユーザー属性の設定3. ユーザー属性の設定 への直接リンク
上記の例は、SDKの初期化時にユーザーが識別された場合と、ユーザーがメール アドレスを提供した後に識別された場合に、ユーザー属性を設定する方法を示しています。
ただし、ユーザーが識別された後は、いつでもユーザー属性を設定できます。これらの属性は、広告配置やログイベントに含まれます。また、配置を挿入する際に直接ユーザー属性を設定することもできます。
ユーザー属性を設定するには、次のコードを実行します。
// 現在のユーザーを取得するには、getCurrentUserを呼び出します。
const currentUser = mParticle.Identity.getCurrentUser();
// 現在のユーザーを`currentUser`という定数に設定したら、次のようにしてユーザー属性を設定できます。
currentUser.setUserAttribute("user-attribute-key", "user-attribute-value");
// リスト属性を設定するには、属性の値を文字列の配列に設定します。例えば:
currentUser.setUserAttribute("favorite-genres", ["documentary", "comedy", "romance", "drama"]);
// ユーザー属性を削除するには、removeUserAttributeを呼び出し、属性名を渡します。すべてのユーザー属性は同じキー空間を共有します。
currentUser.removeUserAttribute("attribute-to-remove");
推奨ユーザー属性推奨ユーザー属性 への直接リンク
Roktは、可能な限り次のユーザー属性を設定することを推奨します:
| ユーザー属性キー | 例の値 | 備考 |
|---|---|---|
| firstname | John | 顧客の名。 |
| lastname | Doe | 顧客の姓。 |
| mobile | 3125551515 | 電話番号は1112345678または+1 (222) 345-6789の形式でフォーマットできます。 |
| age | 33 | 顧客の年齢。 |
| dob | 19900717 | 生年月日。yyyymmddの形式でフォーマットされています。 |
| gender | M | 顧客の性別。例: M, Male, F, Female。 |
| city | Brooklyn | 顧客の市。 |
| state | NY | 顧客の州。 |
| zip | 11201 | 顧客の郵便番号。 |
| title | Mr | 顧客の敬称。例: Mr, Mrs, Ms。 |
| language | en | 購入に関連する言語。 |
| value | 52.25 | 顧客の価値。 |
| predictedltv | 136.23 | 顧客の予測生涯価値の合計。 |