mirror of
https://github.com/whitechi73/OpenShamrock.git
synced 2024-08-14 13:12:17 +08:00
Shamrock
: fix #105
This commit is contained in:
parent
80a4a208b9
commit
ecb3cea5a5
@ -192,7 +192,11 @@ fun LabFragment() {
|
|||||||
descColor = it,
|
descColor = it,
|
||||||
isSwitch = AppRuntime.state.supportVoice.value
|
isSwitch = AppRuntime.state.supportVoice.value
|
||||||
) {
|
) {
|
||||||
|
if(AppRuntime.state.supportVoice.value) {
|
||||||
|
scope.toast(ctx, "关闭请手动删除文件。")
|
||||||
|
} else {
|
||||||
scope.toast(ctx, "请按照Github提示手动操作。")
|
scope.toast(ctx, "请按照Github提示手动操作。")
|
||||||
|
}
|
||||||
return@Function false
|
return@Function false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,80 +1,6 @@
|
|||||||
#include "anti_detection.h"
|
#include "anti_detection.h"
|
||||||
|
|
||||||
int (*backup_system_property_get)(const char *name, char *value);
|
|
||||||
FILE* (*backup_fopen)(const char *filename, const char *mode);
|
|
||||||
|
|
||||||
int fake_system_property_get(const char *name, char *value) {
|
|
||||||
for (auto &prop: qemu_detect_props) {
|
|
||||||
if (strstr(name, prop.c_str())) {
|
|
||||||
LOGI("[Shamrock] bypass qemu detection");
|
|
||||||
value[0] = 0;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (strstr(name, "ro.debuggable")
|
|
||||||
|| strstr(name, "ro.kernel.qemu.gles")
|
|
||||||
|| strstr(name, "debug.atrace.tags.enableflags")) {
|
|
||||||
strcpy(value, "0");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (strstr(name, "ro.product.cpu.abilist")) {
|
|
||||||
int len = backup_system_property_get(name, value);
|
|
||||||
if (len > 0) {
|
|
||||||
if (strstr(value, "x86")) {
|
|
||||||
strcpy(value, "arm64-v8a,armeabi-v7a,armeabi");
|
|
||||||
return 29;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return len;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (strstr(name, "ro.hardware")) {
|
|
||||||
int len = backup_system_property_get(name, value);
|
|
||||||
if (len > 0) {
|
|
||||||
if (strstr(value, "generic")
|
|
||||||
|| strstr(value, "unknown")
|
|
||||||
|| strstr(value, "emulator")
|
|
||||||
|| strstr(value, "vbox")
|
|
||||||
|| strstr(value, "genymotion")
|
|
||||||
|| strstr(value, "goldfish")) {
|
|
||||||
strcpy(value, "qcom");
|
|
||||||
return 4;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return len;
|
|
||||||
}
|
|
||||||
|
|
||||||
//LOGI("[Shamrock] fake_system_property_get(%s)", name);
|
|
||||||
return backup_system_property_get(name, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
FILE* fake_fopen(const char *filename, const char *mode) {
|
|
||||||
if (strstr(filename, "qemu_pipe")) {
|
|
||||||
LOGI("[Shamrock] bypass qemu detection");
|
|
||||||
return nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (strstr(filename, "libhoudini.so")) {
|
|
||||||
LOGI("[Shamrock] bypass emu detection");
|
|
||||||
return nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
return backup_fopen(filename, mode);
|
|
||||||
}
|
|
||||||
|
|
||||||
void on_library_loaded(const char *name, void *handle) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C" [[gnu::visibility("default")]] [[gnu::used]]
|
|
||||||
NativeOnModuleLoaded native_init(const NativeAPIEntries *entries) {
|
|
||||||
hook_function = entries->hook_func;
|
|
||||||
LOGI("[Shamrock] LSPosed NativeModule Init: %p", hook_function);
|
|
||||||
|
|
||||||
hook_function((void*) __system_property_get, (void *)fake_system_property_get, (void **) &backup_system_property_get);
|
|
||||||
hook_function((void*) fopen, (void*) fake_fopen, (void**) &backup_fopen);
|
|
||||||
|
|
||||||
return on_library_loaded;
|
|
||||||
}
|
|
||||||
|
@ -7,12 +7,18 @@
|
|||||||
#include "lsposed.h"
|
#include "lsposed.h"
|
||||||
#include "jnihelper.h"
|
#include "jnihelper.h"
|
||||||
|
|
||||||
static HookFunType hook_function = nullptr;
|
|
||||||
|
|
||||||
static std::vector<std::string> qemu_detect_props = {
|
static std::vector<std::string> qemu_detect_props = {
|
||||||
"init.svc.qemu-props", "qemu.hw.mainkeys", "qemu.sf.fake_camera", "ro.kernel.android.qemud",
|
"init.svc.qemu-props", "qemu.hw.mainkeys", "qemu.sf.fake_camera", "ro.kernel.android.qemud",
|
||||||
"qemu.sf.lcd_density", "init.svc.qemud", "ro.kernel.qemu",
|
"qemu.sf.lcd_density", "init.svc.qemud", "ro.kernel.qemu",
|
||||||
"libc.debug.malloc"
|
"libc.debug.malloc"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static int (*backup_system_property_get)(const char *name, char *value);
|
||||||
|
static FILE* (*backup_fopen)(const char *filename, const char *mode);
|
||||||
|
|
||||||
|
//int fake_system_property_get(const char *name, char *value);
|
||||||
|
//FILE* fake_fopen(const char *filename, const char *mode);
|
||||||
|
|
||||||
|
//void on_library_loaded(const char *name, void *handle);
|
||||||
|
|
||||||
#endif //SHAMROCK_ANTI_DETECTION_H
|
#endif //SHAMROCK_ANTI_DETECTION_H
|
||||||
|
@ -3,17 +3,20 @@
|
|||||||
#include "helper/lsposed.h"
|
#include "helper/lsposed.h"
|
||||||
#include "jnihelper.h"
|
#include "jnihelper.h"
|
||||||
|
|
||||||
|
static JavaVM *global_jvm = nullptr;
|
||||||
|
static HookFunType hook_function = nullptr;
|
||||||
|
|
||||||
extern "C" [[gnu::visibility("default")]] [[gnu::used]]
|
extern "C" [[gnu::visibility("default")]] [[gnu::used]]
|
||||||
jint JNI_OnLoad(JavaVM *jvm, void*) {
|
jint JNI_OnLoad(JavaVM *jvm, void*) {
|
||||||
JNIHelper::initJavaVM(jvm);
|
global_jvm = jvm;
|
||||||
int attach = 0;
|
int attach = 0;
|
||||||
JNIEnv *env = JNIHelper::getJNIEnv(&attach);
|
JNIEnv *env = JNIHelper::getJNIEnv(jvm, &attach);
|
||||||
|
|
||||||
// do something
|
// do something
|
||||||
LOGI("[Shamrock] JNI_OnLoad NativeModule Init: %p", env);
|
LOGI("[Shamrock] JNI_OnLoad NativeModule Init: %p", env);
|
||||||
|
|
||||||
if (attach == 1) {
|
if (attach == 1) {
|
||||||
JNIHelper::delJNIEnv();
|
JNIHelper::delJNIEnv(jvm);
|
||||||
}
|
}
|
||||||
|
|
||||||
//hook_function((void *)env->functions->FindClass, (void *)fake_FindClass, (void **)&backup_FindClass);
|
//hook_function((void *)env->functions->FindClass, (void *)fake_FindClass, (void **)&backup_FindClass);
|
||||||
@ -23,11 +26,89 @@ jint JNI_OnLoad(JavaVM *jvm, void*) {
|
|||||||
extern "C"
|
extern "C"
|
||||||
JNIEXPORT jboolean JNICALL
|
JNIEXPORT jboolean JNICALL
|
||||||
Java_moe_fuqiuluo_shamrock_xposed_XposedEntry_00024Companion_injected(JNIEnv *env, jobject thiz) {
|
Java_moe_fuqiuluo_shamrock_xposed_XposedEntry_00024Companion_injected(JNIEnv *env, jobject thiz) {
|
||||||
|
LOGI("[Shamrock] injected: %p", hook_function);
|
||||||
return hook_function != nullptr;
|
return hook_function != nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C"
|
extern "C"
|
||||||
JNIEXPORT jboolean JNICALL
|
JNIEXPORT jboolean JNICALL
|
||||||
Java_moe_fuqiuluo_shamrock_xposed_XposedEntry_00024Companion_hasEnv(JNIEnv *env, jobject thiz) {
|
Java_moe_fuqiuluo_shamrock_xposed_XposedEntry_00024Companion_hasEnv(JNIEnv *env, jobject thiz) {
|
||||||
return JNIHelper::global_jvm != nullptr;
|
LOGI("[Shamrock] hasEnv: %p", global_jvm);
|
||||||
}
|
return global_jvm != nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
int fake_system_property_get(const char *name, char *value) {
|
||||||
|
for (auto &prop: qemu_detect_props) {
|
||||||
|
if (strstr(name, prop.c_str())) {
|
||||||
|
LOGI("[Shamrock] bypass qemu detection");
|
||||||
|
value[0] = 0;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strstr(name, "ro.debuggable")
|
||||||
|
|| strstr(name, "ro.kernel.qemu.gles")
|
||||||
|
|| strstr(name, "debug.atrace.tags.enableflags")) {
|
||||||
|
strcpy(value, "0");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strstr(name, "ro.product.cpu.abilist")) {
|
||||||
|
int len = backup_system_property_get(name, value);
|
||||||
|
if (len > 0) {
|
||||||
|
if (strstr(value, "x86")) {
|
||||||
|
strcpy(value, "arm64-v8a,armeabi-v7a,armeabi");
|
||||||
|
return 29;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strstr(name, "ro.hardware")) {
|
||||||
|
int len = backup_system_property_get(name, value);
|
||||||
|
if (len > 0) {
|
||||||
|
if (strstr(value, "generic")
|
||||||
|
|| strstr(value, "unknown")
|
||||||
|
|| strstr(value, "emulator")
|
||||||
|
|| strstr(value, "vbox")
|
||||||
|
|| strstr(value, "genymotion")
|
||||||
|
|| strstr(value, "goldfish")) {
|
||||||
|
strcpy(value, "qcom");
|
||||||
|
return 4;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
|
||||||
|
//LOGI("[Shamrock] fake_system_property_get(%s)", name);
|
||||||
|
return backup_system_property_get(name, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
FILE* fake_fopen(const char *filename, const char *mode) {
|
||||||
|
if (strstr(filename, "qemu_pipe")) {
|
||||||
|
LOGI("[Shamrock] bypass qemu detection");
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strstr(filename, "libhoudini.so")) {
|
||||||
|
LOGI("[Shamrock] bypass emu detection");
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
return backup_fopen(filename, mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
void on_library_loaded(const char *name, void *handle) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" [[gnu::visibility("default")]] [[gnu::used]]
|
||||||
|
NativeOnModuleLoaded native_init(const NativeAPIEntries *entries) {
|
||||||
|
hook_function = entries->hook_func;
|
||||||
|
LOGI("[Shamrock] LSPosed NativeModule Init: %p", hook_function);
|
||||||
|
|
||||||
|
hook_function((void*) __system_property_get, (void *)fake_system_property_get, (void **) &backup_system_property_get);
|
||||||
|
hook_function((void*) fopen, (void*) fake_fopen, (void**) &backup_fopen);
|
||||||
|
|
||||||
|
return on_library_loaded;
|
||||||
|
}
|
||||||
|
@ -1,19 +1,15 @@
|
|||||||
#include "jnihelper.h"
|
#include "jnihelper.h"
|
||||||
|
|
||||||
void JNIHelper::initJavaVM(JavaVM *jvm) {
|
JNIEnv *JNIHelper::getJNIEnv(JavaVM * jvm, int *attach) {
|
||||||
global_jvm = jvm;
|
if (jvm == NULL) return NULL;
|
||||||
}
|
|
||||||
|
|
||||||
JNIEnv *JNIHelper::getJNIEnv(int *attach) {
|
|
||||||
if (global_jvm == NULL) return NULL;
|
|
||||||
|
|
||||||
*attach = 0;
|
*attach = 0;
|
||||||
JNIEnv *jni_env = NULL;
|
JNIEnv *jni_env = NULL;
|
||||||
|
|
||||||
int status = global_jvm->GetEnv((void **)&jni_env, JNI_VERSION_1_6);
|
int status = jvm->GetEnv((void **)&jni_env, JNI_VERSION_1_6);
|
||||||
|
|
||||||
if (status == JNI_EDETACHED || jni_env == NULL) {
|
if (status == JNI_EDETACHED || jni_env == NULL) {
|
||||||
status = global_jvm->AttachCurrentThread(&jni_env, NULL);
|
status = jvm->AttachCurrentThread(&jni_env, NULL);
|
||||||
if (status < 0) {
|
if (status < 0) {
|
||||||
jni_env = NULL;
|
jni_env = NULL;
|
||||||
} else {
|
} else {
|
||||||
@ -23,8 +19,8 @@ JNIEnv *JNIHelper::getJNIEnv(int *attach) {
|
|||||||
return jni_env;
|
return jni_env;
|
||||||
}
|
}
|
||||||
|
|
||||||
jint JNIHelper::delJNIEnv() {
|
jint JNIHelper::delJNIEnv(JavaVM * jvm) {
|
||||||
if (global_jvm == nullptr) return 0;
|
if (jvm == nullptr) return 0;
|
||||||
return global_jvm->DetachCurrentThread();
|
return jvm->DetachCurrentThread();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,13 +5,9 @@
|
|||||||
#include "android/log.h"
|
#include "android/log.h"
|
||||||
|
|
||||||
namespace JNIHelper {
|
namespace JNIHelper {
|
||||||
static JavaVM *global_jvm = nullptr;
|
JNIEnv *getJNIEnv(JavaVM * jvm, int *attach);
|
||||||
|
|
||||||
void initJavaVM(JavaVM *jvm);
|
jint delJNIEnv(JavaVM * jvm);
|
||||||
|
|
||||||
JNIEnv *getJNIEnv(int *attach);
|
|
||||||
|
|
||||||
jint delJNIEnv();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -29,7 +29,12 @@ internal object NativeLoader {
|
|||||||
val applicationInfo = packageManager.getApplicationInfo("moe.fuqiuluo.shamrock.hided", 0)
|
val applicationInfo = packageManager.getApplicationInfo("moe.fuqiuluo.shamrock.hided", 0)
|
||||||
val file = File(applicationInfo.nativeLibraryDir)
|
val file = File(applicationInfo.nativeLibraryDir)
|
||||||
LogCenter.log("LoadLibrary(name = $name)")
|
LogCenter.log("LoadLibrary(name = $name)")
|
||||||
System.load(file.resolve("lib$name.so").absolutePath)
|
System.load(file.resolve("lib$name.so").also {
|
||||||
|
if (!it.exists()) {
|
||||||
|
LogCenter.log("LoadLibrary(name = $name) failed, file not exists.", level = Level.ERROR)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}.absolutePath)
|
||||||
} else {
|
} else {
|
||||||
val sourceFile = externalLibPath.resolve("lib$name.so")
|
val sourceFile = externalLibPath.resolve("lib$name.so")
|
||||||
val soFile = MobileQQ.getContext().filesDir.parentFile!!.resolve("txlib").resolve("lib$name.so")
|
val soFile = MobileQQ.getContext().filesDir.parentFile!!.resolve("txlib").resolve("lib$name.so")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user