SafetyNet Verify Apps API

SafetyNet Verify Apps API، کتابخانه‌ای که توسط سرویس‌های Google Play پشتیبانی می‌شود، به برنامه شما اجازه می‌دهد تا به صورت برنامه‌نویسی با ویژگی Verify Apps در دستگاه تعامل داشته باشد و از دستگاه در برابر برنامه‌های بالقوه مضر محافظت کند.

اگر برنامه شما داده‌های حساس کاربر، مانند اطلاعات مالی را مدیریت می‌کند، مهم است که تأیید کنید دستگاه کاربر در برابر برنامه‌های مخرب محافظت می‌شود و هیچ برنامه‌ای ندارد که بتواند جعل هویت برنامه شما یا انجام سایر اقدامات مخرب باشد. اگر امنیت دستگاه با حداقل وضعیت امنیتی مطابقت ندارد، می‌توانید عملکرد برنامه خود را غیرفعال کنید تا خطر را برای کاربر کاهش دهید.

به عنوان بخشی از تعهد مستمر خود برای ایمن کردن اکوسیستم اندروید تا حد امکان، Google بر رفتار برنامه‌های اندروید نظارت و نمایه می‌کند. اگر ویژگی تأیید برنامه‌ها یک برنامه بالقوه خطرناک را شناسایی کند، به همه کاربرانی که برنامه را نصب کرده‌اند اطلاع داده می‌شود و تشویق می‌شود که سریعاً برنامه را حذف نصب کنند. این فرآیند از امنیت و حریم خصوصی این کاربران محافظت می کند.

SafetyNet Verify Apps API به شما امکان می دهد از این ویژگی برای محافظت از داده های برنامه خود استفاده کنید. با استفاده از این API، می‌توانید تعیین کنید که آیا دستگاه کاربر توسط ویژگی تأیید برنامه‌ها محافظت می‌شود یا خیر، کاربرانی را که قبلاً از این ویژگی استفاده نمی‌کنند تشویق کنید تا در حفاظت از آن شرکت کنند، و هر برنامه بالقوه مضر شناخته‌شده‌ای را که روی دستگاه نصب شده است شناسایی کنید. .

شرایط اضافی خدمات

با دسترسی یا استفاده از APIهای SafetyNet، با شرایط خدمات Google APIs و شرایط خدمات Verify Apps API زیر موافقت می‌کنید. لطفاً قبل از دسترسی به APIها، همه شرایط و خط مشی های قابل اجرا را بخوانید و درک کنید.

شرایط سرویس Apps API را تأیید کنید

تجزیه و تحلیل برنامه‌هایی که برنامه‌های مضر بالقوه را شناسایی می‌کنند ممکن است هم مثبت کاذب و هم منفی کاذب به دست آورند. نتایج (یا عدم وجود آنها) از این مجموعه API به بهترین نحو ارائه شده است. شما تأیید و درک می کنید که نتایج ارائه شده توسط این مجموعه API SafetyNet تضمین نمی شود که همیشه دقیق باشند.

وابستگی SafetyNet API را اضافه کنید

قبل از استفاده از Verify Apps API، SafetyNet API را به پروژه خود اضافه کنید. اگر از Android Studio استفاده می کنید، این وابستگی را به فایل Gradle در سطح برنامه خود اضافه کنید. برای اطلاعات بیشتر، تنظیمات SafetyNet API را ببینید.

تأیید برنامه را فعال کنید

SafetyNet Verify Apps API دو روش را برای فعال کردن ویژگی Verify Apps ارائه می‌کند. شما می توانید تعیین کنید که آیا تأیید برنامه با استفاده از isVerifyAppsEnabled() فعال است یا خیر، و می توانید با استفاده از enableVerifyApps() درخواست فعال سازی تأیید برنامه را بدهید.

تفاوت بین این دو روش در این است که در حالی که isVerifyAppsEnabled() وضعیت فعلی ویژگی Verify Apps را گزارش می کند، enableVerifyApps() به صراحت از کاربر برای استفاده از این ویژگی رضایت می خواهد. اگر می‌خواهید برنامه شما فقط از وضعیت ویژگی آگاه باشد تا تصمیمی مبتنی بر امنیت بگیرد، برنامه شما باید isVerifyAppsEnabled() فراخوانی کند. با این حال، اگر می‌خواهید مطمئن شوید که برنامه شما می‌تواند برنامه‌های نصب شده بالقوه مضر را فهرست کند، باید به‌جای آن enableVerifyApps() فراخوانی کنید.

تعیین کنید که آیا تأیید برنامه فعال است یا خیر

روش ناهمزمان isVerifyAppsEnabled() به برنامه شما اجازه می دهد تعیین کند که آیا کاربر در ویژگی Verify Apps ثبت نام کرده است یا خیر. این روش یک شی VerifyAppsUserResponse را برمی گرداند که حاوی اطلاعاتی در مورد تمام اقداماتی است که کاربر در رابطه با ویژگی Verify Apps انجام داده است، از جمله فعال کردن آن.

قطعه کد زیر نحوه ایجاد پاسخ تماس مرتبط با این روش را نشان می دهد:

SafetyNet.getClient(this)
        .isVerifyAppsEnabled
        .addOnCompleteListener { task ->
            if (task.isSuccessful) {
                if (task.result.isVerifyAppsEnabled) {
                    Log.d("MY_APP_TAG", "The Verify Apps feature is enabled.")
                } else {
                    Log.d("MY_APP_TAG", "The Verify Apps feature is disabled.")
                }
            } else {
                Log.e("MY_APP_TAG", "A general error occurred.")
            }
        }
SafetyNet.getClient(this)
    .isVerifyAppsEnabled()
    .addOnCompleteListener(new OnCompleteListener<VerifyAppsUserResponse>() {
        @Override
        public void onComplete(Task<VerifyAppsUserResponse> task) {
            if (task.isSuccessful()) {
                VerifyAppsUserResponse result = task.getResult();
                if (result.isVerifyAppsEnabled()) {
                    Log.d("MY_APP_TAG", "The Verify Apps feature is enabled.");
                } else {
                    Log.d("MY_APP_TAG", "The Verify Apps feature is disabled.");
                }
            } else {
                Log.e("MY_APP_TAG", "A general error occurred.");
            }
        }
    });

درخواست فعال کردن تأیید برنامه

متد enableVerifyApps() ناهمزمان به برنامه شما اجازه می‌دهد تا یک گفتگو را فراخوانی کند و از کاربر بخواهد ویژگی Verify Apps را فعال کند. این روش یک شی VerifyAppsUserResponse را برمی گرداند، که حاوی اطلاعاتی در مورد تمام اقداماتی است که کاربر در رابطه با ویژگی Verify Apps انجام داده است، از جمله اینکه آیا با فعال کردن آن موافقت کرده است یا خیر.

قطعه کد زیر نحوه ایجاد پاسخ تماس مرتبط با این روش را نشان می دهد:

SafetyNet.getClient(this)
        .enableVerifyApps()
        .addOnCompleteListener { task ->
            if (task.isSuccessful) {
                if (task.result.isVerifyAppsEnabled) {
                    Log.d("MY_APP_TAG", "The user gave consent to enable the Verify Apps feature.")
                } else {
                    Log.d(
                            "MY_APP_TAG",
                            "The user didn't give consent to enable the Verify Apps feature."
                    )
                }
            } else {
                Log.e("MY_APP_TAG", "A general error occurred.")
            }
        }
SafetyNet.getClient(this)
    .enableVerifyApps()
    .addOnCompleteListener(new OnCompleteListener<VerifyAppsUserResponse>() {
        @Override
        public void onComplete(Task<VerifyAppsUserResponse> task) {
            if (task.isSuccessful()) {
                VerifyAppsUserResponse result = task.getResult();
                if (result.isVerifyAppsEnabled()) {
                    Log.d("MY_APP_TAG", "The user gave consent " +
                          "to enable the Verify Apps feature.");
                } else {
                    Log.d("MY_APP_TAG", "The user didn't give consent " +
                          "to enable the Verify Apps feature.");
                }
            } else {
                Log.e("MY_APP_TAG", "A general error occurred.");
            }
        }
    });

هنگام استفاده از این روش، برنامه شما ممکن است با یک یا چند شرایط غیرعادی مواجه شود:

  • اگر ویژگی Verify Apps قبلاً فعال باشد، کادر گفتگو ظاهر نمی‌شود و API طوری رفتار می‌کند که انگار کاربر رضایت خود را برای فعال کردن این ویژگی اعلام کرده است.
  • اگر کاربر از دیالوگ دور شود، گفتگو از بین می‌رود و API فرض می‌کند که کاربر برای فعال کردن این ویژگی رضایت نداده است.
  • اگر برنامه شما و یک برنامه دیگر به طور همزمان این روش را فراخوانی کنند، فقط یک گفتگو ظاهر می شود و همه برنامه ها مقادیر بازگشتی یکسانی را از روش دریافت می کنند.

برنامه های نصب شده مضر را فهرست کنید

روش ناهمزمان listHarmfulApps() به شما امکان می دهد لیستی از هر برنامه بالقوه مضر شناخته شده ای را که کاربر بر روی دستگاه خود نصب کرده است به دست آورید. این فهرست شامل دسته‌هایی برای برنامه‌های بالقوه مضر شناسایی‌شده است تا برنامه شما بتواند اقدامات لازم را انجام دهد.

قطعه کد زیر نحوه ایجاد پاسخ تماس مرتبط با این روش را نشان می دهد:

SafetyNet.getClient(this)
        .listHarmfulApps()
        .addOnCompleteListener { task ->
            Log.d(TAG, "Received listHarmfulApps() result")

            if (task.isSuccessful) {
                val result = task.result
                val scanTimeMs = result.lastScanTimeMs

                val appList = result.harmfulAppsList
                if (appList?.isNotEmpty() == true) {
                    Log.e("MY_APP_TAG", "Potentially harmful apps are installed!")

                    for (harmfulApp in appList) {
                        Log.e("MY_APP_TAG", "Information about a harmful app:")
                        Log.e("MY_APP_TAG", "  APK: ${harmfulApp.apkPackageName}")
                        Log.e("MY_APP_TAG", "  SHA-256: ${harmfulApp.apkSha256}")

                        // Categories are defined in VerifyAppsConstants.
                        Log.e("MY_APP_TAG", "  Category: ${harmfulApp.apkCategory}")
                    }
                } else {
                    Log.d("MY_APP_TAG", "There are no known potentially harmful apps installed.")
                }
            } else {
                Log.d(
                        "MY_APP_TAG",
                        "An error occurred. Call isVerifyAppsEnabled() to ensure that the user "
                                + "has consented."
                )
            }
        }
SafetyNet.getClient(this)
    .listHarmfulApps()
    .addOnCompleteListener(new OnCompleteListener<HarmfulAppsResponse>() {
        @Override
        public void onComplete(Task<HarmfulAppsResponse> task) {
            Log.d(TAG, "Received listHarmfulApps() result");

            if (task.isSuccessful()) {
                HarmfulAppsResponse result = task.getResult();
                long scanTimeMs = result.getLastScanTimeMs();

                List<HarmfulAppsData> appList = result.getHarmfulAppsList();
                if (appList.isEmpty()) {
                    Log.d("MY_APP_TAG", "There are no known " +
                          "potentially harmful apps installed.");
                } else {
                    Log.e("MY_APP_TAG",
                          "Potentially harmful apps are installed!");

                    for (HarmfulAppsData harmfulApp : appList) {
                        Log.e("MY_APP_TAG", "Information about a harmful app:");
                        Log.e("MY_APP_TAG",
                              "  APK: " + harmfulApp.apkPackageName);
                        Log.e("MY_APP_TAG",
                              "  SHA-256: " + harmfulApp.apkSha256);

                        // Categories are defined in VerifyAppsConstants.
                        Log.e("MY_APP_TAG",
                              "  Category: " + harmfulApp.apkCategory);
                    }
                }
            } else {
                Log.d("MY_APP_TAG", "An error occurred. " +
                      "Call isVerifyAppsEnabled() to ensure " +
                      "that the user has consented.");
            }
        }
    });