دستورالعمل های زیر را برای اعلام مجوزهای خاص API و پیکربندی دسترسی SDK به منابع مدیریت شده توسط API هدفمند دنبال کنید.
مجوزهای مربوط به API AdServices را اعلام کنید
دسترسی به هر PPAPI نیاز به مجوز normal
سرویس تبلیغات دارد. در مانیفست خود، مجوزهای دسترسی مناسب را که با APIهای مورد نیاز در برنامه یا SDK شما مطابقت دارد، اعلام کنید.
Attribution Reporting API:
<uses-permission android:name="android.permission.ACCESS_ADSERVICES_ATTRIBUTION" />
Attribution Reporting API (با گزارشهای اشکالزدایی):
<uses-permission android:name="android.permission.ACCESS_ADSERVICES_ATTRIBUTION" />
<uses-permission android:name="android.permission.ACCESS_ADSERVICES_AD_ID" />
API مخاطبان محافظت شده / مخاطبان سفارشی:
<uses-permission android:name="android.permission.ACCESS_ADSERVICES_CUSTOM_AUDIENCE" />
Topics API:
<uses-permission android:name="android.permission.ACCESS_ADSERVICES_TOPICS" />
در صورت تمایل، برای دریافت گزارشهای اشکالزدایی با API Attribution Reporting، مجوز AD_ID را اضافه کنید:
<uses-permission android:name="android.permission.ACCESS_ADSERVICES_AD_ID" />
اگر پروژه شما به ماژول ها یا SDK ها وابستگی دارد، ممکن است مجوزهای مورد نیاز سرویس های تبلیغاتی را در فایل های مانیفست خود اعلام کنند. به طور پیشفرض، ساخت Gradle همه فایلهای مانیفست را در یک فایل مانیفست واحد که در برنامه شما بستهبندی شده است، ادغام میکند. از نمای Manifest Merged برای تأیید اینکه مجوزهای صحیح استفاده شده است استفاده کنید.
اگر نیاز دارید از ادغام هر یک از مجوزها از طریق وابستگی هایی مانند SDK در برنامه خود جلوگیری کنید، نشانگر remove
گره را برای مجوزهای خاص اضافه کنید. مثال زیر نحوه جلوگیری از ادغام مجوز Topics را نشان می دهد.
<uses-permission android:name="android.permission.ACCESS_ADSERVICES_TOPICS"
tools:node="remove" />
پیکربندی سرویس های تبلیغاتی خاص API
مشابه مجوزهای دسترسی PPAPI، هر API دارای ورودی مربوطه در پیکربندی سرویس های تبلیغاتی است. این پیکربندی به شما امکان دسترسی کنترل دقیق به منابع مدیریت شده توسط APIهای برنامه یا SDK تعبیه شده را می دهد.
همانطور که در مثال زیر نشان داده شده است، در مانیفست خود، یک ویژگی adservicesConfig
را مشخص کنید:
<application ...>
...
<property android:name="android.adservices.AD_SERVICES_CONFIG"
android:resource="@xml/ad_services_config" />
...
</application>
منبع XML خدمات تبلیغاتی را که در مانیفست ارجاع داده شده است، مشخص کنید، مانند res/xml/ad_services_config.xml
. برای هر API حفظ حریم خصوصی که برای برنامه شما (یا SDK تعبیه شده) قابل اجرا است، ویژگی allowAllToAccess
را روی true
تنظیم کنید تا به هر تماس گیرنده دسترسی داشته باشید.
از طرف دیگر، میتوانید از ویژگی allowAdPartnersToAccess
برای اعطای دسترسی API دقیق به هر فناوری تبلیغاتی استفاده کنید. باید فهرستی از شناسههای حساب ثبتنام توسعهدهنده که از طریق ثبتنام به دست آمدهاند ارائه کنید. اگر ویژگی allowAllToAccess
روی true
تنظیم شود، این ویژگی بر هر شناسه حساب ثبت نامی که در ویژگی allowAdPartnersToAccess
مشخص شده است، اولویت دارد.
پلتفرمهای فناوری تبلیغات همچنین باید مطمئن شوند که سرویسگیرندگان برنامهشان به درستی به APIهای مورد نیاز حفظ حریم خصوصی در پیکربندی سرویسهای تبلیغاتی دسترسی دارند.
مثال زیر نشان می دهد که چگونه می توان دسترسی گسترده را تعیین کرد تا به هر شناسه حساب ثبت نامی اجازه دسترسی به همه APIهای حفظ حریم خصوصی داده شود:
<ad-services-config>
<!-- Attribution API -->
<attribution allowAllToAccess="true" />
<!-- Topics API -->
<topics allowAllToAccess="true" />
<!-- Protected Audience on Android API -->
<custom-audiences allowAllToAccess="true" />
</ad-services-config>
مثال زیر نحوه تعیین دسترسی دقیق به هر API حفظ حریم خصوصی را برای شناسه های حساب ثبت نام خاص نشان می دهد:
<ad-services-config>
<!-- Attribution API -->
<attribution allowAdPartnersToAccess="ENROLLMENT-ID" allowAllToAccess="false" />
<!-- Topics API -->
<includes-sdk-library name="ENROLLMENT-ID" />
<topics allowAdPartnersToAccess="ENROLLMENT-ID" allowAllToAccess="false" />
<!-- Protected Audience on Android API -->
<custom-audiences allowAdPartnersToAccess="ENROLLMENT-ID" allowAllToAccess="false" />
</ad-services-config>
وابستگی های کتابخانه Jetpack را اعلام کنید
از کتابخانه تبلیغاتی Jetpack 1.0.0-beta01 یا بالاتر برای ادغام با APIهای حفظ حریم خصوصی Privacy Sandbox استفاده کنید. می توانید از این کتابخانه برای انتزاع برنامه خود از جزئیات سطح پلت فرم و ساده سازی ادغام با API های حفظ حریم خصوصی استفاده کنید.
- یک مخزن Maven به پروژه خود اضافه کنید.
- در فایل
build.gradle
برای برنامه یا ماژول خود ، وابستگی های کتابخانه Jetpack ads-adservices را اعلام کنید. - از API های بسته
androidx.privacysandbox.ads.adservices.*
استفاده کنید. - کتابخانه Jetpack Ads-Adservices پشتیبانی داخلی Kotlin را فراهم می کند. ممکن است لازم باشد وابستگیهای آگاه از چرخه حیات مناسب برای پروژه خود را برای مدیریت دامنههای معمولی ترکیب کنید.
در دسترس بودن نسخه افزونه های خدمات تبلیغاتی را بررسی کنید
اگر از کتابخانه سرویسهای تبلیغاتی Jetpack برای ادغام با APIهای حفظ حریم خصوصی استفاده میکنید، کتابخانه در دسترس بودن APIهای درخواستی را در obtain()
بررسی میکند. در صورتی که API درخواستی در دستگاه موجود نباشد، این تابع null برمیگرداند. مثال زیر نحوه تنظیم اولیه TopicsManager
برای Topics API را نشان می دهد. به طور مشابه برای دسترسی به سایر APIهای حفظ حریم خصوصی کار می کند.
کاتلین
import androidx.privacysandbox.ads.adservices.topics.TopicsManager
// The initialization function will return null if the requested
// functionality is not available on the device.
val topicsManager = TopicsManager.obtain(context)
جاوا
import androidx.privacysandbox.ads.adservices.topics.TopicsManager;
// The initialization function will return null if the requested
// functionality is not available on the device.
TopicsManager topicsManager = TopicsManager.obtain(context);
اگر مستقیماً از AdServices API در Extension SDK استفاده میکنید، نسخه AdServices Extensions را که شامل AdServices APIهایی است که میخواهید استفاده کنید، بررسی کنید. در مرجع API، میتوانید نسخهای را شناسایی کنید که یک AdServices API خاص در آن معرفی شده است. به عنوان مثال، مرجع API برای کلاس TopicsManager
نشان میدهد که "افزوده شده در Ad Services Extensions 4" است. از بررسیهای شرطی زیر برای تأیید اعتبار برنامههای افزودنی SDK که حاوی AdServices API هستند استفاده کنید.
کاتلین
import android.os.ext.SdkExtensions
if (SDK_INT >= Build.VERSION_CODES.R && // The extensions API is available since R.
SdkExtensions.getExtensionVersion(SdkExtensions.AD_SERVICES) >= 4) {
// AdServices API is available.
...
}
جاوا
import android.os.ext.SdkExtensions;
if (SDK_INT >= Build.VERSION_CODES.R && // The extensions API is available since R.
SdkExtensions.getExtensionVersion(SdkExtensions.AD_SERVICES) >= 4) {
// AdServices API is available.
...
}
محدودیت دسترسی به پیش زمینه
برای ایجاد شفافیت، دسترسی به SDK Runtime و APIهای حفظ حریم خصوصی به برنامههایی با یک Activity قابل مشاهده یا با RunningAppProcessInfo
از IMPORTANCE_FOREGROUND
محدود میشود.