آلية عمل ميزة "الإحالات الناجحة المحسّنة للويب"
تتطلّب ميزة "الإحالات الناجحة المحسّنة للويب" إعداد علامة تُرسِل تلقائيًا معرّف نقرة، مثل GCLID ومعرّف الطلب، إلى "إعلانات Google" عندما يُجري المستخدم إحالة ناجحة. يتوفّر لك خيار إعداد ميزة الإحالات الناجحة المحسّنة من خلال أداة إدارة العلامات من Google أو علامة Google أو Google Ads API. ويتيح لك استخدام Google Ads API ميزة إرسال بيانات الإحالات الناجحة للطرف الأول خلال 24 ساعة من حدث الإحالة الناجحة، بدلاً من إرسالها في الوقت نفسه. وهذا يجعل من الممكن تحديد موقع بيانات الطرف الأول من مجموعة متنوعة من المصادر، مثل قاعدة بيانات العملاء أو نظام إدارة علاقات العملاء.
إنّ الإحالات الناجحة المحسّنة للويب في Google Ads API مكمّلة الخطوة 3 في التدفق التالي.
وبدلاً من إرسال معلومات المستخدِم المجزّأة عندما يُجري المستخدم إحالة ناجحة، تُرسل العلامة معرّف GCLID ومعرّف الطلب فقط، ويمكنك إرسال معلومات المستخدم المجزّأة لاحقًا عن طريق تحميل معرّف الطلب مع البيانات المجزّأة.
تنفيذ المتطلبات الأساسية
هناك بعض المتطلّبات الأساسية لإعداد ميزة "الإحالات الناجحة المحسّنة" الفعّالة. تأكد من استيفاء جميع المتطلبات الأساسية قبل متابعة التنفيذ:
فعِّل ميزة تتبُّع الإحالات الناجحة في حساب عميل الإحالات الناجحة في "إعلانات Google".
وافِق على شروط بيانات العملاء.
إعداد وضع العلامات.
1- تفعيل ميزة تتبُّع الإحالات الناجحة في حساب عميل الإحالات الناجحة في "إعلانات Google"
استرداد المعلومات المتعلقة بإعداد ميزة تتبُّع الإحالات الناجحة
يمكنك التحقّق من إعداد ميزة تتبُّع الإحالات الناجحة في حسابك والتأكّد
من تفعيل هذه الميزة عن طريق إجراء طلب بحث عن مورد Customer
الخاص بـ ConversionTrackingSetting
.
أدخِل الطلب التالي باستخدام GoogleAdsService.SearchStream
:
SELECT
customer.conversion_tracking_setting.google_ads_conversion_customer,
customer.conversion_tracking_setting.conversion_tracking_status,
customer.conversion_tracking_setting.conversion_tracking_id,
customer.conversion_tracking_setting.cross_account_conversion_tracking_id
FROM customer
يشير الحقل google_ads_conversion_customer
إلى حساب "إعلانات Google" الذي
يُنشئ الإحالات الناجحة لهذا العميل ويديرها. بالنسبة إلى العملاء الذين يستخدمون
تتبّع الإحالات الناجحة في جميع الحسابات،
في ما يلي رقم تعريف الحساب الإداري. يجب تقديم رقم تعريف عميل الإحالة الناجحة في "إعلانات Google" على أنّه customer_id
في طلبات إنشاء الإحالات الناجحة وإدارتها في Google Ads API.
تجدر الإشارة إلى أنّه تتمّ تعبئة هذا الحقل حتى في حال عدم تفعيل ميزة تتبُّع الإحالات الناجحة.
يشير الحقل
conversion_tracking_status
إلى ما إذا كانت ميزة تتبُّع الإحالات الناجحة مفعَّلة وما إذا كان الحساب
يستخدِم ميزة تتبُّع الإحالات الناجحة في جميع الحسابات.
إنشاء إجراء إحالة ناجحة ضمن عميل الإحالة الناجحة في "إعلانات Google"
إذا كانت قيمة conversion_tracking_status
هي NOT_CONVERSION_TRACKED
،
لن يتم تفعيل ميزة تتبُّع الإحالات الناجحة للحساب. فعِّل ميزة تتبُّع الإحالات الناجحة
عن طريق إنشاء رمز ConversionAction
واحد على الأقل في
حساب الإحالات الناجحة على "إعلانات Google"، كما في المثال التالي. بدلاً من ذلك، يمكنك إنشاء إجراء إحالة ناجحة في واجهة المستخدم باتّباع التعليمات الواردة في مركز المساعدة لنوع الإحالة الناجحة الذي تريد تفعيله.
تجدر الإشارة إلى أنّه يتم تفعيل ميزة الإحالات الناجحة المحسّنة تلقائيًا عند إرسالها من خلال Google Ads API، ولكن يمكن إيقافها من خلال واجهة مستخدِم "إعلانات Google".
مثال على الرمز البرمجي
Java
private void runExample(GoogleAdsClient googleAdsClient, long customerId) { // Creates a ConversionAction. ConversionAction conversionAction = ConversionAction.newBuilder() // Note that conversion action names must be unique. If a conversion action already // exists with the specified conversion_action_name the create operation will fail with // a ConversionActionError.DUPLICATE_NAME error. .setName("Earth to Mars Cruises Conversion #" + getPrintableDateTime()) .setCategory(ConversionActionCategory.DEFAULT) .setType(ConversionActionType.WEBPAGE) .setStatus(ConversionActionStatus.ENABLED) .setViewThroughLookbackWindowDays(15L) .setValueSettings( ValueSettings.newBuilder() .setDefaultValue(23.41) .setAlwaysUseDefaultValue(true) .build()) .build(); // Creates the operation. ConversionActionOperation operation = ConversionActionOperation.newBuilder().setCreate(conversionAction).build(); try (ConversionActionServiceClient conversionActionServiceClient = googleAdsClient.getLatestVersion().createConversionActionServiceClient()) { MutateConversionActionsResponse response = conversionActionServiceClient.mutateConversionActions( Long.toString(customerId), Collections.singletonList(operation)); System.out.printf("Added %d conversion actions:%n", response.getResultsCount()); for (MutateConversionActionResult result : response.getResultsList()) { System.out.printf( "New conversion action added with resource name: '%s'%n", result.getResourceName()); } } }
C#
public void Run(GoogleAdsClient client, long customerId) { // Get the ConversionActionService. ConversionActionServiceClient conversionActionService = client.GetService(Services.V17.ConversionActionService); // Note that conversion action names must be unique. // If a conversion action already exists with the specified name the create operation // will fail with a ConversionAction.DUPLICATE_NAME error. string ConversionActionName = "Earth to Mars Cruises Conversion #" + ExampleUtilities.GetRandomString(); // Add a conversion action. ConversionAction conversionAction = new ConversionAction() { Name = ConversionActionName, Category = ConversionActionCategory.Default, Type = ConversionActionType.Webpage, Status = ConversionActionStatus.Enabled, ViewThroughLookbackWindowDays = 15, ValueSettings = new ConversionAction.Types.ValueSettings() { DefaultValue = 23.41, AlwaysUseDefaultValue = true } }; // Create the operation. ConversionActionOperation operation = new ConversionActionOperation() { Create = conversionAction }; try { // Create the conversion action. MutateConversionActionsResponse response = conversionActionService.MutateConversionActions(customerId.ToString(), new ConversionActionOperation[] { operation }); // Display the results. foreach (MutateConversionActionResult newConversionAction in response.Results) { Console.WriteLine($"New conversion action with resource name = " + $"'{newConversionAction.ResourceName}' was added."); } } catch (GoogleAdsException e) { Console.WriteLine("Failure:"); Console.WriteLine($"Message: {e.Message}"); Console.WriteLine($"Failure: {e.Failure}"); Console.WriteLine($"Request ID: {e.RequestId}"); throw; } }
PHP
public static function runExample(GoogleAdsClient $googleAdsClient, int $customerId) { // Creates a conversion action. $conversionAction = new ConversionAction([ // Note that conversion action names must be unique. // If a conversion action already exists with the specified conversion_action_name // the create operation will fail with a ConversionActionError.DUPLICATE_NAME error. 'name' => 'Earth to Mars Cruises Conversion #' . Helper::getPrintableDatetime(), 'category' => ConversionActionCategory::PBDEFAULT, 'type' => ConversionActionType::WEBPAGE, 'status' => ConversionActionStatus::ENABLED, 'view_through_lookback_window_days' => 15, 'value_settings' => new ValueSettings([ 'default_value' => 23.41, 'always_use_default_value' => true ]) ]); // Creates a conversion action operation. $conversionActionOperation = new ConversionActionOperation(); $conversionActionOperation->setCreate($conversionAction); // Issues a mutate request to add the conversion action. $conversionActionServiceClient = $googleAdsClient->getConversionActionServiceClient(); $response = $conversionActionServiceClient->mutateConversionActions( MutateConversionActionsRequest::build($customerId, [$conversionActionOperation]) ); printf("Added %d conversion actions:%s", $response->getResults()->count(), PHP_EOL); foreach ($response->getResults() as $addedConversionAction) { /** @var ConversionAction $addedConversionAction */ printf( "New conversion action added with resource name: '%s'%s", $addedConversionAction->getResourceName(), PHP_EOL ); } }
Python
def main(client, customer_id): conversion_action_service = client.get_service("ConversionActionService") # Create the operation. conversion_action_operation = client.get_type("ConversionActionOperation") # Create conversion action. conversion_action = conversion_action_operation.create # Note that conversion action names must be unique. If a conversion action # already exists with the specified conversion_action_name, the create # operation will fail with a ConversionActionError.DUPLICATE_NAME error. conversion_action.name = f"Earth to Mars Cruises Conversion {uuid.uuid4()}" conversion_action.type_ = ( client.enums.ConversionActionTypeEnum.UPLOAD_CLICKS ) conversion_action.category = ( client.enums.ConversionActionCategoryEnum.DEFAULT ) conversion_action.status = client.enums.ConversionActionStatusEnum.ENABLED conversion_action.view_through_lookback_window_days = 15 # Create a value settings object. value_settings = conversion_action.value_settings value_settings.default_value = 15.0 value_settings.always_use_default_value = True # Add the conversion action. conversion_action_response = ( conversion_action_service.mutate_conversion_actions( customer_id=customer_id, operations=[conversion_action_operation], ) ) print( "Created conversion action " f'"{conversion_action_response.results[0].resource_name}".' )
Ruby
def add_conversion_action(customer_id) # GoogleAdsClient will read a config file from # ENV['HOME']/google_ads_config.rb when called without parameters client = Google::Ads::GoogleAds::GoogleAdsClient.new # Add a conversion action. conversion_action = client.resource.conversion_action do |ca| ca.name = "Earth to Mars Cruises Conversion #{(Time.new.to_f * 100).to_i}" ca.type = :UPLOAD_CLICKS ca.category = :DEFAULT ca.status = :ENABLED ca.view_through_lookback_window_days = 15 # Create a value settings object. ca.value_settings = client.resource.value_settings do |vs| vs.default_value = 15 vs.always_use_default_value = true end end # Create the operation. conversion_action_operation = client.operation.create_resource.conversion_action(conversion_action) # Add the ad group ad. response = client.service.conversion_action.mutate_conversion_actions( customer_id: customer_id, operations: [conversion_action_operation], ) puts "New conversion action with resource name = #{response.results.first.resource_name}." end
Perl
sub add_conversion_action { my ($api_client, $customer_id) = @_; # Note that conversion action names must be unique. # If a conversion action already exists with the specified conversion_action_name, # the create operation fails with error ConversionActionError.DUPLICATE_NAME. my $conversion_action_name = "Earth to Mars Cruises Conversion #" . uniqid(); # Create a conversion action. my $conversion_action = Google::Ads::GoogleAds::V17::Resources::ConversionAction->new({ name => $conversion_action_name, category => DEFAULT, type => WEBPAGE, status => ENABLED, viewThroughLookbackWindowDays => 15, valueSettings => Google::Ads::GoogleAds::V17::Resources::ValueSettings->new({ defaultValue => 23.41, alwaysUseDefaultValue => "true" })}); # Create a conversion action operation. my $conversion_action_operation = Google::Ads::GoogleAds::V17::Services::ConversionActionService::ConversionActionOperation ->new({create => $conversion_action}); # Add the conversion action. my $conversion_actions_response = $api_client->ConversionActionService()->mutate({ customerId => $customer_id, operations => [$conversion_action_operation]}); printf "New conversion action added with resource name: '%s'.\n", $conversion_actions_response->{results}[0]{resourceName}; return 1; }
تأكَّد من ضبط السمة conversion_action_type
على قيمة
ConversionActionType
الصحيحة.
لمزيد من الإرشادات عن إنشاء إجراءات الإحالات الناجحة في Google Ads API، يُرجى الاطّلاع على مقالة إنشاء إجراءات الإحالات الناجحة.
استرداد إجراء إحالة ناجحة حالي
يمكنك استرداد تفاصيل إجراء إحالة ناجحة حالي عن طريق إصدار طلب البحث التالي. تأكّد من ضبط الرقم التعريفي للعميل في الطلب على عميل الإحالات الناجحة في "إعلانات Google"
الذي حدّدته أعلاه، ومن ضبط نوع إجراء الإحالة الناجحة
على قيمة
ConversionActionType
الصحيحة.
SELECT
conversion_action.resource_name,
conversion_action.name,
conversion_action.status
FROM conversion_action
WHERE conversion_action.type = 'WEBPAGE'
2. قبول شروط بيانات العملاء
يجب قبول بنود بيانات العملاء قبل أن تتمكّن من استخدام ميزة "الإحالات الناجحة المحسّنة للويب". يمكنك التحقّق ممّا إذا تم قبول بنود بيانات العملاء من خلال إصدار الطلب التالي إلى عميل الإحالات الناجحة في "إعلانات Google":
SELECT
customer.id,
customer.conversion_tracking_setting.accepted_customer_data_terms
FROM customer
إذا كانت قيمة accepted_customer_data_terms
هي false
، اتّبِع التعليمات الواردة في
مركز المساعدة
لإكمال هذا الشرط الأساسي.
3- إعداد وضع العلامات
يمكنك ضبط عملية وضع العلامات لموقعك الإلكتروني باتّباع التعليمات الواردة في مركز المساعدة.
عليك أيضًا إضافة معرّفات المعاملات، المعروفة أيضًا باسم معرّفات الطلبات، إلى علامة تتبُّع الإحالات الناجحة باتّباع التعليمات الواردة في مركز المساعدة. تتطلّب "إعلانات Google" أن تكون هذه العناصر قادرة على العثور على الإحالة الناجحة لتحسينها.
الخطوات التالية
بعد استيفاء المتطلبات الأساسية، ستتمكّن من تنفيذ الإحالات الناجحة المحسّنة للويب في Google Ads API.