Partager via


TelephonyManager.GetImei(Int32) Method

Definition

Returns the IMEI (International Mobile Equipment Identity).

[Android.Runtime.Register("getImei", "(I)Ljava/lang/String;", "GetGetImei_IHandler", ApiSince=26)]
[Android.Runtime.RequiresPermission("android.permission.READ_PRIVILEGED_PHONE_STATE")]
public virtual string? GetImei (int slotIndex);
[<Android.Runtime.Register("getImei", "(I)Ljava/lang/String;", "GetGetImei_IHandler", ApiSince=26)>]
[<Android.Runtime.RequiresPermission("android.permission.READ_PRIVILEGED_PHONE_STATE")>]
abstract member GetImei : int -> string
override this.GetImei : int -> string

Parameters

slotIndex
Int32

of which IMEI is returned

Returns

Attributes

Remarks

Returns the IMEI (International Mobile Equipment Identity). Return null if IMEI is not available.

Starting with API level 29, persistent device identifiers are guarded behind additional restrictions, and apps are recommended to use resettable identifiers (see Best practices for unique identifiers). This method can be invoked if one of the following requirements is met: <ul> <li>If the calling app has been granted the READ_PRIVILEGED_PHONE_STATE permission; this is a privileged permission that can only be granted to apps preloaded on the device. <li>If the calling app is the device owner of a fully-managed device, a profile owner of an organization-owned device, or their delegates (see android.app.admin.DevicePolicyManager#getEnrollmentSpecificId()). <li>If the calling app has carrier privileges (see #hasCarrierPrivileges) on any active subscription. <li>If the calling app is the default SMS role holder (see RoleManager#isRoleHeld(String)). <li>If the calling app has been granted the Manifest.permission#USE_ICC_AUTH_WITH_DEVICE_IDENTIFIER permission. </ul>

If the calling app does not meet one of these requirements then this method will behave as follows:

<ul> <li>If the calling app's target SDK is API level 28 or lower and the app has the READ_PHONE_STATE permission then null is returned.</li> <li>If the calling app's target SDK is API level 28 or lower and the app does not have the READ_PHONE_STATE permission, or if the calling app is targeting API level 29 or higher, then a SecurityException is thrown.</li> </ul>

Java documentation for android.telephony.TelephonyManager.getImei(int).

Portions of this page are modifications based on work created and shared by the Android Open Source Project and used according to terms described in the Creative Commons 2.5 Attribution License.

Applies to