Anfrage verarbeiten

Eine Echtzeitgebotsinteraktion beginnt, wenn Google eine Gebotsanfrage an Ihre Anwendung sendet. In diesem Leitfaden wird beschrieben, wie Sie Ihre Anwendung so programmieren, dass die Gebotsanfrage verarbeitet wird.

Anfrage zum Parsen

Google sendet eine Gebotsanfrage, die entweder im OpenRTB-JSON- oder im Protobuf-Format serialisiert und als Nutzlast einer HTTP-POST-Anfrage angehängt ist. Das empfangene Format hängt von der Konfiguration Ihres Endpunkts ab. Beispiel für eine Gebotsanfrage

Sie müssen diese Anfrage parsen, um die serialisierte BidRequest zu erhalten. Wenn Sie das Protobuf-Format verwenden, müssen Sie openrtb.proto und openrtb-adx.proto von der Seite Referenzdaten herunterladen und damit eine Bibliothek generieren, mit der die BidRequest-Nachricht geparst werden kann. Mit dem folgenden C++-Code wird beispielsweise eine Anfrage mit einem POST-Payload in einem String geparst:

string post_payload = /* the payload from the POST request */;
BidRequest bid_request;
if (bid_request.ParseFromString(post_payload)) {
  // Process the request.
}

Sobald Sie das BidRequest haben, können Sie es als Objekt verwenden und die benötigten Felder extrahieren und interpretieren. In C++ könnte das Durchlaufen von Deals in einer OpenRTB-`BidRequest` beispielsweise so aussehen:

for (const BidRequest::Imp::Pmp::Deal& deal : pmp.deals()) {
  DoSomething(deal.id(), deal.wseat());
}

Abrechnungs-IDs

Sie erhalten eine Gebotsanfrage, wenn das Anzeigeninventar eines Publishers auf eine oder mehrere Ihrer Pre-Targeting-Konfigurationen ausgerichtet ist. BidRequest.imp.ext.billing_id wird mit den Abrechnungs-IDs aller infrage kommenden Käufer und relevanten Pretargeting-Konfigurationen gefüllt. Außerdem können Sie für Deal-Inventar mit BidRequest.imp.pmp.deal.ext.billing_id Abrechnungs-IDs finden, die mit den entsprechenden Käufern verknüpft sind. Beim Abgeben eines Gebots dürfen nur Abrechnungs-IDs von Käufern angegeben werden, die in der Gebotsanfrage enthalten sind.

Wenn in der Gebotsanfrage mehrere Abrechnungs-IDs enthalten sind, müssen Sie mit dem Feld BidResponse.seatbid.bid.ext.billing_id die Abrechnungs-ID des Käufers angeben, dem Sie Ihr Gebot zuordnen möchten.

imp {
  ext {
    // The billing IDs of all of your matching pretargeting configs and eligible child seats are
    // stored in a flat list here.
    billing_id: 123
    billing_id: 456
    billing_id: 789
  }
  pmp {
    // All eligible deals are stored in a single flat list.
    deal {
      id: 1000
      ext {
        // The specific billing IDs eligible to bid on this deal are indicated here.
        billing_id: 789
      }
      ...
    }
    deal {
      id: 2000
      ext {
        billing_id: 123
        billing_id: 456
      }
      ...
    }
  }
  ...
}
...

Blockierte Kategorien ermitteln

Wenn Sie ein Gebot abgeben, dürfen für das enthaltene Creative keine Kategorien erkannt worden sein, die vom Publisher blockiert wurden. Andernfalls wird das Gebot aus der Auktion herausgefiltert.

Die blockierten Kategorien für eine Impression finden Sie im Feld BidRequest.bcat. Dieses Feld wird mit Kategorien aus der Taxonomie gefüllt, die für Ihr Konto konfiguriert ist.

Im folgenden Beispiel sehen Sie blockierte Kategorien basierend auf einer konfigurierten Anzeigenkategorietaxonomie:

Version 1.0 der IAB-Taxonomie für Inhalte

// Bid request
{
  // Indicates the blocked categories using IAB Content 1.0 Taxonomy.
  "bcat": [
    "IAB9-9",  // Cigars
    "IAB8-18"  // Wine
  ]
  "imp": {
    ...
  }
}
      
// Bid request
{
  // Indicates the blocked categories using Google Ad Category Taxonomy.
  "bcat": [
    "10138",  // Cigar and tobacco collecting
    "10080",  // Tobacco
    "11649",  // Wine
    "10674",  // Wine collecting
    "13008"   // Wine clubs
  ]
  "imp": {
    ...
  }
}
      

Wörterbuchdateien

In der Gebotsanfrage werden Kennungen verwendet, die in Wörterbuchdateien definiert sind. Diese sind auf der Seite Referenzdaten verfügbar.

URL-Makros für Gebote

Optional können einige Informationen aus BidRequest mithilfe von Makros in die URLs von Gebotsendpunkten eingefügt werden. Wenn Sie eine Endpunkt-URL mit einem oder mehreren Makros konfigurieren, werden diese erweitert, sofern die entsprechenden Informationen in der Gebotsanfrage enthalten sind. Das kann beispielsweise nützlich sein, wenn Sie den Lastenausgleich anhand von Informationen in der BidRequest durchführen möchten. Wenden Sie sich an Ihren Account Manager, um Unterstützung für neue Makros anzufordern.

MacroBeschreibung
%%GOOGLE_USER_ID%%

Wird durch die Google-Nutzer-ID in BidRequest.user.id ersetzt. Die Bieter-URL http://google.bidder.com/path?gid=%%GOOGLE_USER_ID%% wird beispielsweise bei der Anfrage durch http://google.bidder.com/path?gid=dGhpyBhbiBleGFtGxl ersetzt.

Wenn die Google-Nutzer-ID unbekannt ist, wird der leere String eingesetzt, mit einem Ergebnis ähnlich dem folgenden:

http://google.bidder.com/path?gid=
%%HAS_MOBILE%%

Wird durch 1 ersetzt, um anzugeben, dass die Gebotsanfrage von einem Mobilgerät stammt, oder durch 0, wenn dies nicht der Fall ist. Dies basiert auf dem Wert von BidRequest.device.devicetype, wobei Mobilgeräte durch HIGHEND_PHONE (4) oder Tablet (5) angegeben werden.

%%HAS_VIDEO%%

Wird durch 1 ersetzt, wenn die Gebotsanfrage Videoinventar enthält, andernfalls durch 0. Das hängt davon ab, ob BidRequest.imp.video in der Gebotsanfrage enthalten ist.

%%HOSTED_MATCH_DATA%%

Wird durch einen Wert basierend auf BidRequest.user.buyeruid ersetzt.

%%MOBILE_IS_APP%%

Wird durch 1 ersetzt, um anzugeben, dass die Gebotsanfrage für Inventar in mobilen Apps gilt. Andernfalls wird 0 verwendet. Dies hängt davon ab, ob BidRequest.app ausgefüllt ist.

App-ID anhand der Transaktions-URL ermitteln

Bei Transaktionen in mobilen Apps werden URLs gemeldet, die so aussehen:

mbappgewtimrzgyytanjyg4888888.com

Verwenden Sie einen Base32-Decoder, um den fettgedruckten Teil des Strings (gewtimrzgyytanjyg4888888) zu decodieren.

Sie können einen Onlinedecoder verwenden, müssen aber die Buchstaben in Großbuchstaben umwandeln und nachgestellte 8-Werte durch =-Werte ersetzen.

So wird dieser Wert decodiert:

GEWTIMRZGYYTANJYG4======
führt zu:
1-429610587
Der String 429610587 ist die App-ID für die iOS-App iFunny.

Ein weiteres Beispiel: Die gemeldete URL lautet:

mbappgewtgmjug4ytmmrtgm888888.com
Diesen Wert decodieren:
GEWTGMJUG4YTMMRTGM======
führt zu:
1-314716233
Das Ergebnis 314716233 ist die App-ID für die iOS-App TextNow.

Namen von mobilen Apps anhand der Transaktions-URL ermitteln

Hier ist ein Beispiel für das Abrufen des App-Namens. Die gemeldete URL lautet:

mbappMFUXELTDN5WS42DZOBQWQLTJN4XHG3DJORUGK4Q888.com
Diesen Wert decodieren:
MFUXELTDN5WS42DZOBQWQLTJN4XHG3DJORUGK4Q===
führt zu:
air.com.hypah.io.slither
Das Ergebnis entspricht der Android-App slither.io.

Open Bidding-Felder

Gebotsanfragen, die an Anzeigenplattformen und Netzwerkbieter gesendet werden, die an Open Bidding teilnehmen, ähneln denen von Authorized Buyers, die an standardmäßigen Echtzeitgeboten teilnehmen. Open Bidding-Kunden erhalten eine kleine Anzahl zusätzlicher Felder und einige vorhandene Felder können alternative Verwendungszwecke haben. Dazu gehören:

OpenRTB Details
BidRequest.imp.ext.dfp_ad_unit_code

Enthält den Ad Manager-Netzwerkcode des Publishers, gefolgt von der Anzeigenblockhierarchie, getrennt durch Schrägstriche.

Ein Beispiel dafür, wie das mit Formatierung aussehen könnte: /1234/cruises/mars.

BidRequest.user.data.segment

Wiederholte Schlüssel/Wert-Paare, die vom Publisher an den Anzeigenplattform-Bieter gesendet werden.

Sie können festlegen, dass die Werte Schlüssel/Wert-Paare sind, die vom Publisher gesendet werden, wenn BidRequest.user.data.name auf “Publisher Passed” gesetzt ist.

Zulässige Anbieter deklarieren

Technologieanbieter, die Dienste wie Marktforschung, Remarketing und Anzeigenbereitstellung anbieten, können eine Rolle bei der Interaktion zwischen Käufern und Verkäufern spielen. Nur Anbieter, die von Google für die Teilnahme an Authorized Buyers-Interaktionen geprüft wurden, sind zulässig.

Um die BidRequest zu verstehen und Ihre BidResponse zu erstellen, müssen Sie die beiden verschiedenen Möglichkeiten zum Deklarieren von Technologieanbietern kennen:

  1. Einige Anbieter müssen nicht deklariert werden. Sie sind in der Liste der für Ad Manager zertifizierten externen Anbieter aufgeführt.
  2. Andere Anbieter können nur teilnehmen, wenn sie in der BidRequest angegeben sind:
    • Im BidRequest gibt das Feld BidRequest.imp.ext.allowed_vendor_type an, welche Anbieter der Verkäufer zulässt. Anbieter, die in der allowed_vendor_type gesendet werden, sind in der Wörterbuchdatei vendors.txt aufgeführt.

Beispiel für eine Gebotsanfrage

Die folgenden Beispiele sind für Menschen lesbare Beispiele für die Protobuf- und JSON-Anfragen.

OpenRTB-Protobuf

OpenRTB-JSON

So können Sie die Gebotsanfrage in ein Binärformat konvertieren, wie Sie es von der POST-Nutzlast in einer echten Anfrage erhalten würden (in C++). Dies gilt jedoch nicht für OpenRTB-JSON.

string text_format_example = /* example from above */;
BidRequest bid_request;
if (TextFormat::ParseFromString(text_format_example, &bid_request)) {
  string post_payload;
  if (bid_request.SerializeToString(&post_payload)) {
    // post_payload is a binary serialization of the protocol buffer
  }
}

Feedback in Echtzeit

Echtzeit-Feedback ist für Authorized Buyers-Nutzer sowie für Anzeigenplattformen und Netzwerke verfügbar, die Open Bidding verwenden.

Echtzeit-Feedback wird in BidRequest.ext.bid_feedback auf Grundlage des Ergebnisses eines oder mehrerer Gebote, die Sie zuvor abgegeben haben, eingefügt. Es kann verwendet werden, um Details wie das Ergebnis des Gebots in der Auktion oder das Mindestgebot zu ermitteln, das erforderlich gewesen wäre, um die Auktion zu gewinnen. Wenden Sie sich an Ihren Account Manager, um Echtzeit-Feedback zu aktivieren.

Zusätzlich zu den Standardfeldern, die im Feedback zur Gebotsantwort gesendet werden, können Sie auch benutzerdefinierte Daten in der Gebotsantwort über das Feld BidResponse.seatbid.bid.ext.event_notification_token senden. Die event_notification_token sind beliebige Daten, die nur dem Bieter bekannt sind und die beim Debuggen helfen können, z. B. eine neue Targeting-ID oder eine Gebots-ID, die eine neue Taktik darstellt, oder Metadaten, die nur dem Bieter bekannt sind und mit dem Creative verknüpft sind. Weitere Informationen finden Sie in der OpenRTB Extensions Protocol Buffer file.

Wenn Authorized Buyers eine Gebotsanfrage an einen Bieter sendet, antwortet dieser mit einem BidResponse. Wenn der Bieter Echtzeit-Feedback aktiviert hat, sendet Authorized Buyers in einer nachfolgenden Gebotsanfrage Feedback zur Antwort in einer BidFeedback-Nachricht:

message BidFeedback {
  // The unique id from BidRequest.id.
  optional string request_id = 1;

  // The status code for the ad. See creative-status-codes.txt in the
  // technical documentation for a list of ids.
  optional int32 creative_status_code = 2;

  // Deprecated. This field is not populated and will be removed after March,
  // 2025. If the bid won the auction, this is the price paid in your account
  // currency. If the bid participated in the auction but was out-bid, this
  // is the CPM that should have been exceeded in order to win. This is not
  // set if the bid was filtered prior to the auction, if the publisher or
  // winning bidder has opted out of price feedback or if your account has
  // opted out of sharing winning prices with other bidders. For first-price
  // auctions, minimum_bid_to_win is populated instead of this field.
  optional double price = 3 [deprecated = true];

  // The minimum bid value necessary to have won the auction, in your account
  // currency. If your bid won the auction, this is the second highest bid
  // that was not filtered (including the floor price). If your bid didn't win
  // the auction, this is the winning candidate's bid. This field will only be
  // populated if your bid participated in a first-price auction, and will not
  // be populated if your bid was filtered prior to the auction.
  optional double minimum_bid_to_win = 6;

  // Deprecated. This field will be removed in February 2026.
  // The minimum bid value necessary to have won the server-side component of
  // the overall auction given that there was also an interest group bidding
  // component to the overall auction which ran using the Protected Audience
  // API. The value is expressed in CPM of the buyer account currency. The
  // minimum bid to win for the overall auction, including bids from the
  // server-side and the on-device interest group components, is populated in
  // the minimum_bid_to_win field of the same BidFeedback object.
  optional double sscminbidtowin = 14 [deprecated = true];

  // Billable event rate multiplier that was applied to this bid during
  // ranking. The adjustment reflects the likelihood that your bid would
  // generate a billable event (namely, the ad renders successfully) if it won
  // the auction, relative to the probability that other bids generate a
  // billable event if they won the auction. This adjustment can be larger or
  // smaller than 1. This affects the final ranking in the auction only; in
  // particular, this multiplier does not affect the payment or whether the
  // bid clears any floor price.
  optional float billable_event_rate_bid_adjustment = 13 [default = 1];

  // When a publisher uses an RTB auction and waterfall-based SDK mediation on
  // the same query, the winner of the real-time auction must also compete in
  // a mediation waterfall (which is ordered by price) to win the impression.
  // If the bid participated in the auction and there was no waterfall, the
  // value of this field is 0. If the bid participated in the auction and
  // there was a waterfall, the value of this field is a price representing a
  // sample bid from the eligible mediation networks that were higher than the
  // auction winner, weighted by expected fill rate. This field can be used
  // in conjunction with minimum_bid_to_win to train bidding models. The CPM
  // is in your account currency.
  optional double sampled_mediation_cpm_ahead_of_auction_winner = 8;

  message EventNotificationToken {
    // The contents of the token.
    optional string payload = 1;
  }

  // The token included in the corresponding bid.
  optional EventNotificationToken event_notification_token = 4;

  // The creative ID included in the corresponding bid.
  optional string buyer_creative_id = 5;

  // Possible types of bid response feedback objects.
  enum FeedbackType {
    FEEDBACK_TYPE_UNSPECIFIED = 0;

    // Feedback for a bid that was submitted on a bid response.
    BID_FEEDBACK = 1;

    // Feedback for an interest group buyer submitted on a bid response to
    // particpate in an interest group bidding component of the auction run
    // using the Protected Audience API.
    INTEREST_GROUP_BUYER_FEEDBACK = 2;
  }

  // Deprecated. This field will be removed in February 2026.
  // The type of the BidFeedback message. Google will send separate
  // BidFeedback objects for:
  // a) Each bid submitted on a bid response
  // b) Each buyer submitted on a bid response to particpate in an interest
  // group bidding component of the auction run using the Protected Audience
  // API.
  optional FeedbackType feedbacktype = 15 [deprecated = true];

  // Deprecated. This field will be removed in February 2026.
  // Origin of an interest group buyer that was included in the bid response.
  // This field is populated only for feedback where a bidder opted in an
  // interest group buyer to participate in the interest group bidding
  // component of the overall auction run using the Protected Audience API.
  // To learn more about origins, see https://www.rfc-editor.org/rfc/rfc6454.
  // To learn more about interest group bidding and the Protected Audience
  // API, see
  // https://developers.google.com/authorized-buyers/rtb/fledge-origin-trial.
  optional string buyerorigin = 16 [deprecated = true];

  // Deprecated. This field will be removed in February 2026.
  // The status code for the submitted interest group buyer. This field is
  // only populated in the feedback for an interest group buyer that a bidder
  // requested to enter into the interest group auction through the bid
  // response. Individual creative status codes of bids submitted by the buyer
  // in the on-device interest group auction are not available. See
  // https://storage.googleapis.com/adx-rtb-dictionaries/interest-group-buyer-status-codes.txt
  // for a list of interest group buyer status codes.
  optional int32 igbuyerstatus = 17 [deprecated = true];
}

Das erste Feld, das Sie in dieser Meldung prüfen sollten, ist bid_feedback.creative_status_code. Die Bedeutung des Codes finden Sie in creative-status-codes.txt. Wenn Sie das Gebot gewinnen, können Sie das Preis-Feedback deaktivieren. Weitere Informationen finden Sie unter Deaktivierung.

Das Echtzeit-Feedback enthält die Gebotsanfrage-ID und eine der folgenden Informationen:

Auktionsergebnis Feedback in Echtzeit
Der Käufer hat kein Gebot abgegeben. Nichts.
Der Käufer hat ein Gebot abgegeben, das herausgefiltert wurde, bevor es die Auktion erreicht hat. Der Creative-Statuscode (creative-status-codes.txt).
Der Käufer hat ein Gebot abgegeben, aber die Auktion verloren. Der Creative-Statuscode 79 (in der Auktion überboten).
Der Käufer hat ein Gebot abgegeben, mit dem er die Auktion gewonnen hat. Der Abrechnungspreis und der Creative-Statuscode 1.

Bei einem App-Impression und einem Creative-Statuscode von 83 hat der App-Publisher möglicherweise einen Vermittlungs-Waterfall verwendet. Das Gewinnergebot hätte dann mit anderen Anfragen in der Passback-Waterfall-Kette des Publishers konkurriert. Informationen zur Verwendung von sampled_mediation_cpm_ahead_of_auction_winner bei Geboten

Beispiel

Im Folgenden finden Sie ein Beispiel für Echtzeit-Feedback in unterstützten Protokollen:

OpenRTB-Protobuf

OpenRTB-JSON

Gebotsmodell für Erstpreisauktionen erstellen

Nachdem Sie ein Gebot in einer Erstpreisauktion abgegeben haben, erhalten Sie Echtzeit-Feedback, einschließlich der Felder minimum_bid_to_win und sampled_mediation_cpm_ahead_of_auction_winner, wenn das Gebot nicht aus der Auktion herausgefiltert wurde. Anhand dieser Signale lässt sich die Gebotslogik so anpassen, dass Sie das Gebot erhöhen oder senken können, um den Impression zu gewinnen.

  • minimum_bid_to_win: Das Mindestgebot, das hätte abgegeben werden können, um die Echtzeitauktion zu gewinnen. Wenn Sie die Auktion gewonnen haben, ist dies das niedrigste Gebot, das Sie hätten abgeben können, um trotzdem zu gewinnen. Wenn Sie die Auktion verloren haben, ist dies das Höchstgebot.
  • sampled_mediation_cpm_ahead_of_auction_winner: Wenn es andere Netzwerke in der Vermittlungskette gibt, ist der Wert dieses Felds ein Preis, der ein Beispielgebot von einem der infrage kommenden Vermittlungsnetzwerke darstellt, das höher als das Gebot des Auktionsgewinners war. Er wird nach der erwarteten Ausfüllrate gewichtet. Dieser Wert wird auf 0 gesetzt, wenn keine der Netzwerke in der Vermittlungskette Anzeigen ausliefern sollen oder wenn der Publisher keine SDK-Vermittlung verwendet.

Funktionsweise

Um die Berechnungen zu beschreiben, mit denen die möglichen Werte für minimum_bid_to_win und sampled_mediation_cpm_ahead_of_auction_winner ermittelt werden, müssen wir zuerst Folgendes definieren:

  • Im Folgenden sind die CPMs in der Vermittlungskette in absteigender Reihenfolge aufgeführt:
    \[C_1, C_2, …, C_n\]
  • Die entsprechenden Fill-Raten für die CPMs in der Vermittlungskette sind:
    \[f_1, f_2, …, f_n\]
  • Die folgende Funktion wird verwendet, um den erwarteten CPM und die zugehörige Wahrscheinlichkeit aus dem Vermittlungskettenelement \(i\)anhand der angegebenen Fillrate zu bestimmen:
    \(X_i = \{C_i\) mit Wahrscheinlichkeit \(f_i\); \(0\) mit Wahrscheinlichkeit \(1 - f_i\}\)
  • Die endgültige Vermittlungskette sieht so aus:
    \[\{C_1, C_2, …, C_K, W\}\]
    Dabei ist \(W\) das erfolgreiche Gebot und \(C_K > W >= C_{K+1}\)
  • Der Mindestpreis wird als \(F\)angegeben.
  • Das zweitbeste Gebot wird als \(R\)bezeichnet.
Berechnungen für den Auktionsgewinner
Feld Berechnung
minimum_bid_to_win
\(max\{F, R, X_{K+1}, …, X_n\}\)
sampled_mediation_cpm_ahead_
of_auction_winner
\(\{C_i\) mit einer Wahrscheinlichkeit von \(\prod_{j=1}^{i-1}(1-f_j) \cdot f_i \div \prod_{j=1}^{K}(1-f_j)\}\)
Für \(1 <= i <= K\).

Berechnungen für den Auktionsverlierer
Feld Berechnung
minimum_bid_to_win
\(max\{F, W\}\)
sampled_mediation_cpm_ahead_
of_auction_winner
\(max\{X_1, …, X_K\}\)

Beispiel mit einer einfachen Mediationskette

Angenommen, ein Publisher verwendet sowohl Echtzeitgebote als auch eine SDK-Vermittlungskette:

SDK-Vermittlungskette Erwarteter CPM Ausführungsrate
Netzwerk 1 \(C_1 = $3.00\) \(f_1 = 5\%\)
Netzwerk 2 \(C_2 = $2.00\) \(f_2 = 45\%\)
Netzwerk 3 \(C_3 = $0.50\) \(f_3 = 80\%\)
Netzwerk 4 \(C_4 = $0.10\) \(f_4 = 85\%\)

Angenommen, das Ergebnis der RTB-Auktion ist Folgendes:

RTB-Auktion CPM
Auktionsgewinner (W) 1,00 $
Zweitplatzierter in der Auktion (R) 0,05 $
Mindestpreis / Mindestpreis (F) 0 $
Gebot, mit dem die Auktion gewonnen wurde

Im Folgenden sehen Sie ein Beispiel dafür, wie Werte und Wahrscheinlichkeiten für minimum_bid_to_win und sampled_mediation_cpm_ahead_of_auction_winner für ein gewonnenes Gebot berechnet werden.

minimum_bid_to_win Probability
\(max(F, R, C_3) = $0.50\) \(f_3 = 80\%\)
\(max(F, R, C_4) = $0.10\) \((1-f_3) \cdot f_4 = 17\%\)
\(max(F, R, 0) = $0.05\) \((1-f_3) \cdot (1-f_4) = 3\%\)
sampled_mediation_cpm_
ahead_of_auction_winner
Probability
\(C_1 = $3.00\) \(f_1 \div (1-(1-f_1) \cdot (1-f_2)) =~ 10.5\%\)
\(C_2 = $2.00\) \(((1-f_1) \cdot f_2) \div (1-(1-f_1) \cdot (1-f_2)) =~ 89.5\%\)
Gebote, mit denen die Auktion nicht gewonnen wurde

Im Folgenden sehen Sie ein Beispiel dafür, wie Werte und Wahrscheinlichkeiten für minimum_bid_to_win und sampled_mediation_cpm_ahead_of_auction_winner für verlorene Gebote berechnet werden.

minimum_bid_to_win Probability
\(max(F, W) = $1.00\) \(100\%\)
sampled_mediation_cpm_
ahead_of_auction_winner
Probability
\(C_1 = $3.00\) \(f_1 = 5\%\)
\(C_2 = $2.00\) \((1-f_1) \cdot f_2 =~ 42.8\%\)
\(0\) \((1-f_1) \cdot (1-f_2) =~ 52.2\%\)

Aufschlüsselung von Gebotsanfragen

Bei der Gebotsvereinfachung wird ein einzelnes komplexes BidRequest in mehrere Gebotsanfragen aufgeteilt, die an Ihre Anwendung gesendet werden. Wenn eine Gebotsanfrage vereinfacht wird, können Sie erkennen, welche Gebotsanfragen Teil des Originals waren, da sie im Feld BidRequest.ext.google_query_id denselben Wert haben.

Die Aufschlüsselung von Geboten ist standardmäßig aktiviert. Wenn Sie sie deaktivieren möchten, wenden Sie sich an Ihren Account Manager.

Anzeigenformate

Bei einigen Anzeigenmöglichkeiten sind mehrere Formate möglich. Bei der Gebotsaufschlüsselung wird jedes Format in einer separaten Gebotsanfrage gesendet. Attribute wie die infrage kommenden Abrechnungs-IDs sind für das in der Anfrage angegebene Format relevant.

Gebotsanfragen mit den folgenden Formaten werden in separate Gebotsanfragen aufgeschlüsselt:

  • Banner
  • Video
  • Audio
  • Nativ

Beispiel für die Vereinheitlichung von Anzeigenformaten

Unten sehen Sie ein Beispiel für eine vereinfachte OpenRTB-JSON-Gebotsanfrage ohne Abflachung des Anzeigenformats im Vergleich zu einer entsprechenden Gruppe von abgeflachten Anfragen:

Vor dem Glätten

Nach dem Reduzieren

Angebote

Eine Anzeigenmöglichkeit für einen bestimmten Bieter kann neben der offenen Auktion auch für verschiedene Arten von Deals gelten. Bei der Aufschlüsselung von Gebotsanfragen für Deals wird eine Gebotsanfrage für die offene Auktion und eine für jeden Typ von Festpreis-Deal gesendet. In der Praxis können sich Anzeigenbeschränkungen zwischen Auktionen und Festpreis-Dealtypen unterscheiden. Für eine bestimmte Videoanzeigenmöglichkeit, die sowohl für die offene Auktion als auch für einen Festpreis-Deal verfügbar ist, erhält ein Bieter beispielsweise separate Gebotsanfragen, in denen sich Beschränkungen wie die maximale Anzeigendauer und die Frage, ob überspringbare Anzeigen zulässig sind, unterscheiden können. Durch die Glättung der Werbegelegenheit lassen sich die Anzeigenbeschränkungen für die offene Auktion und den Deal mit Festpreis leichter erkennen.

Überspringbarkeit und Videodauer

In der OpenRTB-Spezifikation gibt es keine separaten Felder zum Angeben der maximalen Videodauer für überspringbare und nicht überspringbare Anzeigen. Bei der Implementierung von Google wird die Gebotsglättung verwendet, um mithilfe der vorhandenen Felder BidRequest.video.maxduration und BidRequest.video.skip zwischen diesen zu unterscheiden.

Im Folgenden sehen Sie ein Beispiel dafür, wie Videoinventar vereinfacht wird, wenn die maximale Dauer einer nicht überspringbaren Anzeige 15 und die maximale Dauer einer überspringbaren Anzeige 60 ist.

Beispiel max_ad_duration skip (true ODER false)
Ursprüngliche Anfrage ohne Reduzierung 15 true
Aufgeschlüsselte Anfrage 1: Nicht überspringbar 15 false
Aufgeschlüsselte Anfrage 2: Überspringbar 60 true

Die Aufschlüsselung von Gebotsanfragen für überspringbare Videodauer erfolgt nur, wenn die folgenden Bedingungen erfüllt sind:

  • Die Anfrage erlaubt Videos.
  • Sowohl überspringbare als auch nicht überspringbare Videos sind zulässig. Die beiden maximalen Dauern unterscheiden sich.
  • Diese Anfrage kann für private oder offene Auktionen verwendet werden.

Wenn Sie diese Art der Aufschlüsselung deaktivieren möchten, wenden Sie sich an Ihren Technical Account Manager. Wenn diese Option deaktiviert ist und der Publisher sowohl überspringbare als auch nicht überspringbare Videoanzeigen mit unterschiedlichen maximalen Dauern je nach Überspringbarkeit zulässt, wird skip auf true und maxduration auf die kürzere Dauer zwischen den Beschränkungen für überspringbare und nicht überspringbare Anzeigen festgelegt.

Video pods

Gebotsanfragen für einen Video-Pod mit mehreren Anzeigen-Opportunities werden aufgeschlüsselt, sodass jede Gebotsanfrage für eine einzelne Anzeigen-Opportunity aus diesem Pod gilt. So können Sie Gebote für mehrere Anzeigenmöglichkeiten für einen bestimmten Pod abgeben.

Open Measurement

Mit Open Measurement können Sie Drittanbieter angeben, die unabhängige Mess- und Überprüfungsdienste für Anzeigen bereitstellen, die in mobilen Apps ausgeliefert werden.

Sie können feststellen, ob ein Publisher Open Measurement in der Gebotsanfrage unterstützt, indem Sie prüfen, ob die Anzeigenmöglichkeit das Attribut OmsdkType: OMSDK 1.0 ausschließt, das in Von Publishern ausschließbare Creative-Attribute enthalten ist. Sie finden sie im battr-Attribut für Banner oder Video, je nach Format.

Weitere Informationen zur Interpretation von Gebotsanfragen mit Open Measurement-Signalen finden Sie im Hilfeartikel Open Measurement SDK.

Beispiel für Gebotsanfragen

In den folgenden Abschnitten finden Sie Beispielanfragen für Gebote für verschiedene Anzeigentypen.

App-Banner

OpenRTB-Protobuf

OpenRTB-JSON

App-Interstitial

OpenRTB-Protobuf

OpenRTB-JSON

Video-Interstitial in Apps

OpenRTB-Protobuf

OpenRTB-JSON

App-nativ

OpenRTB-Protobuf

OpenRTB-JSON

Webvideo

OpenRTB-Protobuf

OpenRTB-JSON

Banner für das mobile Web für Exchange-Bieter

OpenRTB-Protobuf

OpenRTB-JSON

Multiformat-Anzeigen (nativ und Video)

OpenRTB-Protobuf

OpenRTB-JSON