各機器を一意に識別するために、IMEI(またはCDMA機器の場合はESN番号)を使用します。プログラム的にこれにアクセスするには?
Android.telephony.TelephonyManager.getDeviceId()
を呼び出します。
これは、デバイスを一意に識別する任意の文字列(GSMではIMEI、CDMAではMEID)を返します。
AndroidManifest.xml
には以下の権限が必要です。
<uses-permission Android:name="Android.permission.READ_PHONE_STATE" />
これを行うためには。
それが言われているので、これをすることに注意してください。なぜあなたのアプリケーションが自分のテレフォニースタックにアクセスしているのか不思議に思うだけでなく、ユーザーが新しいデバイスを手に入れた場合にデータを移行するのは難しいかもしれません。
更新: 下記のコメントで述べたように、これはユーザーを認証するための安全な方法ではなく、プライバシーの問題を引き起こします。お勧めできません。代わりに、 Google+ Login API を見てください。摩擦のないログインシステムを実装したい場合は。
Android Backup API は、ユーザーが自分の電話をリセットしたとき(または新しいデバイスを購入したとき)に文字列の束を永続化する軽量な方法が必要な場合にも使用できます。
Trevor Johnsの答えに加えて、これを次のように使用できます。
TelephonyManager telephonyManager = (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
telephonyManager.getDeviceId();
そして、あなたはあなたのManifest.xmlファイルに次の権限を追加するべきです:
<uses-permission Android:name="Android.permission.READ_PHONE_STATE"/>
エミュレータでは、おそらく "00000 ..."のような値になるでしょう。デバイスIDが利用できない場合、getDeviceId()はNULLを返します。
デバイスに電話機能がない場合は、IMEIを取得するか、代替としてSecure.Android_IDを使用するために、次のコードを使用します。
/**
* Returns the unique identifier for the device
*
* @return unique identifier for the device
*/
public String getDeviceIMEI() {
String deviceUniqueIdentifier = null;
TelephonyManager tm = (TelephonyManager) this.getSystemService(Context.TELEPHONY_SERVICE);
if (null != tm) {
deviceUniqueIdentifier = tm.getDeviceId();
}
if (null == deviceUniqueIdentifier || 0 == deviceUniqueIdentifier.length()) {
deviceUniqueIdentifier = Settings.Secure.getString(this.getContentResolver(), Settings.Secure.Android_ID);
}
return deviceUniqueIdentifier;
}
あるいは、Android.Provider.Settings.SystemからAndroid_ID設定を使用することもできます(ここに記載されているように strazerre.com )。
これは特別な許可を必要としませんが、別のアプリケーションが書き込みアクセスを持っていてそれを変更した場合には変更される可能性があるという利点があります(これは明らかに珍しいが不可能ではありません)。
参考までに、ブログのコードをここに示します。
import Android.provider.Settings;
import Android.provider.Settings.System;
String androidID = System.getString(this.getContentResolver(),Secure.Android_ID);
インプリメンテーションノート :IDがシステムアーキテクチャにとって重要である場合は、実際にはいくつかの非常にローエンドのAndroid携帯電話やタブレットが同じAndroid IDを再利用していることがわかっています(9774d56d682e549cログに表示される値)
から: http://mytechead.wordpress.com/2011/08/28/how-to-get-imei-number-of-Android-device/ :
次のコードは、AndroidデバイスのIMEI番号を取得するのに役立ちます。
TelephonyManager tm = (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
String device_id = tm.getDeviceId();
Androidのマニフェストに必要な権限:
Android.permission.READ_PHONE_STATE
注:携帯電話のIMEIとして機能できないタブレットやデバイスの場合は無効になります。
_ imei _ (国際移動機識別子)を取得する
public String getIMEI(Activity activity) {
TelephonyManager telephonyManager = (TelephonyManager) activity
.getSystemService(Context.TELEPHONY_SERVICE);
return telephonyManager.getDeviceId();
}
デバイス固有のIDを取得する
public String getDeviceUniqueID(Activity activity){
String device_unique_id = Secure.getString(activity.getContentResolver(),
Secure.Android_ID);
return device_unique_id;
}
Android 6.0以降のゲームは変更されたため、これを使用することをお勧めします。
実行する最善の方法は実行時にそうでなければパーミッションエラーが発生します。
/**
* A loading screen after AppIntroActivity.
*/
public class LoadingActivity extends BaseActivity {
private static final int MY_PERMISSIONS_REQUEST_READ_PHONE_STATE = 0;
private TextView loading_tv2;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_loading);
//trigger 'loadIMEI'
loadIMEI();
/** Fading Transition Effect */
overridePendingTransition(Android.R.anim.fade_in, Android.R.anim.fade_out);
}
/**
* Called when the 'loadIMEI' function is triggered.
*/
public void loadIMEI() {
// Check if the READ_PHONE_STATE permission is already available.
if (ActivityCompat.checkSelfPermission(this, Manifest.permission.READ_PHONE_STATE)
!= PackageManager.PERMISSION_GRANTED) {
// READ_PHONE_STATE permission has not been granted.
requestReadPhoneStatePermission();
} else {
// READ_PHONE_STATE permission is already been granted.
doPermissionGrantedStuffs();
}
}
/**
* Requests the READ_PHONE_STATE permission.
* If the permission has been denied previously, a dialog will Prompt the user to grant the
* permission, otherwise it is requested directly.
*/
private void requestReadPhoneStatePermission() {
if (ActivityCompat.shouldShowRequestPermissionRationale(this,
Manifest.permission.READ_PHONE_STATE)) {
// Provide an additional rationale to the user if the permission was not granted
// and the user would benefit from additional context for the use of the permission.
// For example if the user has previously denied the permission.
new AlertDialog.Builder(LoadingActivity.this)
.setTitle("Permission Request")
.setMessage(getString(R.string.permission_read_phone_state_rationale))
.setCancelable(false)
.setPositiveButton(Android.R.string.yes, new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
//re-request
ActivityCompat.requestPermissions(LoadingActivity.this,
new String[]{Manifest.permission.READ_PHONE_STATE},
MY_PERMISSIONS_REQUEST_READ_PHONE_STATE);
}
})
.setIcon(R.drawable.onlinlinew_warning_sign)
.show();
} else {
// READ_PHONE_STATE permission has not been granted yet. Request it directly.
ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.READ_PHONE_STATE},
MY_PERMISSIONS_REQUEST_READ_PHONE_STATE);
}
}
/**
* Callback received when a permissions request has been completed.
*/
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions,
@NonNull int[] grantResults) {
if (requestCode == MY_PERMISSIONS_REQUEST_READ_PHONE_STATE) {
// Received permission result for READ_PHONE_STATE permission.est.");
// Check if the only required permission has been granted
if (grantResults.length == 1 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
// READ_PHONE_STATE permission has been granted, proceed with displaying IMEI Number
//alertAlert(getString(R.string.permision_available_read_phone_state));
doPermissionGrantedStuffs();
} else {
alertAlert(getString(R.string.permissions_not_granted_read_phone_state));
}
}
}
private void alertAlert(String msg) {
new AlertDialog.Builder(LoadingActivity.this)
.setTitle("Permission Request")
.setMessage(msg)
.setCancelable(false)
.setPositiveButton(Android.R.string.yes, new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
// do somthing here
}
})
.setIcon(R.drawable.onlinlinew_warning_sign)
.show();
}
public void doPermissionGrantedStuffs() {
//Have an object of TelephonyManager
TelephonyManager tm =(TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
//Get IMEI Number of Phone //////////////// for this example i only need the IMEI
String IMEINumber=tm.getDeviceId();
/************************************************
* **********************************************
* This is just an icing on the cake
* the following are other children of TELEPHONY_SERVICE
*
//Get Subscriber ID
String subscriberID=tm.getDeviceId();
//Get SIM Serial Number
String SIMSerialNumber=tm.getSimSerialNumber();
//Get Network Country ISO Code
String networkCountryISO=tm.getNetworkCountryIso();
//Get SIM Country ISO Code
String SIMCountryISO=tm.getSimCountryIso();
//Get the device software version
String softwareVersion=tm.getDeviceSoftwareVersion()
//Get the Voice mail number
String voiceMailNumber=tm.getVoiceMailNumber();
//Get the Phone Type CDMA/GSM/NONE
int phoneType=tm.getPhoneType();
switch (phoneType)
{
case (TelephonyManager.PHONE_TYPE_CDMA):
// your code
break;
case (TelephonyManager.PHONE_TYPE_GSM)
// your code
break;
case (TelephonyManager.PHONE_TYPE_NONE):
// your code
break;
}
//Find whether the Phone is in Roaming, returns true if in roaming
boolean isRoaming=tm.isNetworkRoaming();
if(isRoaming)
phoneDetails+="\nIs In Roaming : "+"YES";
else
phoneDetails+="\nIs In Roaming : "+"NO";
//Get the SIM state
int SIMState=tm.getSimState();
switch(SIMState)
{
case TelephonyManager.SIM_STATE_ABSENT :
// your code
break;
case TelephonyManager.SIM_STATE_NETWORK_LOCKED :
// your code
break;
case TelephonyManager.SIM_STATE_PIN_REQUIRED :
// your code
break;
case TelephonyManager.SIM_STATE_PUK_REQUIRED :
// your code
break;
case TelephonyManager.SIM_STATE_READY :
// your code
break;
case TelephonyManager.SIM_STATE_UNKNOWN :
// your code
break;
}
*/
// Now read the desired content to a textview.
loading_tv2 = (TextView) findViewById(R.id.loading_tv2);
loading_tv2.setText(IMEINumber);
}
}
これがあなたや誰かに役立つことを願っています。
新しいアップデート:
Androidバージョン6以降では、WLAN MACアドレスは推奨されなくなりました。TrevorJohnsの回答に従ってください。
更新:
デバイスを一意に識別するために、 Secure.Android_ID を使用できます。
旧回答:
IMEIを一意のデバイスIDとして使用することのデメリット:
WLAN MACアドレス文字列を使用できます(WLAN MACアドレスはMarshmallow以降では推奨されていないため、MarshmallowおよびMarshmallow +にはお勧めできません。したがって、偽の値が得られます)
WLANのMACアドレスを使用して、Android携帯の一意のIDを取得することもできます。 MACアドレスはすべてのデバイスに固有のものであり、あらゆる種類のデバイスに対して機能します。
デバイスIDとしてWLAN MACアドレスを使用する利点:
それはすべてのタイプのデバイス(スマートフォンとタブレット)のためのユニークな識別子です。
アプリケーションが再インストールされた場合は一意のままです
WLAN MACアドレスをデバイスIDとして使用することのデメリット:
あなたにマシュマロと上から偽の価値を与えなさい。
デバイスにWi-Fiハードウェアがない場合は、ヌルのMACアドレスが表示されますが、一般的にAndroidデバイスのほとんどにWi-Fiハードウェアがあり、Wi-Fiハードウェアがない市場にはほとんどデバイスがありません。
SOURCE: technetexperts.com
API 26と同様に、getDeviceId()は廃止予定なので、次のコードを使用してAPI 26以前のバージョンに対応できます。
TelephonyManager telephonyManager = (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
String imei="";
if (Android.os.Build.VERSION.SDK_INT >= 26) {
imei=telephonyManager.getImei();
}
else
{
imei=telephonyManager.getDeviceId();
}
上記のコードを使用するために "READ_PHONE_STATE"に対する許可要求を追加することを忘れないでください。
TelephonyManagerのメソッドgetDeviceId()は一意のデバイスIDを返します。たとえば、GSMの場合はIMEI、CDMA電話の場合はMEIDまたはESNです。デバイスIDが利用できない場合はnullを返します。
Javaコード
package com.AndroidTelephonyManager;
import Android.app.Activity;
import Android.content.Context;
import Android.os.Bundle;
import Android.telephony.TelephonyManager;
import Android.widget.TextView;
public class AndroidTelephonyManager extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
TextView textDeviceID = (TextView)findViewById(R.id.deviceid);
//retrieve a reference to an instance of TelephonyManager
TelephonyManager telephonyManager = (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
textDeviceID.setText(getDeviceID(telephonyManager));
}
String getDeviceID(TelephonyManager phonyManager){
String id = phonyManager.getDeviceId();
if (id == null){
id = "not available";
}
int phoneType = phonyManager.getPhoneType();
switch(phoneType){
case TelephonyManager.PHONE_TYPE_NONE:
return "NONE: " + id;
case TelephonyManager.PHONE_TYPE_GSM:
return "GSM: IMEI=" + id;
case TelephonyManager.PHONE_TYPE_CDMA:
return "CDMA: MEID/ESN=" + id;
/*
* for API Level 11 or above
* case TelephonyManager.PHONE_TYPE_SIP:
* return "SIP";
*/
default:
return "UNKNOWN: ID=" + id;
}
}
}
_ xml _
<linearlayout Android:layout_height="fill_parent" Android:layout_width="fill_parent" Android:orientation="vertical" xmlns:Android="http://schemas.Android.com/apk/res/Android">
<textview Android:layout_height="wrap_content" Android:layout_width="fill_parent" Android:text="@string/hello">
<textview Android:id="@+id/deviceid" Android:layout_height="wrap_content" Android:layout_width="fill_parent">
</textview></textview></linearlayout>
許可が必要 マニフェストファイルの/ READ_PHONE_STATE。
このTelephonyManager TELEPHONY_SERVICE関数を使用して 固有のデバイスID を取得できます。権限が必要です:READ_PHONE_STATE
<uses-permission Android:name="Android.permission.READ_PHONE_STATE" />
例:GSMの場合はIMEIおよびCDMAの場合はMEIDまたはESN電話。
/**
* Gets the device unique id called IMEI. Sometimes, this returns 00000000000000000 for the
* rooted devices.
**/
public static String getDeviceImei(Context ctx) {
TelephonyManager telephonyManager = (TelephonyManager) ctx.getSystemService(Context.TELEPHONY_SERVICE);
return telephonyManager.getDeviceId();
}
nullを返す if デバイスIDが利用できない .
メソッドgetDeviceId()
は非推奨です。このgetImei(int)
のための新しい方法があります
以下のコードを使用するとIMEI番号がわかります。
TelephonyManager telephonyManager = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE);
System.out.println("IMEI::" + telephonyManager.getDeviceId());
すべてのAndroidバージョンの処理許可と比較可能性チェックを使用してDeviceId(IMEI)を取得するためのKotlinコード:
val telephonyManager = getSystemService(Context.TELEPHONY_SERVICE) as TelephonyManager
if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_PHONE_STATE)
== PackageManager.PERMISSION_GRANTED) {
// Permission is granted
val imei : String? = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) telephonyManager.imei
// older OS versions
else telephonyManager.deviceId
imei?.let {
Log.i("Log", "DeviceId=$it" )
}
} else { // Permission is not granted
}
また、AndroidManifest.xmlにこの権限を追加してください。
<uses-permission Android:name="Android.permission.READ_PHONE_STATE"/> <!-- IMEI-->
aPIレベル11以上の場合
case TelephonyManager.PHONE_TYPE_SIP:
return "SIP";
TelephonyManager tm= (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
textDeviceID.setText(getDeviceID(tm));
Kotlinのバージョンを探している人のために、あなたはこのようなものを使うことができます。
private fun telephonyService() {
val telephonyManager = getSystemService(TELEPHONY_SERVICE) as TelephonyManager
val imei = if (Android.os.Build.VERSION.SDK_INT >= 26) {
Timber.i("Phone >= 26 IMEI")
telephonyManager.imei
} else {
Timber.i("Phone IMEI < 26")
telephonyManager.deviceId
}
Timber.i("Phone IMEI $imei")
}
注: checkSelfPermission または使用する方法にかかわらず、上記のtelephonyService()
をパーミッションチェックでラップする必要があります。
この許可をマニフェストファイルにも追加します。
<uses-permission Android:name="Android.permission.READ_PHONE_STATE"/>
これを試してください(常に最初のIMEIを入手する必要があります)
TelephonyManager mTelephony = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE);
if (ActivityCompat.checkSelfPermission(LoginActivity.this,Manifest.permission.READ_PHONE_STATE)!= PackageManager.PERMISSION_GRANTED) {
return;
}
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
if (mTelephony.getPhoneCount() == 2) {
IME = mTelephony.getImei(0);
}else{
IME = mTelephony.getImei();
}
}else{
if (mTelephony.getPhoneCount() == 2) {
IME = mTelephony.getDeviceId(0);
} else {
IME = mTelephony.getDeviceId();
}
}
} else {
IME = mTelephony.getDeviceId();
}