安卓逆向环境检测--unidbg&unicorn

一、methodid检测

// 通过获取一个不存在的方法的methodid来判断当前是否在unidbg中,因为unidbg会模拟环境,所以一定会模拟一个jmethodid出来


UNEXPORT void AntiUnidbg::check_GetStaticMethodID(JNIEnv *env) {
    jmethodID id = getStaticMethodID(env, "com.yooha.antisdk.MainActivity", "getSig", "()Ljava/lang/String;");
    if (id != nullptr){
        // TODO 当前方法被模拟,说明存在于unidbg环境中
        LOGE("check_GetStaticMethodID -------------------> find unidbg");
    }
}

UNEXPORT jmethodID AntiUnidbg::getStaticMethodID(JNIEnv *env, const char *clsName, const char *methodName,
                                        const char *sig) {
    jclass cls = env->FindClass(clsName);
    if (env->ExceptionCheck()) {
        env->ExceptionDescribe();
        env->ExceptionClear();
        LOGE("getStaticMethodID FindClass %s Error", clsName);
        return nullptr;
    }

    jmethodID  method = env->GetStaticMethodID(cls, methodName, sig);
    if (env->ExceptionCheck()) {
        env->ExceptionDescribe(); //调试阶段打开此开关
        env->ExceptionClear();
        LOGE("getStaticMethodID  name:%s sig:%s Error", methodName, sig);
        return nullptr;
    }
    return method;
}

二、uname检测

UNEXPORT void AntiUnidbg::check_uname() {
    struct utsname sysinfo;

    if( uname( &sysinfo ) == -1 ) {
        LOGE("[%s %s %d] -> check_uname  error:%s", __FILE__, __FUNCTION__, __LINE__, strerror(errno));
        return;
    }

    if (Str::strstr(sysinfo.sysname, "Unidbg") != nullptr){
        // TODO Unidbg的uname系统调用表明了自己是Unidbg
        LOGE("check_uname -------------------> find unidbg");
    }

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值