الخطوات الأولى

يجب تفعيل ميزة تتبُّع الإحالات الناجحة في حساب الإحالات الناجحة على "إعلانات Google" من أجل تسجيل الإحالات الناجحة. يوفّر هذا الدليل تفاصيل حول كيفية تأكيد أو إذا كانت ميزة تتبُّع الإحالات الناجحة مفعَّلة، أو إذا لم تكن مفعَّلة، واسترجاع معلومات عن إجراءات الإحالات الناجحة الحالية

تتطلب معظم إجراءات الإحالة الناجحة أيضًا خطوات إضافية من جانبك لتتبُّعها. معهم. للاطّلاع على القائمة الكاملة بالمتطلبات، انتقِل إلى مركز المساعدة. المقالة في مركز المساعدة لإجراء الإحالات الناجحة

تفعيل ميزة تتبُّع الإحالات الناجحة في حساب الإحالات الناجحة على "إعلانات 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 = 'INSERT_CONVERSION_ACTION_TYPE'

تتبّع الإحالات الناجحة في جميع الحسابات

إذا كنت تستخدم الإحالة الناجحة في جميع الحسابات للتتبُّع، تعرض الدالة ConversionActionService القيمة إجراءات الإحالات الناجحة التالية:

  • كل إجراءات الإحالة الناجحة التي حدّدها الحساب الإداري الذي يستخدِمه الحساب من أجل تتبُّع الإحالات الناجحة في جميع الحسابات
  • كل إجراءات الإحالة الناجحة التي تراكمت على العميل إحصاءات عنها، بما في ذلك والإجراءات التي يحددها النظام والإجراءات التي يملكها المدير حتى لو كان هذا المدير إلغاء الربط لاحقًا
  • كل الإجراءات التي حدّدها العميل في حسابه
  • الإحالات الناجحة على "إحصاءات Google" التي تم إنشاؤها في مواقع "إحصاءات Google" المرتبطة ويشمل ذلك إجراءات الإحالات الناجحة من "إحصاءات Google" التي لم يتمّ استيرادها إلى "إعلانات Google". والتي لها حالة HIDDEN

يمكنك إعداد إجراءات الإحالات الناجحة في جميع الحسابات وإجراء طلبات بحث عنها باستخدام واجهة برمجة التطبيقات، ولكن لا يمكنك تفعيل ميزة تتبُّع الإحالات الناجحة في جميع الحسابات في حساباتك من خلال واجهة برمجة التطبيقات. لا يمكنك تفعيل الإحالات الناجحة في جميع الحسابات أو إيقافها إلا باستخدام واجهة مستخدم "إعلانات Google" للحساب الإداري