ディスプレイ&ビデオ 360 API を使用して、アップロードした顧客の連絡先情報またはモバイル デバイス ID を使用してカスタマー マッチ オーディエンスを作成できます。このページでは、ディスプレイ&ビデオ 360 API を使用して、最初のカスタマー マッチ オーディエンスを作成し、既存のオーディエンスに新しい顧客データを追加する方法について説明します。
ユーザーデータを準備する
カスタマー マッチのオーディエンスの作成に使用されるユーザーデータは機密情報であるため、アップロードする前に適切に準備する必要があります。
機密データをハッシュ化する
カスタマー マッチのオーディエンスの一部は、顧客の機密性の高い連絡先情報を使用して作成されます。ディスプレイ&ビデオ 360 では、機密データをアップロードする前に SHA256 アルゴリズムでハッシュ化する必要があります。次のデータ フィールドは、アップロード前にハッシュ化する必要があります。
- 名
- 姓
- メールアドレス
- 電話番号
郵便番号と国コードは、アップロード前にハッシュ化しないでください。ハッシュ化されていない顧客データをアップロードしようとすると、エラーが発生します。
データをハッシュする前に、次の条件を満たしていることを確認します。
- 名、姓、メールアドレスの値から空白文字を削除する必要があります。
- すべての値は小文字にする必要があります。
- すべての電話番号は E.164 形式で指定し、国コードを含める必要があります。
ユーザーの同意を設定する
ユーザーデータをアップロードする際は、提供された ContactInfoList オブジェクトまたは MobileDeviceIdList オブジェクトの consent フィールドを使用して、含まれるユーザーから付与された同意のシグナルを渡します。
Consent オブジェクトのいずれかのフィールドを CONSENT_STATUS_DENIED に設定すると、エラーが発生します。
同意シグナルは、1 回の firstPartyAndPartnerAudiences.create リクエストまたは firstPartyAndPartnerAudiences.editCustomerMatchMembers リクエストで追加されたすべてのユーザーに設定されます。同意シグナルが異なるユーザーは、別々のリクエストでアップロードする必要があります。
カスタマー マッチ オーディエンスを作成する
カスタマー マッチ オーディエンスは、firstPartyAndPartnerAudiences.create メソッドを使用して作成できます。オーディエンスはファーストパーティ オーディエンスとして宣言され、audienceType が CUSTOMER_MATCH_CONTACT_INFO または CUSTOMER_MATCH_DEVICE_ID である必要があります。カスタマー マッチのデータは、ユニオン フィールド members 内の適切なフィールドを使用して提供する必要があります。
ハッシュ化された電話番号のリストを使用して、有効期間が 540 日の新しい連絡先情報のカスタマー マッチ オーディエンスを作成する例を次に示します。
Java
// Create Customer Match audience object. FirstPartyAndPartnerAudience customerMatchAudience = new FirstPartyAndPartnerAudience() .setDisplayName(display-name) .setFirstPartyAndPartnerAudienceType( "FIRST_AND_THIRD_PARTY_AUDIENCE_TYPE_FIRST_PARTY" ) .setAudienceType("CUSTOMER_MATCH_CONTACT_INFO") .setMembershipDurationDays(540L); // Build list of contact information objects. ContactInfoList contactInfoList = new ContactInfoList(); ArrayList<ContactInfo> contactInfos = new ArrayList<ContactInfo>(); for (String hashedPhoneNumber : list-of-hashed-phone-numbers) { ContactInfo contactInfo = new ContactInfo(); ArrayList<String> phoneNumberList = new ArrayList<String>(); phoneNumberList.add(hashedPhoneNumber); contactInfo.setHashedPhoneNumbers(phoneNumberList); contactInfos.add(contactInfo); } contactInfoList.setContactInfos(contactInfos); // Build consent object for passing consent if granted by the end user. Consent consent = new Consent() .setAdUserData(ad-user-data-consent) .setAdPersonalization(ad-personalization-consent); ContactInfoList.setConsent(consent); // Assign contact info list to Customer Match audience. customerMatchAudience.setContactInfoList(contactInfoList); // Create Customer Match audience. FirstPartyAndPartnerAudience response = service .firstPartyAndPartnerAudiences() .create(customerMatchAudience) .setAdvertiserId(advertiser-id) .execute(); // Display name of new audience. System.out.printf( "Customer Match audience %s was created.", response.getName() );
Python
# Build list of Contact Info objects contact_infos = [] for hashed_phone_number in list-of-hashed-phone-numbers: contact_infos.append({'hashedPhoneNumbers': [hashed_phone_number]}) # Create a Customer Match first- and third-party audience object. audience_obj = { 'displayName': display-name, 'firstPartyAndPartnerAudienceType': 'FIRST_AND_THIRD_PARTY_AUDIENCE_TYPE_FIRST_PARTY', 'audienceType': 'CUSTOMER_MATCH_CONTACT_INFO', 'membershipDurationDays': 540, 'contactInfoList': { 'contactInfos': [ contact_infos ], 'consent': { 'adUserData': ad-user-data-consent, 'adPersonalization': ad-personalization-consent } } } # Build and execute request. audience = service.firstPartyAndPartnerAudiences().create( advertiserId=advertiser-id, body=audience_obj ).execute() # Display name of new audience. print('Customer Match audience %s was created.' % audience["name"])
PHP
// Create a Customer Match first-party and partner audience object. $audience = new Google_Service_DisplayVideo_FirstPartyAndPartnerAudience(); $audience->setDisplayName(display-name); $audience->setFirstPartyAndPartnerAudienceType( 'FIRST_AND_THIRD_PARTY_AUDIENCE_TYPE_FIRST_PARTY' ); $audience->setAudienceType('CUSTOMER_MATCH_CONTACT_INFO'); $audience->setMembershipDurationDays(540); // Build list of contact information objects. $contactInfoList = new Google_Service_DisplayVideo_ContactInfoList(); $contactInfos = array(); foreach (list-of-hashed-phone-numbers as $hashedPhoneNumber) { $contactInfo = new Google_Service_DisplayVideo_ContactInfo(); $contactInfo->setHashedPhoneNumbers(array($hashedPhoneNumber)); $contactInfos[] = $contactInfo; } $contactInfoList->setContactInfos($contactInfos); // Build consent object for passing consent if granted by the end user. $consent = new Google_Service_DisplayVideo_Consent(); $consent->setAdUserData(ad-user-data-consent); $consent->setAdPersonalization(ad-personalization-consent); $contactInfoList->setConsent($consent); // Assign contactInfoList to audience object. $audience->setContactInfoList($contactInfoList); // Call the API, creating the audience. $result = $this->service->firstPartyAndPartnerAudiences->create( $audience, array('advertiserId' => advertiser-id) ); // Display name of new audience. printf('Customer Match audience %s was created.', $result['name']);
カスタマー マッチ オーディエンスのメンバーシップを更新する
ターゲットに設定する顧客を追加したり、既存のオーディエンス メンバーシップを更新したり、オーディエンスから顧客を削除したりする場合は、firstPartyAndPartnerAudiences.editCustomerMatchMembers メソッドを使用して、既存のカスタマー マッチ オーディエンスの顧客データを更新できます。added_members 共用体フィールドを使用して顧客をリストに追加し、removed_members 共用体フィールドを使用して顧客をリストから削除できます。
1 つの firstPartyAndPartnerAudiences.editCustomerMatchMembers リクエストで、リストのメンバーを追加または削除できます。両方を実行しようとする単一のリクエストは、INVALID_ARGUMENT エラーになります。
以下は、提供された郵送先住所データを使用して、既存の連絡先情報のカスタマー マッチ オーディエンスに 1 人の顧客をメンバーとして追加する例です。
Java
// Create an edit members request object. EditCustomerMatchMembersRequest editCustomerMatchMembersRequest = new EditCustomerMatchMembersRequest() .setAdvertiserId(advertiser-id); // Build contact information object to add to audience. ContactInfoList contactInfoList = new ContactInfoList(); ArrayList<ContactInfo> contactInfos = new ArrayList<ContactInfo>(); ContactInfo contactInfo = new ContactInfo() .setHashedFirstName(hashed-customer-first-name) .setHashedLastName(hashed-customer-last-name) .setZipCodes(customer-zip-codes-list) .setCountryCode(customer-country-code); contactInfos.add(contactInfo); contactInfoList.setContactInfos(contactInfos); // Build consent object for passing consent if granted by the end user. Consent consent = new Consent() .setAdUserData(ad-user-data-consent) .setAdPersonalization(ad-personalization-consent); ContactInfoList.setConsent(consent); // Assign contact info list to request body. editCustomerMatchMembersRequest.setAddedContactInfoList(contactInfoList); // Edit Customer Match audience membership. EditCustomerMatchMembersResponse response = service .firstPartyAndPartnerAudiences() .editCustomerMatchMembers( audience-id, editCustomerMatchMembersRequest ) .execute(); // Display ID of updated audience. System.out.printf( "The membership of Customer Match audience ID %s was edited.", response.getFirstPartyAndPartnerAudienceId() );
Python
# Create an edit members request object. edit_member_request_obj = { 'advertiserId': advertiser-id, 'addedContactInfoList': { 'contactInfos': [ { 'hashedFirstName': hashed-customer-first-name, 'hashedLastName': hashed-customer-last-name, 'countryCode': customer-country-code, 'zipCodes': customer-zip-codes-list } ], 'consent': { 'adUserData': ad-user-data-consent, 'adPersonalization': ad-personalization-consent } } } # Build and execute request. response = service.firstPartyAndPartnerAudiences().editCustomerMatchMembers( firstPartyAndPartnerAudienceId=audience-id, body=edit_member_request_obj ).execute() # Display ID of updated audience. print('The membership of the Customer Match audience ID %s was updated.' % response["firstPartyAndPartnerAudienceId"])
PHP
// Create an edit members request object. $editMemberRequest = new Google_Service_DisplayVideo_EditCustomerMatchMembersRequest(); $editMemberRequest->setAdvertiserId(advertiser-id); // Build contact information object to add to audience. $contactInfoList = new Google_Service_DisplayVideo_ContactInfoList(); $contactInfos = array(); $contactInfo = new Google_Service_DisplayVideo_ContactInfo(); $contactInfo->setHashedFirstName(hashed-customer-first-name); $contactInfo->setHashedLastName(hashed-customer-last-name); $contactInfo->setCountryCode(customer-country-code); $contactInfo->setZipCodes(array(customer-zip-codes-list)); $contactInfos[] = $contactInfo; $contactInfoList->setContactInfos($contactInfos); // Build consent object for passing consent if granted by the end user. $consent = new Google_Service_DisplayVideo_Consent(); $consent->setAdUserData(ad-user-data-consent); $consent->setAdPersonalization(ad-personalization-consent); $contactInfoList->setConsent($consent); // Assign contactInfoList to edit members request body. $editMemberRequest->setAddedContactInfoList($contactInfoList); // Call the API, editing the audience membership. $response = $this ->service ->firstPartyAndPartnerAudiences ->editCustomerMatchMembers( audience-id, $editMemberRequest ); // Display ID of updated audience. printf( 'The membership of Customer Match audience ID %s was edited', $result['firstPartyAndPartnerAudienceId'] );