在游戏上线之后可能会遇到这样的问题,有人用模拟器恶意刷金币或者注册啊等问题,这个时候我们就需要把那些用模拟器登录玩家的某些功能屏蔽掉或者直接不让其登录,这个因人而异了。下面就说一下如何鉴别真机和模拟器,网上的方法也有很多,什么压力传感器温度传感器啊光传感器等,然而我这边经过研究之后,只有一个光传感器还算靠谱,鉴别成功率最好了。
下面直接上代码吧,不比比了。
java代码:
/**
* 判断是否存在光传感器来判断是否为模拟器
* 部分真机也不存在温度和压力传感器。其余传感器模拟器也存在。
* @return true 为模拟器
*/
public static int getmmethod(){
boolean isMmethod = true;
try {
Class<?> mclass = Class.forName("android.os.SystemProperties");
Object invoker = mclass.newInstance();
Method mmethod = mclass.getMethod("get", new Class[] { String.class,String.class });
Object result = mmethod.invoke(invoker, new Object[] {"gsm.version.baseband", "0000" });
Log.i("基带版本:", (String) result);
if ((String) result == "0000"){
isMmethod = false;
}
} catch (Exception e) {
}
if (!isMmethod){
//判断是否存在光传感器来判断是否为模拟器true 为模拟器
SensorManager sensorManager = (SensorManager) instance.getSystemService(SENSOR_SERVICE);
Sensor sensor8 = sensorManager.getDefaultSensor(Sensor.TYPE_LIGHT); //光
if (null == sensor8) {//sensor8为空的话则是模拟器
isMmethod = false;
if(isRootSystem())
{
isMmethod = false;
}
else
{
isMmethod = true;
}
}
else
{
isMmethod = true;
}
}
if(isMmethod)
{
return 0;
}
return 1;
}
public static boolean isRootSystem() {
if(isRootSystem1()||isRootSystem2()){
//TODO 可加其他判断 如是否装了权限管理的apk,大多数root 权限 申请需要app配合,也有不需要的,这个需要改su源码。因为管理su权限的app太多,无法列举所有的app,特别是国外的,暂时不做判断是否有root权限管理app
//多数只要su可执行就是root成功了,但是成功后用户如果删掉了权限管理的app,就会造成第三方app无法申请root权限,此时是用户删root权限管理app造成的。
//市场上常用的的权限管理app的包名 com.qihoo.permmgr com.noshufou.android.su eu.chainfire.supersu com.kingroot.kinguser com.kingouser.com com.koushikdutta.superuser
//com.dianxinos.superuser com.lbe.security.shuame com.geohot.towelroot 。。。。。。
return true;
}else{
return false;
}
}
private static boolean isRootSystem1() {
File f = null;
final String kSuSearchPaths[] = { "/system/bin/", "/system/xbin/",
"/system/sbin/", "/sbin/", "/vendor/bin/" };
try {
for (int i = 0; i < kSuSearchPaths.length; i++) {