پلتفرم اندروید از مفهوم sandboxing برنامه برای حفظ اجرای قوی و مرزهای امنیتی برای کد برنامه، در امتداد مرزهای فرآیند استفاده می کند. استفاده از کدهای شخص ثالث، اغلب به شکل کیت توسعه نرم افزاری، مانند کیت توسعه نرم افزاری تبلیغات یا کیت توسعه نرم افزاری تحلیلی، یک روش معمول برای برنامه ها است. این استفاده مجدد توسعه دهندگان برنامه را قادر می سازد تا روی تمایز برنامه خود تمرکز کنند و در عین حال از کار متخصصان موضوع استفاده کنند تا اجرای خود را فراتر از آنچه که به راحتی می توانند انجام دهند، افزایش دهند.
مانند بسیاری از سیستمعاملها، در اندروید SDKها در sandbox برنامه میزبان اجرا میشوند و همان امتیازات و مجوزهای برنامه میزبان خود و همچنین دسترسی به حافظه و فضای ذخیرهسازی برنامه میزبان را به ارث میبرند. در حالی که این معماری SDK ها و برنامه ها را قادر می سازد تا به طور انعطاف پذیر یکپارچه شوند، همچنین پتانسیل جمع آوری و به اشتراک گذاری داده های کاربر نامشخص را ایجاد می کند. علاوه بر این، توسعهدهندگان برنامه ممکن است از میزان عملکرد یک SDK شخص ثالث و دادههایی که به آن دسترسی پیدا میکند، کاملاً آگاه نباشند، و حساب کردن جمعآوری دادهها و شیوههای اشتراکگذاری برنامهشان را به چالش میکشد.
در Android 13، ما یک قابلیت پلتفرم جدید اضافه کردهایم که به SDKهای شخص ثالث اجازه میدهد در یک محیط زمان اجرا اختصاصی به نام SDK Runtime اجرا شوند. SDK Runtime تدابیر و تضمینهای قویتر زیر را در مورد جمعآوری و اشتراکگذاری دادههای کاربر فراهم میکند:
- یک محیط اجرایی اصلاح شده
- مجوزها و حقوق دسترسی به داده به خوبی تعریف شده برای SDKها
ما فعالانه به دنبال بازخورد از جامعه تبلیغاتی برنامه تلفن همراه در مورد این طراحی هستیم. همچنین از بازخورد جامعه توسعهدهندگان گستردهتر برای کمک به شکلگیری تکرارهای آینده SDK Runtime، از جمله پشتیبانی از موارد استفاده اضافی، استقبال میکنیم.
اهداف
این پیشنهاد به دنبال دستیابی به اهداف زیر است:
- از طریق جداسازی فرآیند و API به خوبی تعریف شده و کنترل دسترسی به داده، دسترسی نامشخص و اشتراک گذاری داده های برنامه کاربر توسط SDK های شخص ثالث را کاهش دهید. در بخش جداگانه ای از این سند درباره جداسازی فرآیند بیشتر بیاموزید.
- با محدود کردن دسترسی به شناسههای ثابت و منحصربهفرد توسط SDKهای شخص ثالث، ردیابی نامعلوم استفاده از برنامه کاربر را کاهش دهید.
- با کاهش بار روی توسعه دهندگان برنامه و کاربران نهایی، توزیع بهروزرسانیهای SDK به برنامهها را ایمن تسریع کنید. در مورد مدل توزیع SDK مورد اعتماد پیشنهادی در بخش دیگری از این سند بیشتر بیاموزید.
- به توسعه دهندگان برنامه کمک کنید تا روش های دسترسی به داده ها و اشتراک گذاری برنامه خود را بهتر حساب کنند.
- به توسعه دهندگان SDK کمک کنید تا از دستکاری سایر SDK ها از طریق محدود کردن برخی ساختارهای زبان ناامن مانند کد JNI جلوگیری کنند.
- از طریق کنترل کامل بر روی نماهای از راه دور رسانه نمایش داده شده، به SDKهای تبلیغاتی کمک کنید تا ترافیک نامعتبر و کلاهبرداری تبلیغاتی را شناسایی کرده و از آن جلوگیری کنند.
- تا آنجا که ممکن است تأثیرات نامناسب را بر توسعه دهندگان برنامه و SDK به حداقل برسانید.
SDK ها در یک فرآیند مجزا اجرا می شوند
SDK Runtime پیشنهادی SDK های سازگار را - که در بقیه این سند به عنوان SDK های فعال در زمان اجرا (RE) نامیده می شود - را قادر می سازد تا در یک فرآیند جداگانه برای برنامه کار کنند. این پلتفرم ارتباط دو طرفه بین فرآیند برنامه و زمان اجرا SDK آن را تسهیل می کند. برای جزئیات بیشتر به بخش ارتباطات این سند مراجعه کنید. SDK های غیر RE مانند امروز در روند برنامه باقی می مانند. نمودارهای زیر این تغییرات را نشان می دهند:
مدل توزیع قابل اعتماد جدید برای SDK ها
این جداسازی پیشنهادی SDK از برنامه، مفهوم جداسازی دیگری را ایجاد میکند، یکی برای SDK و توزیع برنامه. پیشنهاد ما به مکانیزم توزیع و نصب قابل اعتماد نیاز دارد تا اطمینان حاصل شود که SDKهای صحیح در زمان اجرای SDK برنامه نصب شده اند. این به محافظت از کاربران و توسعه دهندگان برنامه در برابر بارگیری SDK های نامعتبر کمک می کند، در حالی که فروشگاه های برنامه را قادر می سازد تا بار توزیع SDK را به میزان قابل توجهی کاهش دهند.
SDK ها دیگر نیازی به پیوند استاتیک و بسته بندی ایستا با برنامه های خود قبل از آپلود در فروشگاه برنامه برای توزیع ندارند. در عوض فرآیند زیر رخ می دهد:
- توسعه دهندگان SDK می توانند SDK های نسخه شده خود را جدا از خود برنامه ها در فروشگاه های برنامه آپلود کنند.
- توسعهدهندگان برنامه میتوانند وابستگیهای SDK خود را بر اساس نسخه، ساخت و آپلود نسخهای که وابستگیهای واقعی SDK را در بر نمیگیرد، آپلود کنند.
- وقتی کاربر این برنامه را دانلود میکند، فرآیند نصب میتواند از وابستگیهای SDK مشخص شده برنامه استفاده کند تا سپس آنها را از فروشگاه برنامه دانلود کند.
این مکانیسم توزیع جدید، توسعه دهندگان SDK را قادر می سازد تا تغییرات غیرقابل شکست (یعنی هیچ تغییری در API یا معنای آن ها) در SDK های خود ایجاد کنند و بدون دخالت توسعه دهندگان برنامه، آن را در دستگاه ها توزیع کنند. این تغییرات غیرقابل شکست SDK را میتوان مستقر کرد یا به عقب بازگرداند، بدون اینکه لزوماً نیازی به منتظر ماندن توسعهدهندگان برنامه برای بازسازی برنامههای خود با SDKهای جدید یا منتظر ماندن کاربران نهایی برای بهروزرسانی برنامههای خود باشند. تغییرات قطعی هنوز باید توسط توسعه دهندگان برنامه به روز شوند، اما توسعه دهندگان SDK می توانند آخرین تغییرات غیرقابل شکست خود را دریافت کنند و سریعتر و یکنواخت تر برای افراد بیشتری رفع شوند، و در حالت ایده آل، پشتیبانی از نسخه را به حداقل برسانند.
نمودارهای زیر تغییرات پیشنهادی در توزیع SDK را نشان می دهد:
تغییرات در نحوه ساخت، اجرا و توزیع SDK ها و برنامه ها
این یک پیشنهاد اولیه برای زمان اجرا و فناوری توزیع SDK انعطاف پذیر است. بخشهای زیر مجموعهای از تغییرات را در دستههای کلی زیر پیشنهاد میکنند:
- دسترسی : مجوزها، حافظه، ذخیره سازی
- اجرا : زبان ها، تغییرات زمان اجرا، چرخه عمر، رندر رسانه
- ارتباطات : App-to-SDK و SDK-to-SDK
- توسعه : نحوه ساخت، اشکال زدایی، تست در این مدل
- توزیع : نحوه توزیع، بهروزرسانی، بازگرداندن نسخههای Android، برنامهها و SDK
این سند همچنین شامل یک سؤال متداول برای کمک به پاسخگویی به سؤالات رایج است.
این یک طرح پیشنهادی اولیه است، و ما می دانیم که این ممکن است یک تغییر معنی دار برای برخی از اعضای اکوسیستم باشد. به همین دلیل است که ما فعالانه بازخورد شما را درخواست می کنیم و از شما می خواهیم که این کار را از طریق ردیاب مشکل انجام دهید.
دسترسی داشته باشید
مدیریت حریم خصوصی یک سیستم مستلزم مدیریت نحوه دسترسی طرف های مختلف به منابع مختلف است. برای برآورده کردن پیشنهاد ارزش حریم خصوصی، پیشنهاد میکنیم مدل دسترسی به برنامهها، SDK و دادههای کاربر را بهروزرسانی کنیم تا از اصل کمترین امتیاز برای جلوگیری از دسترسی نامشخص به دادههای حساس بالقوه پیروی کنیم.
مجوزهای SDK
به عنوان یک فرآیند جداگانه، SDK Runtime به جای ارث بردن مجوزهایی که کاربر به برنامه اعطا کرده است، مجموعه ای از مجوزهای کاملاً تعریف شده خود را دارد. بر اساس تحقیقات اولیه در مورد مجوزهای استفاده شده توسط SDK های مرتبط با تبلیغات، ما پیشنهاد می کنیم که مجوزهای زیر به طور پیش فرض برای SDK ها در زمان اجرا SDK قابل دسترسی باشد:
-
INTERNET
: دسترسی به اینترنت برای برقراری ارتباط با یک سرویس وب. -
ACCESS_NETWORK_STATE
: به اطلاعات مربوط به شبکه ها دسترسی پیدا کنید. -
READ_BASIC_PHONE_STATE
: به اطلاعات مربوط به وضعیت تلفن، به عنوان مثال نوع شبکه تلفن همراه دسترسی پیدا کنید. - مجوزهای دسترسی به APIهای حفظ حریم خصوصی ، که قابلیتهای اصلی تبلیغات را بدون نیاز به دسترسی به شناسههای بین برنامهای ارائه میکنند.
-
AD_ID
: امکان درخواست شناسه تبلیغاتی. این نیز با دسترسی برنامه به این مجوز محدود می شود.
ما در حال حاضر در حال بررسی این موضوع هستیم که آیا و چگونه مجوزهای اضافی را مجاز کنیم یا خیر، که تاثیر آن بر کاربران نهایی را از منظر حریم خصوصی و قابلیت استفاده محدود می کند. ما درخواست بازخورد در مورد موارد استفاده که ممکن است توسط این مجموعه از مجوزها برآورده نشده است.
حافظه
SDK Runtime به دلیل داشتن فرآیند خاص خود، فضای حافظه ایزوله خود را خواهد داشت. این ساختار به طور پیشفرض دسترسی SDK را به فضای حافظه برنامه منع میکند و برنامه به طور مشابه نمیتواند به فضای حافظه SDK دسترسی پیدا کند. ما پیشنهاد میکنیم که این رفتار پیشفرض حفظ شود تا با اصل کمترین امتیاز مطابقت داشته باشد.
ذخیره سازی
این پیشنهاد قصد دارد بین نیاز SDK ها برای دسترسی به فضای ذخیره سازی برای عملکرد عادی خود تعادل ایجاد کند و ردیابی بین برنامه ای و بین فرآیندی را با استفاده از ذخیره سازی دائمی به حداقل برساند. ما بهروزرسانی زیر را برای نحوه دسترسی به فضای ذخیرهسازی امروز پیشنهاد میکنیم:
- یک برنامه نمیتواند مستقیماً به حافظه SDK خود دسترسی داشته باشد و بالعکس.
- حافظه خارجی دستگاه برای SDK ها قابل دسترسی نخواهد بود.
- در هر زمان اجرای SDK، هم فضای ذخیرهسازی قابل دسترسی برای همه SDKها و هم فضای ذخیرهسازی خصوصی برای یک SDK مشخص وجود دارد.
مانند مدل ذخیره سازی فعلی، خود ذخیره سازی محدودیت های دلخواه در اندازه ندارد. SDK ها می توانند از فضای ذخیره سازی برای ذخیره دارایی ها استفاده کنند. زمانی که SDK به طور فعال اجرا نمی شود، این حافظه به صورت دوره ای پاک می شود.
اعدام
برای اطمینان از یک سیستم خصوصی بین برنامهها، SDKها و کاربران، خود زمینه اجرا (فرمتهای کد، ساختارهای زبان، APIهای قابل دسترسی و دادههای سیستم) باید این مرزهای حریم خصوصی را تقویت کند، یا حداقل فرصتهایی برای دور زدن آنها ایجاد نکند. در عین حال، ما می خواهیم دسترسی به پلتفرم غنی و اکثر قابلیت های زمان اجرا را که SDK ها در حال حاضر دارند حفظ کنیم. در اینجا ما مجموعهای از بهروزرسانیها را برای محیط اجرا پیشنهاد میکنیم تا این تعادل برقرار شود.
کد
کد اندروید (برنامهها و SDK) عمدتاً توسط Android Runtime (ART) تفسیر میشود، چه کد به زبان Kotlin نوشته شده باشد یا جاوا. غنای ART و ساختارهای زبانی که ارائه میدهد، همراه با قابلیت تأیید آن در مقایسه با گزینههای جایگزین - بهویژه کدهای بومی - به نظر میرسد که عملکرد و حریم خصوصی را به طور مناسب متعادل میکند. پیشنهاد ما این است که کد SDK فعال در زمان اجرا به جای پشتیبانی از دسترسی JNI، منحصراً از بایت کد Dex تشکیل شده باشد.
ما می دانیم که موارد استفاده مانند استفاده از SQLite بسته بندی شده سفارشی وجود دارد که با توجه به استفاده از کد بومی، باید با یک جایگزین مانند نسخه داخلی SQLite در Android SDK جایگزین شود.
SELinux
در اندروید، هر فرآیند (از جمله پروسههایی که بهعنوان روت اجرا میشوند) با یک زمینه SELinux خاص اجرا میشود و به هسته اجازه میدهد تا کنترل دسترسی به سرویسهای سیستم، فایلها، دستگاهها و سایر فرآیندها را مدیریت کند. در تلاش برای حفظ اکثر موارد استفاده از SDK و در عین حال به حداقل رساندن دور زدن محافظتهای حریم خصوصی که در تلاش برای پیشبرد آن هستیم، بهروزرسانیهای زیر را از زمینه SELinux یک برنامه غیر سیستمی برای زمان اجرا SDK پیشنهاد میکنیم:
- مجموعه محدودی از خدمات سیستم در دسترس خواهد بود. ( در حال طراحی فعال )
- SDK ها فقط می توانند کد را در APK خود بارگیری و اجرا کنند.
- مجموعه محدودی از ویژگی های سیستم در دسترس خواهد بود. ( در حال طراحی فعال )
API ها
استفاده از بازتاب و فراخوانی APIها در زمان اجرا SDK مجاز است. با این حال، یک SDK مجاز به استفاده از بازتاب یا فراخوانی APIها در SDK دیگری با زمان اجرا فعال نخواهد بود. ما یک پیشنهاد کامل از APIهای ممنوعه را در به روز رسانی آینده به اشتراک خواهیم گذاشت.
علاوه بر این، نسخههای اخیر پلتفرم اندروید دسترسی به شناسههای دائمی را به منظور بهبود حریم خصوصی به طور فزایندهای محدود کرده است. برای زمان اجرا SDK، ما محدود کردن دسترسی بیشتر به شناسه هایی را پیشنهاد می کنیم که می توانند برای ردیابی بین برنامه ای استفاده شوند.
APIهای SDK Runtime فقط از برنامههایی که در پیشزمینه اجرا میشوند قابل دسترسی هستند. تلاش برای دسترسی به APIهای SdkSandboxManager
از برنامههای موجود در پسزمینه منجر به ایجاد یک SecurityException
میشود.
در نهایت، RE-SDK ها نمی توانند از API های اعلان ها برای ارسال اعلان های کاربر در هر مقطع زمانی استفاده کنند.
چرخه زندگی
SDK های برنامه در حال حاضر از چرخه عمر برنامه میزبان خود پیروی می کنند، به این معنی که وقتی برنامه وارد یا خارج از پیش زمینه می شود، خاموش می شود یا توسط سیستم عامل به دلیل فشار حافظه متوقف می شود، SDK های برنامه نیز این کار را انجام می دهند. پیشنهاد ما برای تفکیک SDK های یک برنامه در فرآیندی متفاوت، متضمن تغییرات چرخه عمر زیر است:
- برنامه می تواند توسط کاربر یا سیستم عامل خاتمه یابد. زمان اجرا SDK بلافاصله پس از آن به طور خودکار خاتمه می یابد.
زمان اجرا SDK می تواند توسط سیستم عامل به دلیل فشار حافظه یا یک استثناء کنترل نشده در یک SDK خاتمه یابد.
برای Android 13، زمانی که یک برنامه در پیش زمینه است، SDK Runtime در اولویت بالایی اجرا می شود و بعید است که پایان یابد. وقتی برنامه به پسزمینه میرود، اولویت فرآیند SDK Runtime کاهش مییابد و واجد شرایط فسخ میشود. اولویت فرآیند SDK Runtime حتی اگر برنامه به پیشزمینه بازگردد کم میماند. در نتیجه، این احتمال وجود دارد که در مقایسه با برنامه تحت فشار حافظه خاتمه یابد.
برای اندروید 14 و جدیدتر، اولویتهای فرآیند برنامه و زمان اجرا SDK همتراز هستند. اولویتهای فرآیند برای
ActivityManager.RunningAppProcessInfo.importance
برای برنامه و زمان اجرا SDK باید تقریباً یکسان باشد.در صورتی که زمان اجرای SDK در حالی که برنامه زنده است خاتمه می یابد - برای مثال، اگر یک استثنا کنترل نشده در SDK وجود داشته باشد، وضعیت زمان اجرا SDK، از جمله همه SDK های بارگیری شده قبلی و نماهای راه دور، از بین می رود. توسعهدهنده برنامه میتواند با استفاده از یکی از روشهای زیر با خاتمه اجرای SDK مقابله کند:
- این پیشنهاد روشهای بازگشت تماس چرخه عمر مرتبط را به توسعهدهندگان برنامه ارائه میکند تا تشخیص دهند که چه زمانی خاتمه SDK Runtime رخ داده است.
- اگر زمان اجرای SDK در حین نمایش تبلیغات پایان یابد، ممکن است تبلیغات آنطور که انتظار می رود کار نکنند. برای مثال، نماها ممکن است روی صفحه ثابت شوند و دیگر تعاملی نباشند. اگر روی تجربه کاربر تأثیری نداشته باشد، برنامه میتواند نمای آگهی را حذف کند.
- این برنامه می تواند تلاش دیگری برای بارگیری SDK و درخواست تبلیغات انجام دهد.
- برای Android 14، اگر SDK Runtime در حالی که SDK های آن بارگذاری شده اند، خاتمه یابد، و اگر توسعه دهنده برنامه روش های بازگشت تماس چرخه عمر فوق را ثبت نکرده باشد، برنامه به طور پیش فرض خاتمه می یابد. فقط پردازشهای برنامهای که SDKها را بارگیری کردهاند به طور معمول خاتمه یافته و خارج میشوند.
- اشیاء Binder که توسط SDK برای برقراری ارتباط با آن برگردانده می شوند (مانند
SandboxedSdk
)، در صورت استفاده توسط برنامه، یکDeadObjectException
پرتاب می کنند.
این مدل چرخه عمر ممکن است در به روز رسانی های آینده تغییر کند.
در صورت خرابیهای مداوم، توسعهدهنده برنامه باید بدون SDK برنامهریزی کند تا بهخوبی تخریب شود یا اگر SDK برای عملکرد اصلی برنامه بسیار مهم است، به کاربر اطلاع دهد. برای جزئیات بیشتر در مورد این تعامل برنامه به SDK، بخش ارتباطات این سند را ببینید.
SDKهای غیر RE می توانند به استفاده از سیستم عامل اولیه اولیه موجود در برنامه تعبیه شده خود - از جمله خدمات، فعالیت ها و پخش ها - ادامه دهند، در حالی که RE SDK نمی توانند.
موارد خاص
موارد زیر پشتیبانی نمیشوند و ممکن است رفتار غیرمنتظرهای داشته باشند:
- اگر چندین برنامه از یک UID استفاده کنند، ممکن است زمان اجرا SDK به درستی کار نکند. پشتیبانی از UIDهای مشترک ممکن است در آینده اضافه شود.
- برای برنامههایی که چندین پردازش دارند، بارگیری SDK باید در فرآیند اصلی انجام شود.
رندر رسانه ای
SDK هایی وجود دارند که محتوایی مانند متن، تصاویر و ویدیو را در نمای برنامه مشخص می کنند. برای انجام این کار، ما یک رویکرد رندر از راه دور را پیشنهاد میکنیم که در آن SDK رسانه را از داخل SDK Runtime رندر میکند، اما از SurfaceControlViewHost
API استفاده میکند تا به رسانه اجازه دهد در یک نمای برنامه مشخص شده ارائه شود. این قابلیت به SDK ارائه میکند تا این رسانه را به گونهای ارائه کند که برای کاربر خصوصی باشد، در حالی که به جلوگیری و شناسایی تعاملات نامعتبر یا تقلبی کاربر با رسانه ارائهشده کمک میکند.
تبلیغات بومی، آنهایی که توسط SDK ارائه نمی شوند، بلکه توسط برنامه ارائه می شوند، توسط SDK ها در زمان اجرا SDK پشتیبانی می شوند. فرآیند جمعآوری سیگنال و واکشی خلاقانه با تبلیغات غیربومی بهطور مداوم انجام میشود. این یک منطقه فعال تحقیق است.
تبلیغات ویدیویی درون جریانی، تبلیغاتی هستند که به صورت درون جریانی همراه با یک ویدیو اجرا میشوند که در پخشکننده در یک برنامه نمایش داده میشود. با توجه به اینکه ویدیو به جای پخش کننده یا مشاهده در SDK در یک پخش کننده در برنامه پخش می شود، مدل رندر با سایر قالب های تبلیغاتی متفاوت است. ما به طور فعال در حال بررسی مکانیسم هایی برای پشتیبانی از درج آگهی سمت سرور و درج آگهی مبتنی بر SDK هستیم.
سلامت سیستم
ما به دنبال به حداقل رساندن تأثیر سلامت سیستم SDK Runtime بر دستگاه های کاربر نهایی هستیم و در حال طراحی راه هایی برای انجام این کار هستیم. با این حال، به احتمال زیاد، برخی از دستگاههای سطح پایه Android 13 با منابع سیستمی بسیار محدود، مانند Android (نسخه Go) ، به دلیل تأثیر بر سلامت سیستم، از زمان اجرا SDK پشتیبانی نمیکنند. ما به زودی حداقل الزامات لازم برای استفاده موفق از زمان اجرا SDK را به اشتراک خواهیم گذاشت.
ارتباطات
از آنجایی که برنامهها و SDKها در حال حاضر در یک فرآیند اجرا میشوند، ارتباط بین آنها مهار نشده و بدون واسطه است. علاوه بر این، اندروید امکان برقراری ارتباط بین برنامهای را فراهم میکند حتی اگر ارتباط با SDK شروع و پایان یابد. این مدل ارتباطی بدون جریان، موارد استفاده مختلف را ممکن میسازد و در عین حال امکان اشتراکگذاری دادههای فاش نشده بین برنامهها و بین SDKها در داخل و بین برنامهها را ارائه میدهد. ما بهروزرسانیهای زیر را برای این مدل ارتباطی پیشنهاد میکنیم تا تعادلی بین ارزش چنین ارتباطاتی و تحقق اهداف اعلام شده ایجاد کنیم.
برنامه به SDK
رابط بین برنامه و SDK رایج ترین مسیر ارتباطی برای یک SDK است و API SDK جایی است که بیشتر تمایز و نوآوری کاربر در آن قرار دارد. ما به دنبال حفظ توانایی SDK برای نوآوری و تمایز در اینجا هستیم. در نتیجه، پیشنهاد ما به SDK ها قدرت می دهد تا API ها را در معرض دید برنامه ها قرار دهند و اطمینان حاصل شود که برنامه ها می توانند از همه این نوآوری ها بهره مند شوند.
با توجه به ساختار مرزی فرآیند SDK Runtime، ما پیشنهاد میکنیم که یک لایه مارشالکننده ایجاد کنیم که در داخل برنامه قابل دسترسی باشد تا تماسها و پاسخها یا تماسهای API را در سراسر این مرز بین برنامه و SDK انجام دهیم. ما پیشنهاد می کنیم که رابط این لایه مارشال توسط توسعه دهندگان SDK تعریف شود و توسط ابزارهای ساخت منبع باز رسمی که ما توسعه خواهیم داد تولید شود.
با این پیشنهاد، ما به دنبال حذف کار مارشال دیگ از برنامهنویسان و توسعهدهندگان SDK هستیم، در حالی که انعطافپذیری را برای توسعهدهندگان SDK فراهم میکنیم و اطمینان میدهیم که کد SDK در زمان اجرا SDK اجرا میشود تا اهداف حریم خصوصی خود را محقق کنیم. اگر این مسیر را طی کنیم، زبان و ابزار تعریف API باید با ورودی شما طراحی شود.
مدل کلی تعامل به صورت زیر خواهد بود:
- برنامه از طریق رابط، SDK را فراخوانی میکند و با ارسال پاسخ تماسها.
- SDK به طور ناهمزمان درخواست ها را برآورده می کند و با استفاده از تماس ها پاسخ می دهد.
- این را میتوان به هر مدل ناشر-مشترک تعمیم داد، به این معنی که یک برنامه میتواند در رویدادهای SDK با تماسهای برگشتی مشترک شود، و زمانی که این رویدادها اتفاق افتاد، تماسهای برگشتی فعال میشوند.
نتیجه ساختار متقابل فرآیند جدید این پیشنهاد این است که دو چرخه حیات فرآیند وجود دارد که باید مدیریت شوند: یکی برای خود برنامه و دیگری برای زمان اجرا SDK. پیشنهاد ما به دنبال آن است که تا آنجا که ممکن است این کار را خودکار کند و تأثیر آن را بر توسعه دهندگان برنامه و SDK به حداقل برساند. نمودار زیر رویکردی را که ما در نظر داریم نشان می دهد:
این پلتفرم APIهای جدیدی را برای برنامهها برای بارگذاری پویا SDKها در فرآیند SDK Runtime، دریافت اطلاعرسانی در مورد تغییرات در وضعیت فرآیند و تعامل با SDKهای بارگذاریشده در SDK Runtime در معرض نمایش قرار میدهد.
نمودار شکل قبلی ارتباط برنامه به SDK را در سطح پایین تر، بدون لایه مارشال نشان می دهد.
برنامه از طریق مراحل زیر با SDK در حال اجرا در فرآیند SDK Runtime ارتباط برقرار می کند:
قبل از اینکه یک برنامه بتواند با یک SDK تعامل داشته باشد، برنامه از پلتفرم درخواست می کند که SDK را بارگیری کند. برای اطمینان از یکپارچگی سیستم، برنامهها SDKهایی را که قصد بارگیری آنها را دارند در فایل مانیفست خود مشخص میکنند و این SDKها تنها مواردی هستند که مجاز به بارگیری هستند.
قطعه کد زیر یک نمونه API گویا را ارائه می دهد:
SdkSandboxManager.loadSdk(String sdkName, Bundle data, Executor executor, OutcomeReceiver<SandboxedSdk, LoadSdkException> receiver)
SDK مطلع می شود که بارگذاری شده است و رابط خود را برمی گرداند. این رابط قرار است در فرآیند برنامه استفاده شود. برای به اشتراک گذاشتن اینترفیس خارج از مرز فرآیند، باید به عنوان یک شی
IBinder
برگردانده شود.راهنمای خدمات محدود راههای مختلفی را برای ارائه
IBinder
ارائه میکند. هر راهی را که انتخاب کنید، باید بین SDK و برنامه تماس گیرنده سازگار باشد. نمودارها از AIDL به عنوان مثال استفاده می کنند.SdkSandboxManager
رابطIBinder
را دریافت کرده و آن را به برنامه برمی گرداند.برنامه
IBinder
دریافت می کند و آن را به رابط SDK می فرستد و عملکردهای آن را فراخوانی می کند:IBinder binder = sandboxSdk.getInterface(); ISdkInterface mySdkInterface = ISdkInterface.Stub.asInterface(binder); mySdkInterface.something();
این برنامه همچنین میتواند با دنبال کردن این مراحل، رسانه را از SDK ارائه کند:
همانطور که در بخش رندر رسانه این سند توضیح داده شد، برای اینکه یک برنامه یک SDK دریافت کند تا رسانه را در یک نمای نمایش دهد، برنامه میتواند با
requestSurfacePackage()
تماس بگیرد وSurfaceControlViewHost.SurfacePackage
مناسب را واکشی کند.قطعه کد زیر یک نمونه API گویا را ارائه می دهد:
SdkSandboxManager.requestSurfacePackage(String sdkName, Bundle extraParams, Executor executor, OutcomeReceiver<Bundle, RequestSurfacePackageException> receiver)
سپس برنامه می تواند
SurfacePackage
برگشتی را از طریقsetChildSurfacePackage
API درSurfaceView
درSurfaceView
جاسازی کند.قطعه کد زیر یک نمونه API گویا را ارائه می دهد:
SurfaceView.setChildSurfacePackage(SurfacePackage surfacePackage)
پیشنهاد ما این است که APIهای IBinder
و requestSurfacePackage()
عمومی باشند و قرار نباشند مستقیماً توسط برنامه ها فراخوانی شوند. در عوض، این API توسط مرجع API ایجاد شده در بالا، در یک لایه "shim" فراخوانی می شود تا بار توسعه دهندگان برنامه کاهش یابد.
SDK به SDK
دو SDK در یک برنامه اغلب نیاز به ارتباط دارند. این می تواند زمانی اتفاق بیفتد که یک SDK معین به گونه ای طراحی شده باشد که از SDK های تشکیل دهنده تشکیل شده باشد، و ممکن است زمانی اتفاق بیفتد که دو SDK از طرف های مختلف برای برآورده کردن درخواستی از برنامه تماس گیرنده با یکدیگر همکاری کنند.
دو مورد کلیدی برای بررسی وجود دارد:
- زمانی که هر دو SDK زمان اجرا فعال هستند . در این حالت، هر دو SDK در زمان اجرای SDK با تمام محافظت های آن در حال اجرا هستند. SDK ها نمی توانند مانند یک برنامه امروزی ارتباط برقرار کنند. در نتیجه، یک API در
SdkSandboxController
اضافه شده است تا واکشی اشیاءSandboxedSdk
را برای همه RE-SDK های بارگذاری شده فعال کند. این به یک RE-SDK اجازه می دهد تا با سایر SDK های بارگذاری شده در زمان اجرا SDK ارتباط برقرار کند. - زمانی که فقط یک SDK در زمان اجرا فعال باشد .
- اگر کیت توسعه نرم افزاری فراخوانی در برنامه اجرا می شود، این کار هیچ تفاوتی با فراخوانی خود برنامه به دومین SDK در زمان اجرا SDK ندارد.
- اگر SDK فراخوانی در مدت زمان اجرای SDK اجرا میشود، این پیشنهاد پیشنهاد میکند که روشی را با استفاده از
IBinder
توضیح داده شده در بخش app-to-SDK نشان دهید که کد موجود در برنامه به آن گوش میدهد، پردازش میکند و با تماسهای ارائهشده پاسخ میدهد. - SDK های تبلیغاتی که در زمان اجرا فعال نیستند ممکن است نتوانند خودشان را ثبت کنند، ما ایجاد یک SDK میانجی را پیشنهاد می کنیم که شامل هر شریک یا SDK برنامه به عنوان وابستگی مستقیم به برنامه باشد و ثبت نام را کنترل می کند. این SDK میانجی ارتباط بین SDK های غیر فعال در زمان اجرا یا سایر وابستگی های برنامه و میانجی فعال در زمان اجرا که به عنوان آداپتور عمل می کند برقرار می کند.
مجموعه ویژگی برای ارتباطات SDK-SDK به دسته های زیر تقسیم شده است:
- ارتباط SDK-SDK در زمان اجرای SDK (موجود در آخرین پیشنمایش توسعهدهنده)
- ارتباط SDK-SDK بین و برنامه و زمان اجرا SDK (موجود در آخرین پیشنمایش برنامهنویس)
- نحوه عملکرد نماها و رندر از راه دور برای میانجیگری (پیشنهاد در حال توسعه)
موارد استفاده زیر در حال طراحی اولیه هستند:
- میانجیگری و مناقصه . بسیاری از SDK های تبلیغاتی قابلیت میانجیگری یا پیشنهاد قیمت را ارائه می دهند که به موجب آن SDK از SDK های مختلف دیگر برای نمایش تبلیغات (میانجی گری) یا برای جمع آوری سیگنال برای اجرای یک حراجی (مناقصه) فراخوانی می کند. معمولاً SDK هماهنگ کننده سایر SDK ها را از طریق یک آداپتور ارائه شده توسط SDK هماهنگ کننده فراخوانی می کند. با توجه به موارد ابتدایی بالا، SDK هماهنگ کننده، RE یا نه، باید بتواند به همه SDK های RE و غیرRE برای عملکرد عادی دسترسی داشته باشد. رندرینگ در این زمینه یک حوزه فعال تحقیق است.
- کشف ویژگی برخی از محصولات SDK از SDK های کوچکتری تشکیل شده اند که از طریق فرآیند کشف بین SDK، مجموعه ویژگی های نهایی را که در معرض توسعه دهنده برنامه قرار می گیرد، تعیین می کند. انتظار می رود که ثبت و کشف اولیه این مورد استفاده را فعال کند.
- مدل های اشتراک ناشر . برخی از SDKها به گونهای طراحی شدهاند که ناشر مرکزی رویدادها داشته باشند که سایر SDKها یا برنامهها میتوانند برای اعلانها از طریق تماسهای برگشتی مشترک شوند. موارد اولیه فوق باید از این مورد استفاده پشتیبانی کنند.
برنامه به برنامه
ارتباط برنامه به برنامه جایی است که حداقل یکی از دو فرآیندی که با هم ارتباط برقرار میکنند، یک SDK با زمان اجرا فعال است و یک بردار بالقوه برای اشتراکگذاری دادههای فاش نشده است. در نتیجه، SDK Runtime قادر به ایجاد یک کانال ارتباطی مستقیم با هیچ برنامه ای غیر از برنامه مشتری، یا با SDK در زمان اجرای SDK دیگری که برای برنامه دیگری ایجاد شده است، نیست. این امر از راه های زیر حاصل می شود:
- SDK نمیتواند مؤلفههایی مانند
<service>
،<contentprovider>
، یا<activity>
را در مانیفست خود تعریف کند. - SDK نمیتواند یک
ContentProvider
منتشر کند یا یک پخش ارسال کند. - SDK میتواند فعالیتی را که متعلق به یک برنامه دیگر است راهاندازی کند، اما با محدودیتهایی در مورد آنچه میتواند در Intent ارسال شود. به عنوان مثال، هیچ اقدام اضافی یا سفارشی را نمی توان به این Intent اضافه کرد.
- SDK فقط میتواند راهاندازی یا متصل به لیست مجاز خدمات باشد.
- SDK فقط میتواند به زیرمجموعهای از
ContentProvider
سیستم (مانندcom.android.providers.settings.SettingsProvider
) دسترسی داشته باشد، جایی که دادههای بهدستآمده فاقد شناسه هستند و نمیتوان از آنها برای ساخت اثر انگشت کاربر استفاده کرد. این بررسی ها همچنین برای دسترسی بهContentProvider
با استفاده ازContentResolver
اعمال می شود. - SDK فقط می تواند به زیر مجموعه ای از گیرنده های پخش محافظت شده (مانند
android.intent.action.AIRPLANE_MODE
) دسترسی داشته باشد.
برچسب های مانیفست
هنگامی که SDK نصب می شود، PackageManager
مانیفست SDK را تجزیه می کند و در صورت وجود برچسب های مانیفست ممنوع، SDK را نصب نمی کند. برای مثال، SDK ممکن است مؤلفههایی مانند <service>, <activity>, <provider>
، یا <receiver>
را تعریف نکند و ممکن است <permission>
در مانیفست اعلام نکند. برچسب هایی که با شکست مواجه می شوند در زمان اجرا SDK پشتیبانی نمی شوند. برچسبهایی که نصب با شکست مواجه نمیشوند اما بیصدا نادیده گرفته میشوند ممکن است در نسخههای اندروید آینده پشتیبانی شوند.
این بررسی ها همچنین ممکن است توسط هر ابزار زمان ساختی که SDK برای ایجاد بسته SDK استفاده می کند و در زمان آپلود در فروشگاه برنامه اعمال شود.
پشتیبانی از فعالیت
SDKها در محیط SDK Runtime نمیتوانند یک برچسب فعالیت به فایل مانیفست خود اضافه کنند و نمیتوانند فعالیتهای خود را با استفاده از Context.startActivity
شروع کنند. در عوض، پلتفرم در صورت درخواست، فعالیتهای SDK را ایجاد میکند و آنها را با SDK به اشتراک میگذارد.
فعالیت پلتفرم از نوع android.app.Activity
است. فعالیت پلت فرم از یکی از فعالیت های برنامه شروع می شود و بخشی از وظیفه برنامه است. FLAG_ACTIVITY_NEW_TASK
پشتیبانی نمی شود.
برای اینکه یک SDK شروع به فعالیت کند، باید نمونهای از نوع SdkSandboxActivityHandler
را ثبت کند که برای اطلاعرسانی در مورد ایجاد فعالیت زمانی که برنامه SdkSandboxManager::startSdkSandboxActivity(Activity, IBinder)
برای شروع فعالیت فرا میخواند، استفاده میشود.
جریان درخواست یک فعالیت در نمودار زیر نشان داده شده است.
توسعه
یک اصل کلیدی در این پیشنهاد، به حداقل رساندن تأثیر بر اکوسیستم توسعهدهنده تا حد امکان است. این پیشنهاد مجموعه ای جامع از ابزارهای توسعه را برای نوشتن، ساختن، اشکال زدایی برنامه های RE و SDK به توسعه دهندگان ارائه می دهد. برای اطمینان از یکپارچگی این پیشنهاد، تغییراتی در نحوه پیکربندی، تألیف و ساخت برنامههای RE و SDK وجود دارد.
تالیف
Android Studio و ابزارهای مربوطه بهروزرسانی میشوند تا SDK Runtime-aware باشند و به توسعهدهندگان کمک میکنند تا برنامهها و SDKهای RE خود را به درستی پیکربندی کردهاند و اطمینان حاصل شود که تماسهای قدیمی یا پشتیبانینشده به جایگزینهای جدیدتر در صورت لزوم بهروزرسانی میشوند. در طول مرحله نگارش، مراحلی وجود دارد که پیشنهاد ما به توسعه دهندگان نیاز دارد.
توسعه دهندگان برنامه
برنامه ها باید وابستگی های گواهی RE SDK و SDK خود را در مانیفست برنامه خود مشخص کنند. در پروپوزال ما این موضوع را به عنوان منبع حقیقت از سوی توسعهدهنده برنامه در سراسر این پیشنهاد در نظر میگیریم. به عنوان مثال:
- نام: نام بسته SDK یا کتابخانه.
- نسخه اصلی: کد نسخه اصلی SDK.
- خلاصه گواهی: خلاصه گواهی ساخت SDK. برای یک ساخت معین، به توسعهدهنده SDK پیشنهاد میکنیم این مقدار را از طریق فروشگاه برنامه مربوطه دریافت و ثبت کند.
این فقط برای SDK های توزیع شده در فروشگاه برنامه اعمال می شود، چه RE یا نه. برنامه هایی که به صورت ایستا SDK ها را به هم پیوند می دهند از مکانیسم های وابستگی فعلی استفاده می کنند.
با توجه به هدف ما از حداقل تأثیر برای توسعه دهندگان، مهم است که وقتی یک سطح API هدف که از زمان اجرای SDK پشتیبانی می کند مشخص شد، توسعه دهندگان برنامه فقط باید یک ساخت واحد داشته باشند، چه آن بیلد روی دستگاه هایی اجرا شود که از SDK Runtime پشتیبانی می کنند یا نه. .
توسعه دهندگان SDK
در طرح پیشنهادی ما، توسعهدهندگان RE SDK باید به صراحت عنصر جدیدی را که نماینده SDK یا موجودیت کتابخانه در مانیفست است، اعلام کنند. علاوه بر این، مجموعه ای از مقادیر مشابه به عنوان وابستگی باید به همراه یک نسخه فرعی ارائه شود:
- نام: نام بسته SDK یا کتابخانه.
- نسخه اصلی: کد نسخه اصلی SDK.
- نسخه کوچک: کد نسخه کوچک SDK.
اگر توسعهدهندگان RE SDK دارای سایر RE SDKها بهعنوان وابستگی در زمان ساخت باشند، احتمالاً باید آنها را به روشی یکسان با نحوه اعلام یک توسعهدهنده برنامه همان وابستگی اعلام کنند. RE SDK ها بسته به SDK های غیر RE به طور ایستا آنها را به هم مرتبط می کنند. اگر SDK های غیر RE به عملکردی نیاز داشته باشند که زمان اجرا SDK از آن پشتیبانی نمی کند، یا اگر باید در فرآیند برنامه اجرا شود، ممکن است مشکلاتی را در زمان ساخت یا در حین قبولی های آزمایشی شناسایی کند.
توسعهدهندگان RE SDK احتمالاً میخواهند به پشتیبانی از دستگاههای غیرفعال RE، مانند Android 12 یا پایینتر و همانطور که در بخش System Health سند اشاره شد، دستگاههای Android 13 سطح پایه با منابع سیستمی بسیار محدود، ادامه دهند. ما از طریق رویکردهایی کار می کنیم تا اطمینان حاصل کنیم که توسعه دهندگان SDK می توانند یک پایه کد واحد را برای پشتیبانی از محیط های RE و غیر RE حفظ کنند.
می سازد
توسعه دهندگان برنامه
ما انتظار داریم توسعه دهندگان برنامه تغییر کمی در مرحله ساخت تجربه کنند. وابستگیهای SDK، خواه به صورت محلی یا توزیعشده در فروشگاه برنامه (RE یا نه)، باید برای پر کردن، کامپایل و ساختها در دستگاه وجود داشته باشند. ما پیشنهاد می کنیم که Android Studio این جزئیات را با استفاده معمولی از توسعه دهنده برنامه انتزاعی کند و تا حد امکان شفاف کند.
اگرچه ما انتظار داریم که ساخت DEBUG باید شامل تمام کدها و نمادهای موجود در ساخت DEBUG برای اشکالزدایی باشد، ساختهای RELEASE به صورت اختیاری همه SDKهای توزیعشده در فروشگاه برنامه (RE یا نه) را از مصنوع نهایی حذف میکنند.
ما زودتر در مرحله طراحی خود در اینجا هستیم و در صورت تحقق، موارد بیشتری را به اشتراک خواهیم گذاشت.
توسعه دهندگان SDK
ما روی مسیری کار میکنیم تا اطمینان حاصل کنیم که نسخههای غیر RE و RE یک SDK را میتوان در یک آرتیفکت برای توزیع قرار داد. این امر مانع از نیاز توسعه دهندگان برنامه به پشتیبانی از ساخت های جداگانه برای نسخه های RE و غیر RE یک SDK می شود.
تقریباً مانند برنامهها، هر SDK وابستگی توزیعشده در فروشگاه برنامهها باید برای پر کردن، کامپایل و ساختها در دستگاه وجود داشته باشد، و ما انتظار داریم که Android Studio این کار را یکپارچه تسهیل کند.
تست کردن
توسعه دهندگان برنامه
همانطور که در پیشنهاد ما توضیح داده شد، توسعه دهندگان برنامه می توانند برنامه های خود را بر روی دستگاه های دارای Android 13 به روش معمول آزمایش کنند. پس از اینکه آنها برنامه خود را ساختند، برنامه می تواند روی دستگاه یا شبیه ساز RE نصب شود. این فرآیند نصب اطمینان حاصل میکند که SDKهای صحیح در زمان اجرا SDK برای دستگاه یا شبیهساز نصب میشوند، خواه SDKها از یک مخزن SDK راه دور یا حافظه پنهان از سیستم ساخت خارج شده باشند.
توسعه دهندگان SDK
توسعه دهندگان SDK معمولاً از برنامه های آزمایشی داخلی روی دستگاه ها و شبیه سازها برای آزمایش توسعه آنها استفاده می کنند. پیشنهاد ما این را تغییر نمیدهد، و اعتبارسنجی درونبرنامه همان مراحلی را دنبال میکند که برای توسعهدهندگان برنامه در بالا ذکر شد، با یک مصنوع ساخت برای برنامههای RE و غیر RE. توسعهدهندگان SDK میتوانند کد خود را چه در زمان اجرا SDK باشد یا نه، مرور کنند، هرچند ممکن است محدودیتهایی در ابزارهای پیشرفته اشکالزدایی و پروفایل وجود داشته باشد. این یک منطقه فعال تحقیق است.
توزیع
پیشنهاد طراحی ما برای جداسازی یک برنامه از SDK های آن، امکان توزیع SDK ها در فروشگاه App را ایجاد کرده است. این یک امکان عمومی است، نه منحصر به یک فروشگاه اپلیکیشن خاص. مزایا واضح است:
- از کیفیت و سازگاری SDK ها اطمینان حاصل کنید.
- انتشار ساده برای توسعه دهندگان SDK.
- بهروزرسانیهای نسخه کوچک SDK را برای برنامههای نصبشده تسریع کنید.
برای پشتیبانی از توزیع SDK، یک فروشگاه برنامه احتمالاً باید بیشتر قابلیتهای زیر را ارائه دهد:
- مکانیزمی برای توسعه دهندگان SDK برای آپلود SDK های قابل توزیع در فروشگاه برنامه خود در فروشگاه، به روز رسانی آنها، بازگرداندن آنها و احتمالا حذف آنها.
- مکانیزمی برای اطمینان از یکپارچگی یک SDK و منشأ آن، و یک برنامه و منشأ آن، و رفع وابستگیهای آنها.
- مکانیزمی برای استقرار آنها بر روی دستگاه ها به شیوه ای ثابت و قابل اعتماد.
محدودیت های در حال تکامل در طول زمان
انتظار داریم محدودیتهای کد در زمان اجرا SDK با نسخههای بعدی اندروید تغییر کند. برای اطمینان از سازگاری برنامه، این محدودیتها را با بهروزرسانیهای ماژول خط اصلی برای یک سطح SDK معین تغییر نمیدهیم. رفتار مرتبط با یک targetSdkVersion
معین حفظ میشود تا زمانی که پشتیبانی از آن targetSdkVersion
از طریق خطمشی فروشگاه برنامه منسوخ شود، و لغو targetSdkVersion
ممکن است با سرعت بیشتری نسبت به برنامهها اتفاق بیفتد. انتظار داشته باشید که محدودیتها بهطور مکرر در نسخههای Android SDK تغییر کند، بهویژه در چند نسخه اول.
علاوه بر این، ما در حال ساخت یک مکانیسم قناری هستیم تا به آزمایشکنندگان خارجی و داخلی اجازه دهد به گروهی بپیوندند که مجموعه محدودیتهای پیشنهادی را برای نسخه بعدی Android دریافت میکند. این به ما کمک می کند تا در مورد تغییرات پیشنهادی در مجموعه محدودیت ها بازخورد و اطمینان حاصل کنیم.
سوالات متداول
SDK مرتبط با تبلیغات چیست؟
یک کیت توسعه نرم افزاری مرتبط با تبلیغات، کیتی است که هر بخشی از هدف گیری کاربران را با پیام هایی برای اهداف تجاری، در برنامه هایی که متعلق به تبلیغ کننده نیستند، تسهیل می کند. این شامل، اما نه محدود به، SDK های تجزیه و تحلیل است که در آنها می توان گروه های کاربری را برای هدف گیری بعدی ایجاد کرد، SDK های ارائه دهنده تبلیغات، SDK های ضد سوء استفاده و ضد تقلب برای تبلیغات، SDK های تعامل، و SDK های ارجاع.
آیا هر SDK می تواند در زمان اجرا SDK اجرا شود؟
اگرچه تمرکز اولیه روی SDK های مرتبط با تبلیغات است، توسعه دهندگان SDK های غیرمرتبط با تبلیغات که به دنبال وضعیت حفظ حریم خصوصی هستند و معتقدند که می توانند تحت شرایط ذکر شده در بالا کار کنند، می توانند درباره SDK های خود که در زمان اجرای SDK اجرا می شوند، بازخورد خود را به اشتراک بگذارند. با این حال، SDK Runtime طوری طراحی نشده است که با همه طرحهای SDK سازگار باشد. فراتر از محدودیت های مستند، SDK Runtime احتمالا برای SDK هایی که نیاز به ارتباطات بلادرنگ یا توان عملیاتی بالا با برنامه میزبانی دارند، نامناسب است.
چرا جداسازی فرآیند را به جای جداسازی در زمان اجرا مبتنی بر جاوا یک فرآیند انتخاب کنید؟
در حال حاضر، زمان اجرا مبتنی بر جاوا به آسانی مرزهای امنیتی لازم برای تضمین حریم خصوصی مورد نظر برای کاربران اندروید را تسهیل نمی کند. تلاش برای اجرای چنین چیزی احتمالاً نیازمند تلاش چند ساله است، بدون اینکه تضمینی برای موفقیت باشد. بنابراین، Privacy Sandbox از مرزهای فرآیند استفاده میکند، یک فناوری آزمایششده و به خوبی درک شده.
آیا انتقال SDK ها به فرآیند SDK Runtime باعث صرفه جویی در حجم دانلود یا فضا می شود؟
اگر چندین برنامه با SDK های یک نسخه با قابلیت زمان اجرا ادغام شوند، این امر می تواند حجم دانلود و فضای دیسک را کاهش دهد.
آیا SDK ها در زمان اجرای SDK به چه نوع رویدادهای چرخه حیات برنامه مانند زمانی که برنامه به پس زمینه می رود دسترسی خواهند داشت؟
ما به طور فعال در حال کار بر روی پشتیبانی طراحی برای اطلاع رسانی زمان اجرا SDK در رویدادهای چرخه عمر برنامه مشتری آن در سطح برنامه هستیم (مثلاً رفتن برنامه به پس زمینه، رفتن برنامه به پیش زمینه). طرح و کد نمونه در پیشنمایش برنامهنویس آینده به اشتراک گذاشته خواهد شد.
برای شما توصیه می شود
- توجه: وقتی جاوا اسکریپت خاموش است، متن پیوند نمایش داده می شود
- راهنمای توسعه SDK Runtime