В Android есть два типа API-интерфейсов, которые недоступны через SDK.
Первый находится в упаковке com.android.internal
. Второй тип API - это набор классов и методов, помеченных атрибутом @hide Javadoc .
Начиная с Android 9 (уровень API 28), Google вводит новые ограничения на использование интерфейсов , отличных от SDK , напрямую, через отражение или через JNI. Эти ограничения применяются всякий раз, когда приложение ссылается на интерфейс, не относящийся к SDK, или пытается получить его дескриптор с помощью отражения или JNI.
Но до уровня API 28 к скрытым методам можно было получить доступ через отражение Java. @hide
Атрибут является лишь частью Javadoc (droiddoc также), так что @hide
просто означает , что метод / класс / поле исключен из API Docs.
Например, в checkUidPermission()
методе ActivityManager.java
используются @hide
:
/** @hide */
public static int checkUidPermission(String permission, int uid) {
try {
return AppGlobals.getPackageManager()
.checkUidPermission(permission, uid);
} catch (RemoteException e) {
// Should never happen, but if it does... deny!
Slog.e(TAG, "PackageManager is dead?!?", e);
}
return PackageManager.PERMISSION_DENIED;
}
Однако мы можем назвать это отражением:
Class c;
c = Class.forName("android.app.ActivityManager");
Method m = c.getMethod("checkUidPermission", new Class[] {String.class, int.class});
Object o = m.invoke(null, new Object[]{"android.permission.READ_CONTACTS", 10010});