تسمح WebView API للإعلانات بتحقيق الربح من الإعلانات داخل التطبيق باستخدام
WebViewController.
إذا كنت تعرض محتوى ويب يتضمّن إعلانات باستخدام
رمز AdSense أو
علامة Google للنشر
في تطبيقك من خلال WebViewController، عليك استخدام واجهة برمجة التطبيقات هذه لتفعيل تحقيق الربح من الإعلانات. لمزيد من المعلومات، يُرجى الاطّلاع على
AdSense
و"مدير إعلانات Google".
- تحقيق الربح من خلال إرسال طلبات الإعلانات باستخدام Google Mobile Ads Flutter Plugin
يمكنك تحقيق الربح من تطبيقك من خلال إرسال طلبات الإعلانات إلى مدير إعلانات Google باستخدام Google Mobile Ads Flutter Plugin عن طريق تنفيذ أشكال الإعلانات للتطبيق على الأجهزة الجوّالة app.
- تحقيق الربح باستخدام WebView API للإعلانات
إذا كان تطبيقك يستخدم
WebViewControllerلعرض محتوى ويب يعرض إعلانات من مدير إعلانات Google أو AdSense، استخدِم WebView API للإعلانات لتسجيل عناصرWebViewControllerفي Google Mobile Ads Flutter Plugin. تنشئ JavaScript في رمز AdSense أو علامة Google للنشر طلبات الإعلانات وترسلها، لذا لن تحتاج إلى إرسال أيّ طلبات إعلانات باستخدام حزمة تطوير البرامج (SDK). يُرجى العِلم أنّه لا تتوفّر باستخدام واجهة برمجة التطبيقات هذه سوى أشكال مستودع الويب على الأجهزة الجوّالة والويب على أجهزة الكمبيوتر .إذا لم تكن تملك محتوى الويب في
WebViewController، ننصحك مع ذلك باستخدام واجهة برمجة التطبيقات هذه للمساعدة في حماية المعلنين من المحتوى غير المرغوب فيه وتحسين تحقيق الربح للناشرين على الويب الذين قدّموا المحتوى.
يُرجى العِلم أنّه يمكنك تنفيذ أحد الخيارَين أو كليهما في التطبيق نفسه.
يهدف هذا الدليل إلى مساعدتك في دمج WebView API للإعلانات في تطبيقك على iOS.
قبل البدء
قبل البدء في استخدام WebView API للإعلانات، تأكَّد من تنفيذ ما يلي:
- استخدِم Google Mobile Ads Flutter Plugin لإضافة مكوّن Flutter الإضافي بالإصدار 3.0.0 أو أعلى في تطبيقك.
- أضِف
webview_flutterكاعتمادية في ملفpubspec.yaml. - أضِف
webview_flutter_androidبالإصدار 3.7.0 أو أعلى في تطبيقك.
تخطّي التحقّق من معرّف التطبيق
Android
أضِف علامة <meta-data> التالية في ملف AndroidManifest.xml لتخطّي التحقّق من APPLICATION_ID. إذا فاتتك هذه الخطوة،
Google Mobile Ads Flutter Plugin قد يعرض
IllegalStateException
عند بدء التطبيق.
<!-- Bypass APPLICATION_ID check for WebView API for Ads -->
<meta-data
android:name="com.google.android.gms.ads.INTEGRATION_MANAGER"
android:value="webview"/>
iOS
عدِّل ملف Runner/Info.plist باستخدام المفتاح وقيمة السلسلة أدناه لتخطّي التحقّق من GADApplicationIdentifier. إذا فاتتك هذه الخطوة،
Google Mobile Ads Flutter Plugin قد يعرض GADInvalidInitializationException
عند بدء التطبيق.
<!-- Bypass GADApplicationIdentifier check for WebView API for Ads -->
<key>GADIntegrationManager</key>
<string>webview</string>
تسجيل WebViewController
لتحسين تحقيق الربح من الإعلانات داخل التطبيق ضمن
WebViewController الذي يستخدم AdSense
code أو Google Publisher
Tags، اتّبِع الخطوات
الموضّحة أدناه:
فعِّل JavaScript في
WebViewController. قد يؤدي عدم إجراء ذلك إلى عدم تحميل الإعلانات.سجِّل مثيل
WebViewControllerمن خلال استدعاء طريقةregisterWebView()التي يوفّرها Google Mobile Ads Flutter Plugin.
import 'package:google_mobile_ads/google_mobile_ads.dart';
import 'package:webview_flutter/webview_flutter.dart';
import 'package:webview_flutter_android/webview_flutter_android.dart';
@override
class WebViewExampleState extends State<WebViewExample> {
late final WebViewController controller;
@override
void initState() {
super.initState();
createWebView();
}
void createWebView() async {
controller = WebViewController();
// 1. Enable JavaScript in the web view.
await controller.setJavaScriptMode(JavaScriptMode.unrestricted);
// 2. Enable third-party cookies for Android.
if (controller.platform is AndroidWebViewController) {
AndroidWebViewCookieManager cookieManager = AndroidWebViewCookieManager(
const PlatformWebViewCookieManagerCreationParams());
await cookieManager.setAcceptThirdPartyCookies(
controller.platform as AndroidWebViewController, true);
}
// 3. Register the web view.
await MobileAds.instance.registerWebView(controller);
}
}
تحميل عنوان URL
يمكنك الآن تحميل عنوان URL وعرض محتوى الويب من خلال WebViewController.
ننصحك بتحميل عنوان URL التجريبي هذا: https://google.github.io/webview-ads/test/ لاختبار عملية الدمج قبل استخدام عنوان URL الخاص بك. ستعرض صفحة الويب خطأً إذا لم يتم تفعيل JavaScript.
import 'package:google_mobile_ads/google_mobile_ads.dart';
import 'package:webview_flutter/webview_flutter.dart';
import 'package:webview_flutter_android/webview_flutter_android.dart';
@override
class WebViewExampleState extends State<WebViewExample> {
late final WebViewController controller;
@override
void initState() {
super.initState();
createWebView();
}
void createWebView() async {
controller = WebViewController();
// 1. Enable JavaScript in the web view.
await controller.setJavaScriptMode(JavaScriptMode.unrestricted);
// 2. Enable third-party cookies for Android.
if (controller.platform is AndroidWebViewController) {
AndroidWebViewCookieManager cookieManager = AndroidWebViewCookieManager(
const PlatformWebViewCookieManagerCreationParams());
await cookieManager.setAcceptThirdPartyCookies(
controller.platform as AndroidWebViewController, true);
}
// 3. Register the web view.
await MobileAds.instance.registerWebView(controller);
// 4. Load the URL.
await controller.loadRequest(Uri.parse('https://google.github.io/webview-ads/test/'));
}
يعرض عنوان URL التجريبي أشرطة حالة خضراء لعملية دمج ناجحة إذا استوفيت الشروط التالية:
WebViewمتصل بـ Google Mobile Ads Flutter Plugin- تم تفعيل JavaScript
- تعمل ملفات تعريف الارتباط الخارجية (لا يُتوقَّع حدوث ذلك على أجهزة iOS)
- تعمل ملفات تعريف الارتباط الخاصة بالطرف الأول
عرض رمز المصدر
لعنوان URL التجريبي يمكنك بعد ذلك استبدال عنوان URL التجريبي بعنوان URL الخاص بك. يمكنك أيضًا
استخدام أداة الخادم الوكيل، مثل Charles، لرصد زيارات HTTPS في تطبيقك وفحص طلبات عرض الإعلانات بحثًا عن مَعلمة &scar=.
