CocosCreator获取设备ID唯一标识符

获取设备信息等操作, 要先到java层去.

在这个文件里面添加代码,用于获取需要的设备信息:
路径:“bulid\jsb-default\frameworks\cocos2d-x\cocos\platform\android\java\src\org\cocos2dx\lib\Cocos2dxActivity.java”

在这个文件里面获取权限:
路径:“bulid\jsb-default\frameworks\runtime-src\proj.android-studio\app\AndroidManifest.xml”
注:没有对应权限,在java层里面的操作都会获得null值,或者直接造成程序崩溃闪退.

在Android中,有以下几种方法获取这样的ID:

1. The IMEI: 仅仅只对Android手机有效:

	//在Cocos2dxActivity.java文件的protected void onCreate(final Bundle savedInstanceState)函数里面添加代码:
	//先添加头文件
	import android.telephony.TelephonyManager;
	//获取IMEI
	TelephonyManager TelephonyMgr = (TelephonyManager)getSystemService(TELEPHONY_SERVICE); 
	String szImei = TelephonyMgr.getDeviceId(); 

采用此种方法,需要在AndroidManifest.xml中加入一个许可:android.permission.READ_PHONE_STATE,并且用户应当允许安装此应用。作为手机来讲,IMEI是唯一的,它应该类似于 359881030314356(除非你有一个没有量产的手机(水货)它可能有无效的IMEI,如:0000000000000).
备注:貌似android系统10.0以上,就算获取了这个权限, 也无法获取到IMEI,调用getDeviceId()程序会直接闪退,所以不推荐这个.

2. Pseudo-Unique ID, 这个在任何Android手机中都有效

	//在Cocos2dxActivity.java文件的protected void onCreate(final Bundle savedInstanceState)函数里面添加代码:
	//先添加头文件
	import android.os.Build;
	//获取Unique ID
	String m_szDevIDShort = "35" + //we make this look like a valid IMEI 
	Build.BOARD.length()%10 + 
	Build.BRAND.length()%10 + 
	Build.CPU_ABI.length()%10 + 
	Build.DEVICE.length()%10 + 
	Build.DISPLAY.length()%10 + 
	Build.HOST.length()%10 + 
	Build.ID.length()%10 + 
	Build.MANUFACTURER.length()%10 + 
	Build.MODEL.length()%10 + 
	Build.PRODUCT.length()%10 + 
	Build.TAGS.length()%10 + 
	Build.TYPE.length()%10 + 
	Build.USER.length()%10 ; //13 digits

采用此种方法,不需要额外添加权限许可.这是通过取出ROM版本、制造商、CPU型号、以及其他硬件信息来实现获取的。这样计算出来的ID不是唯一的(因为如果两个手机应用了同样的硬件以及Rom 镜像)。但应当明白的是,出现类似情况的概率基本可以忽略.

3. The Android ID

	//在Cocos2dxActivity.java文件的protected void onCreate(final Bundle savedInstanceState)函数里面添加代码:
	//先添加头文件
	import android.provider.Settings.Secure;
	//获取Android ID
	String m_szAndroidID = Secure.getString(getContentResolver(), Secure.ANDROID_ID);

Returns: 9774d56d682e549c . 无需任何许可。通常被认为不可信,因为它有时为null。开发文档中说明了:这个ID会改变如果进行了出厂设置。并且,如果某个Andorid手机被Root过的话,这个ID也可以被任意改变。

4. The WLAN MAC Address string

	//在Cocos2dxActivity.java文件的protected void onCreate(final Bundle savedInstanceState)函数里面添加代码:
	//先添加头文件
	import android.net.wifi.WifiManager;
	//获取WLAN MAC ID
	WifiManager wm = (WifiManager)getSystemService(Context.WIFI_SERVICE); 
	String m_szWLANMAC = wm.getConnectionInfo().getMacAddress();

是另一个唯一ID。但是你需要在AndroidManifest.xml中加入一个许可:android.permission.ACCESS_WIFI_STATE 权限,否则这个地址会为null。
Returns: 00:11:22:33:44:55 (这不是一个真实的地址。而且这个地址能轻易地被伪造。).WLan不必打开,就可读取些值。

5. The BT MAC Address string

	//在Cocos2dxActivity.java文件的protected void onCreate(final Bundle savedInstanceState)函数里面添加代码:
	//先添加头文件
	import android.bluetooth.BluetoothAdapter;
	//获取BT MAC ID
	BluetoothAdapter m_BluetoothAdapter = null; // Local Bluetooth adapter      
	m_BluetoothAdapter = BluetoothAdapter.getDefaultAdapter();      
	String m_szBTMAC = m_BluetoothAdapter.getAddress();

只在有蓝牙的设备上运行。并且需要在AndroidManifest.xml中加入一个许可:android.permission.BLUETOOTH 权限.
Returns: 43:25:78:50:93:38 . 蓝牙没有必要打开,也能读取。

6.Combined Device ID(综合唯一标识符)
综上所述,我们一共有五种方式取得设备的唯一标识。它们中的一些可能会返回null,或者由于硬件缺失、权限问题等获取失败。
但你总能获得至少一个能用。所以,最好的方法就是通过拼接,或者拼接后的计算出的MD5值来产生一个结果。

	//在Cocos2dxActivity.java文件的protected void onCreate(final Bundle savedInstanceState)函数里面添加代码:
	//在以下代码中使用的类有MessageDigest,NoSuchAlgorithmException,需要添加这两个头文件
	import java.security.MessageDigest;
	import java.security.NoSuchAlgorithmException;

	//获取综合ID
	String m_szLongID = m_szImei + m_szDevIDShort 
   		 + m_szAndroidID+ m_szWLANMAC + m_szBTMAC;  
   	//因为android10以上获取m_szlmei值会出问题,所以最好把这个值去掉.

	// compute md5     
 	MessageDigest m = null;   
	try {
 			m = MessageDigest.getInstance("MD5");
	 } 
	catch (NoSuchAlgorithmException e) {
 			e.printStackTrace();   
	}    
	m.update(m_szLongID.getBytes(),0,m_szLongID.length());   
	// get md5 bytes   
	byte p_md5Data[] = m.digest();   
	// create a hex string   
	String m_szUniqueID = new String();   
	for (int i=0;i<p_md5Data.length;i++) {   
     	int b =  (0xFF & p_md5Data[i]);    
		// if it is a single digit, make sure it have 0 in front (proper padding)    
   	 	if (b <= 0xF) 
        	m_szUniqueID+="0";    
		// add number to string    
    	m_szUniqueID+=Integer.toHexString(b); 
   }   
   // hex string to uppercase   
	m_szUniqueID = m_szUniqueID.toUpperCase();

通过以上算法,可产生32位的16进制数据:
9DDDF85AFF0A87974CE4541BD94D5F55

7.在cocoscreator的脚本代码中获取信息.

/在Cocos2dxActivity.java文件里,通过以上步骤, 我们在onCreate函数里面,最终获取到一个m_szUniqueID值.我们需要将这个值保存到一个静态变量里面.

静态变量声明:

private static String DeviceID = "";

然后在onCreate函数里将获取到的m_szUniqueID值赋值到这个静态变量:

this.DeviceID = m_szUniqueID;

最后再写一个静态成员函数, 以方便在cocoscreator的脚本代码里面调用这个函数.

public static String getMachineID(){
    return DeviceID;
}

最终,在cocoscreator的脚本代码里获取这个值:

var machinid = String(jsb.reflection.callStaticMethod("org/cocos2dx/lib/Cocos2dxActivity", 
            "getMachineID", "()Ljava/lang/String;"));

完成.

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值