Google Ads के लिए वेबव्यू एपीआई को इंटिग्रेट करना

विज्ञापन के लिए वेब व्यू एपीआई, आपके WKWebView में मौजूद टैग के लिए ऐप्लिकेशन सिग्नल उपलब्ध कराते हैं. इससे, कॉन्टेंट उपलब्ध कराने वाले पब्लिशर के लिए कमाई बढ़ाने में मदद मिलती है. साथ ही, विज्ञापन देने वाले लोगों या कंपनियों को स्पैम से बचाया जा सकता है. ऐप्लिकेशन आईडी और ऐप्लिकेशन वर्शन जैसे ये ऐप्लिकेशन सिग्नल, रिपोर्टिंग और इन-ऐप्लिकेशन ब्राउज़र इन्वेंट्री को टारगेट करने के इस्तेमाल के मामलों को चालू करने में मदद करते हैं. ये मामले, सिर्फ़ ऐप्लिकेशन ट्रैफ़िक पर उपलब्ध होते हैं.

यह कैसे काम करता है

Google Mobile Ads SDK के साथ कम्यूनिकेशन सिर्फ़ तब होता है, जब विज्ञापन से जुड़े इवेंट ट्रिगर होते हैं. ये इवेंट इनमें से किसी भी वजह से ट्रिगर हो सकते हैं:

एसडीके, रजिस्टर किए गए WKWebView में मैसेज हैंडलर जोड़ता है, ताकि वह विज्ञापन से जुड़े इन इवेंट को सुन सके. यह कैसे काम करता है, इस बारे में बेहतर तरीके से जानने के लिए, टेस्ट पेज का सोर्स कोड देखें.

ज़रूरी शर्तें

  • Google Mobile Ads SDK का वर्शन 9.6.0 या इसके बाद का वर्शन.
  • Info.plist फ़ाइल को इस कुंजी और स्ट्रिंग वैल्यू के साथ अपडेट करें. इससे, Google Mobile Ads SDK की ओर से की जाने वाली उस जांच को बायपास किया जाता है जो वेब व्यू के बाहर विज्ञापन दिखाने वाले डेवलपर के लिए, GADApplicationIdentifier वैल्यू के लिए की जाती है. अगर आपने यह चरण पूरा नहीं किया और GADApplicationIdentifier नहीं दिया, तो ऐप्लिकेशन शुरू होने पर Google Mobile Ads SDK टूल, GADInvalidInitializationException दिखाएगा.

    <!-- Indicate 
      
        Google Mobile Ads SDK
      
     usage is only for web view APIs for ads -->
    <key>GADIntegrationManager</key>
    <string>webview</string>
    

वेब व्यू रजिस्टर करना

कॉल register(_:) हर WKWebView इंस्टेंस में AdSense कोड या Google पब्लिशर टैग में JavaScript हैंडलर से कनेक्शन बनाने के लिए, मुख्य थ्रेड पर. यह काम जल्द से जल्द किया जाना चाहिए. जैसे, अपने व्यू कंट्रोलर के viewDidLoad तरीके में.

Swift

import WebKit

class ViewController: UIViewController {

  var webView: WKWebView!

  override func viewDidLoad() {
    super.viewDidLoad()

    // Initialize a WKWebViewConfiguration object.
    let webViewConfiguration = WKWebViewConfiguration()
    // Let HTML videos with a "playsinline" attribute play inline.
    webViewConfiguration.allowsInlineMediaPlayback = true
    // Let HTML videos with an "autoplay" attribute play automatically.
    webViewConfiguration.mediaTypesRequiringUserActionForPlayback = []

    // Initialize the WKWebView with your WKWebViewConfiguration object.
    webView = WKWebView(frame: view.frame, configuration: webViewConfiguration)
    view.addSubview(webView)

    // Register the web view.
    MobileAds.shared.register(webView)
  }
}

Objective-C

@import WebKit;

#import "ViewController.h"

@interface ViewController ()

@property(nonatomic, strong) WKWebView *webView;

@end

@implementation ViewController

- (void)viewDidLoad {
  [super viewDidLoad];

  // Initialize a WKWebViewConfiguration object.
  WKWebViewConfiguration *webViewConfiguration = [[WKWebViewConfiguration alloc] init];
  // Let HTML videos with a "playsinline" attribute play inline.
  webViewConfiguration.allowsInlineMediaPlayback = YES;
  // Let HTML videos with an "autoplay" attribute play automatically.
  webViewConfiguration.mediaTypesRequiringUserActionForPlayback = WKAudiovisualMediaTypeNone;

  // Initialize the WKWebView with your WKWebViewConfiguration object.
  self.webView = [[WKWebView alloc] initWithFrame:self.view.frame configuration:webViewConfiguration];
  [self.view addSubview:self.webView];

  // Register the web view.
  [GADMobileAds.sharedInstance registerWebView:self.webView];
}

अपने इंटिग्रेशन की जांच करना

अपने यूआरएल का इस्तेमाल करने से पहले, हमारा सुझाव है कि आप इंटिग्रेशन की जांच करने के लिए, यह यूआरएल लोड करें:

https://google.github.io/webview-ads/test/#api-for-ads-tests

अगर ये शर्तें पूरी होती हैं, तो टेस्ट यूआरएल में इंटिग्रेशन के लिए हरे रंग के स्टेटस बार दिखते हैं:

  • WKWebView कनेक्ट किया गया है Google Mobile Ads SDK

अगले चरण

  • WKWebView में सहमति लें. विज्ञापनों के लिए वेब व्यू एपीआई, IAB टीसीएफ़ के 2.0 वर्शन या IAB CCPA के अनुपालन फ़्रेमवर्क का इस्तेमाल करके, मोबाइल ऐप्लिकेशन के कॉन्टेक्स्ट में इकट्ठा की गई सहमति को आपके वेब व्यू में मौजूद टैग तक नहीं पहुंचाते हैं. अगर आपको WKWebView और उससे जुड़े वेब कॉन्टेंट, दोनों के मालिक के तौर पर सहमति लेने का एक ही तरीका लागू करना है, तो सहमति लेने के लिए इस्तेमाल किए जाने वाले प्लैटफ़ॉर्म के साथ मिलकर काम करें. इससे WKWebView के संदर्भ में सहमति ली जा सकेगी.