From f1d84fa6d0915a5ab7dc70df4e682991b6f6259b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=83=B3=E8=A6=81=E6=88=90=E4=B8=BARapStar=E5=90=97?= =?UTF-8?q?=EF=BC=9F?= Date: Fri, 18 Sep 2020 17:25:21 +0800 Subject: [PATCH] =?UTF-8?q?feat=EF=BC=9A=E8=BF=98=E6=98=AF=E6=B2=A1?= =?UTF-8?q?=E7=BB=95=E8=BF=87Android=2010=E7=9A=84XSharedPreferences?= =?UTF-8?q?=E5=9D=91=EF=BC=8C=E5=8F=AA=E8=83=BD=E5=9C=A8InitZygote?= =?UTF-8?q?=E6=9C=9F=E9=97=B4=E8=8E=B7=E5=8F=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/src/main/assets/config | 2 +- .../com/lateautumn4lin/headwolf/Config.java | 6 -- .../lateautumn4lin/headwolf/MainActivity.java | 53 ++++++++++++++- .../headwolf/entry/BaseEntry.java | 13 +++- .../headwolf/entry/RealEntry.java | 5 +- .../headwolf/initialization/Register.java | 68 +++++++++++-------- .../utils/ClassesReaderAssistant.java | 1 - .../headwolf/utils/PreferenceAssistant.java | 45 ++++++++++++ app/src/main/res/layout/activity_main.xml | 27 +++++++- app/src/main/res/values/strings.xml | 1 + 10 files changed, 176 insertions(+), 45 deletions(-) create mode 100644 app/src/main/java/com/lateautumn4lin/headwolf/utils/PreferenceAssistant.java diff --git a/app/src/main/assets/config b/app/src/main/assets/config index 141b469..174577e 100644 --- a/app/src/main/assets/config +++ b/app/src/main/assets/config @@ -8,4 +8,4 @@ group_kuaishou.name=com.smile.gifmaker group_kuaishou.home=com.yxcorp.gifshow.HomeActivity //ԱֱĿ group_taobao.name=com.taobao.live -group_taobao.home=com.taobao.live.home.activity.HomePage3Activity \ No newline at end of file +group_taobao.home=com.taobao.live.home.activity.HomePage2Activity,com.taobao.live.home.activity.HomePage3Activity \ No newline at end of file diff --git a/app/src/main/java/com/lateautumn4lin/headwolf/Config.java b/app/src/main/java/com/lateautumn4lin/headwolf/Config.java index d4505ea..26c769e 100644 --- a/app/src/main/java/com/lateautumn4lin/headwolf/Config.java +++ b/app/src/main/java/com/lateautumn4lin/headwolf/Config.java @@ -10,18 +10,12 @@ package com.lateautumn4lin.headwolf; import com.google.gson.Gson; import com.google.gson.JsonObject; import com.lateautumn4lin.headwolf.commons.Logger; -import com.lateautumn4lin.headwolf.handlers.KuaishouHandler; import com.lateautumn4lin.headwolf.utils.PropertiesAssistant; -import com.virjar.sekiro.api.SekiroRequestHandler; - import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.UUID; -import static java.util.Arrays.asList; - - /** * The type Config. */ diff --git a/app/src/main/java/com/lateautumn4lin/headwolf/MainActivity.java b/app/src/main/java/com/lateautumn4lin/headwolf/MainActivity.java index adcb431..0e31dd0 100644 --- a/app/src/main/java/com/lateautumn4lin/headwolf/MainActivity.java +++ b/app/src/main/java/com/lateautumn4lin/headwolf/MainActivity.java @@ -1,7 +1,9 @@ package com.lateautumn4lin.headwolf; +import androidx.annotation.RequiresApi; import androidx.appcompat.app.AppCompatActivity; +import android.annotation.SuppressLint; import android.app.ActivityManager; import android.content.ComponentName; import android.content.Context; @@ -10,8 +12,12 @@ import android.content.SharedPreferences; import android.content.pm.ApplicationInfo; import android.content.pm.PackageInfo; import android.content.pm.PackageManager; +import android.os.Build; import android.os.Bundle; +import android.text.Editable; +import android.text.TextWatcher; import android.widget.CompoundButton; +import android.widget.EditText; import android.widget.Switch; import android.widget.Toast; @@ -20,6 +26,7 @@ import com.google.gson.JsonObject; import com.lateautumn4lin.headwolf.commons.Logger; import com.lateautumn4lin.headwolf.utils.PropertiesAssistant; +import java.io.File; import java.util.HashMap; import java.util.List; @@ -34,13 +41,16 @@ public class MainActivity extends AppCompatActivity { HashMap HookPackageInfo = new HashMap(); private SharedPreferences sharedPreferences; + @RequiresApi(api = Build.VERSION_CODES.N) @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); - sharedPreferences = getSharedPreferences("HeadWolf", MODE_PRIVATE); + sharedPreferences = getNormalSharedPreferences(); + setWorldReadable(); Logger.logi("StartUp MainActivity"); Switch btnUpdate = findViewById(R.id.btn_update); + EditText contentChange = findViewById(R.id.content_change); Boolean function_1_enable = sharedPreferences.getBoolean("function_1", false); btnUpdate.setChecked(function_1_enable); btnUpdate.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() { @@ -48,20 +58,57 @@ public class MainActivity extends AppCompatActivity { public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { SharedPreferences.Editor edt = sharedPreferences.edit(); if (isChecked) { - edt.putBoolean("function_1", true); + edt.putBoolean("function_1", true).apply(); + setWorldReadable(); Toast.makeText(MainActivity.this, "开启", Toast.LENGTH_SHORT).show(); } else { - edt.putBoolean("function_1", false); + edt.putBoolean("function_1", false).apply(); + setWorldReadable(); Toast.makeText(MainActivity.this, "关闭", Toast.LENGTH_SHORT).show(); } edt.apply(); } }); + contentChange.addTextChangedListener(new TextWatcher() { + @Override + public void onTextChanged(CharSequence s, int start, int before, int count) { + SharedPreferences.Editor edt = sharedPreferences.edit(); + edt.putString("function_name", contentChange.getText().toString()).apply(); + setWorldReadable(); + } + + @Override + public void beforeTextChanged(CharSequence s, int start, int count, int after) { + } + + @Override + public void afterTextChanged(Editable s) { + } + }); if (function_1_enable) { GetPackages(); } } + + @SuppressLint({"SetWorldReadable", "SetWorldWritable"}) + @RequiresApi(api = Build.VERSION_CODES.N) + private void setWorldReadable() { + try { + File f = new File("/data/user_de/0/com.lateautumn4lin.headwolf/shared_prefs/HeadWolf.xml"); + f.setReadable(true, false); + f.setExecutable(true, false); + f.setWritable(true, false); + } catch (Exception e) { + Logger.loge(e.toString()); + } + } + + @RequiresApi(api = Build.VERSION_CODES.N) + public SharedPreferences getNormalSharedPreferences() { + return this.createDeviceProtectedStorageContext().getSharedPreferences("HeadWolf", MODE_PRIVATE); + } + /** * Get packages. */ diff --git a/app/src/main/java/com/lateautumn4lin/headwolf/entry/BaseEntry.java b/app/src/main/java/com/lateautumn4lin/headwolf/entry/BaseEntry.java index 38ddcdc..ebe5fad 100644 --- a/app/src/main/java/com/lateautumn4lin/headwolf/entry/BaseEntry.java +++ b/app/src/main/java/com/lateautumn4lin/headwolf/entry/BaseEntry.java @@ -13,6 +13,7 @@ import android.content.pm.PackageManager; import com.lateautumn4lin.headwolf.MyApplication; import com.lateautumn4lin.headwolf.commons.Logger; +import com.lateautumn4lin.headwolf.utils.PreferenceAssistant; import java.io.BufferedReader; import java.io.File; @@ -30,7 +31,9 @@ import java.util.zip.ZipFile; import dalvik.system.PathClassLoader; import de.robv.android.xposed.IXposedHookLoadPackage; +import de.robv.android.xposed.IXposedHookZygoteInit; import de.robv.android.xposed.XC_MethodHook; +import de.robv.android.xposed.XSharedPreferences; import de.robv.android.xposed.XposedBridge; import de.robv.android.xposed.XposedHelpers; import de.robv.android.xposed.callbacks.XC_LoadPackage; @@ -38,7 +41,7 @@ import de.robv.android.xposed.callbacks.XC_LoadPackage; /** * The type Base entry. 第一层Hook入口 */ -public class BaseEntry implements IXposedHookLoadPackage { +public class BaseEntry implements IXposedHookLoadPackage, IXposedHookZygoteInit { private static String modulePackage = MyApplication.class.getPackage().getName(); private static List hookPackages = null; private final String handleHookClass = RealEntry.class.getName(); @@ -49,9 +52,17 @@ public class BaseEntry implements IXposedHookLoadPackage { */ public static ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(50, 50, 1, TimeUnit.MINUTES, blockingQueue); + @Override + public void initZygote(IXposedHookZygoteInit.StartupParam startupParam) { + PreferenceAssistant.initPref(); + } + @Override public void handleLoadPackage(final XC_LoadPackage.LoadPackageParam loadPackageParam) throws Throwable { try { +// 获取全局有Zygote初始化的变量 + XSharedPreferences x = PreferenceAssistant.getPref(loadPackageParam.packageName); + String t = x.getAll().toString(); // 根据配置文件设置需要hook的包名 try { // 获取context对象 diff --git a/app/src/main/java/com/lateautumn4lin/headwolf/entry/RealEntry.java b/app/src/main/java/com/lateautumn4lin/headwolf/entry/RealEntry.java index 0a52a44..a89feda 100644 --- a/app/src/main/java/com/lateautumn4lin/headwolf/entry/RealEntry.java +++ b/app/src/main/java/com/lateautumn4lin/headwolf/entry/RealEntry.java @@ -25,11 +25,13 @@ import de.robv.android.xposed.callbacks.XC_LoadPackage; * The type Real entry. */ public class RealEntry implements IXposedHookLoadPackage { + private boolean RegisterState = false; + @Override public void handleLoadPackage(final XC_LoadPackage.LoadPackageParam loadPackageParam) throws Throwable { try { // 测试 - Logger.logi(String.format("Begin Real Hook Logic About:%s", loadPackageParam.packageName)); + Logger.logi(String.format("Begin Real Hook Logic About:%s %s", loadPackageParam.packageName, RegisterState)); // step1:获取context Context context = (Context) XposedHelpers.callMethod( XposedHelpers.callStaticMethod( @@ -46,6 +48,7 @@ public class RealEntry implements IXposedHookLoadPackage { // step2:由注册类进行handler注册 if (Register.GroupRegister(loadPackageParam, associate_handlers)) { Logger.logi(String.format("Real Hook Logic About:%s Success", loadPackageParam.packageName)); + RegisterState = true; } else { Logger.logi(String.format("Real Hook Logic About:%s Error", loadPackageParam.packageName)); } diff --git a/app/src/main/java/com/lateautumn4lin/headwolf/initialization/Register.java b/app/src/main/java/com/lateautumn4lin/headwolf/initialization/Register.java index 730a89c..ca42fda 100644 --- a/app/src/main/java/com/lateautumn4lin/headwolf/initialization/Register.java +++ b/app/src/main/java/com/lateautumn4lin/headwolf/initialization/Register.java @@ -11,12 +11,13 @@ import android.os.Bundle; import com.lateautumn4lin.headwolf.Config; import com.lateautumn4lin.headwolf.commons.Logger; -import com.lateautumn4lin.headwolf.entry.RealEntry; -import com.lateautumn4lin.headwolf.handlers.KuaishouHandler; import com.virjar.sekiro.api.SekiroClient; import com.virjar.sekiro.api.SekiroRequestHandler; -import java.lang.reflect.Constructor; +import org.apache.commons.lang3.StringUtils; + +import java.util.ArrayList; +import java.util.Arrays; import java.util.HashMap; import java.util.Map; @@ -37,36 +38,45 @@ public class Register { */ public static Boolean GroupRegister(final XC_LoadPackage.LoadPackageParam loadPackageParam, final HashMap associate_handlers) { try { - Class HomeClass = loadPackageParam.classLoader.loadClass(Config.GetHome(loadPackageParam.packageName)); - final String group_name = Config.GetGroup(loadPackageParam.packageName); - XposedHelpers.findAndHookMethod(HomeClass, "onCreate", Bundle.class, new XC_MethodHook() { - @Override - protected void afterHookedMethod(MethodHookParam param) throws Throwable { - Logger.logi(String.format("Group Register:%s Begin ClientId:%s", group_name, Config.getClientId())); - final SekiroClient sekiroClient = SekiroClient.start( - Config.getRemoteServer(), - Config.getClientId(), - group_name - ); - try { - for (Map.Entry entry : associate_handlers.entrySet()) { - try { - SekiroRequestHandler handler = entry.getValue(); - sekiroClient.registerHandler(entry.getKey(), handler); - Logger.logi(String.format("Group Register Group:%s Action:%s Handler:%s Success ClientId:%s", group_name, entry.getKey(), handler, Config.getClientId())); - } catch (Exception e) { - Logger.loge(e.toString()); + ArrayList home_activities = new ArrayList(); + String home_activity = Config.GetHome(loadPackageParam.packageName); + if (home_activity.contains(",")) { + String[] t_home_activities = home_activity.split(","); + home_activities.addAll(Arrays.asList(t_home_activities)); + } else { + home_activities.add(home_activity); + } + for (String home : home_activities) { + Class HomeClass = loadPackageParam.classLoader.loadClass(StringUtils.strip(home, "[]")); + final String group_name = Config.GetGroup(loadPackageParam.packageName); + XposedHelpers.findAndHookMethod(HomeClass, "onCreate", Bundle.class, new XC_MethodHook() { + @Override + protected void afterHookedMethod(MethodHookParam param) throws Throwable { + Logger.logi(String.format("Group Register:%s Begin ClientId:%s", group_name, Config.getClientId())); + final SekiroClient sekiroClient = SekiroClient.start( + Config.getRemoteServer(), + Config.getClientId(), + group_name + ); + try { + for (Map.Entry entry : associate_handlers.entrySet()) { + try { + SekiroRequestHandler handler = entry.getValue(); + sekiroClient.registerHandler(entry.getKey(), handler); + Logger.logi(String.format("Group Register Group:%s Action:%s Handler:%s Success ClientId:%s", group_name, entry.getKey(), handler, Config.getClientId())); + } catch (Exception e) { + Logger.loge(e.toString()); + } } - + } catch (Exception e) { + Logger.loge(e.toString()); } - } catch (Exception e) { - Logger.loge(e.toString()); + super.afterHookedMethod(param); } - super.afterHookedMethod(param); - } - }); + }); + } } catch (Exception e) { - Logger.loge(String.format("Group Register Error ClientId:%s", Config.getClientId())); + Logger.loge(String.format("Group Register Error ClientId:%s %s", Config.getClientId(), e.toString())); return false; } return true; diff --git a/app/src/main/java/com/lateautumn4lin/headwolf/utils/ClassesReaderAssistant.java b/app/src/main/java/com/lateautumn4lin/headwolf/utils/ClassesReaderAssistant.java index eac37ad..b3c53f1 100644 --- a/app/src/main/java/com/lateautumn4lin/headwolf/utils/ClassesReaderAssistant.java +++ b/app/src/main/java/com/lateautumn4lin/headwolf/utils/ClassesReaderAssistant.java @@ -14,7 +14,6 @@ import android.content.Context; import com.lateautumn4lin.headwolf.Config; import com.lateautumn4lin.headwolf.commons.Logger; import com.lateautumn4lin.headwolf.entry.RealEntry; -import com.lateautumn4lin.headwolf.handlers.KuaishouHandler; import com.virjar.sekiro.api.SekiroRequestHandler; import java.io.File; diff --git a/app/src/main/java/com/lateautumn4lin/headwolf/utils/PreferenceAssistant.java b/app/src/main/java/com/lateautumn4lin/headwolf/utils/PreferenceAssistant.java new file mode 100644 index 0000000..18d00db --- /dev/null +++ b/app/src/main/java/com/lateautumn4lin/headwolf/utils/PreferenceAssistant.java @@ -0,0 +1,45 @@ +package com.lateautumn4lin.headwolf.utils; +/* + * PreferenceAssistant + * + * @author lateautumn4lin + * @github https://github.com/lateautumn4lin + * @date 2020/9/17 15:24 + */ + + +import java.io.File; + +import de.robv.android.xposed.XSharedPreferences; + +/** + * The type Preference assistant. + */ +public class PreferenceAssistant { + private static XSharedPreferences xSharedPreferences = null; + + /** + * Init pref. + */ + public static void initPref() { + xSharedPreferences = new XSharedPreferences(new File("/data/user_de/0/com.lateautumn4lin.headwolf/shared_prefs/HeadWolf.xml")); + xSharedPreferences.makeWorldReadable(); + } + + /** + * Gets pref. + * + * @return the pref + */ + public static XSharedPreferences getPref(String name) { + return xSharedPreferences; + } + + /** + * Reload pref. + */ + public static void reloadPref() { + xSharedPreferences.reload(); + xSharedPreferences.makeWorldReadable(); + } +} diff --git a/app/src/main/res/layout/activity_main.xml b/app/src/main/res/layout/activity_main.xml index 34d7481..c539751 100644 --- a/app/src/main/res/layout/activity_main.xml +++ b/app/src/main/res/layout/activity_main.xml @@ -11,17 +11,38 @@ android:layout_height="wrap_content" android:text="来Github提Issue、提Pr!" app:layout_constraintBottom_toBottomOf="parent" + app:layout_constraintHorizontal_bias="0.498" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" - app:layout_constraintTop_toTopOf="parent" /> + app:layout_constraintTop_toTopOf="parent" + app:layout_constraintVertical_bias="0.661" /> + + \ No newline at end of file diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index c3b825f..fc1e0ce 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -1,4 +1,5 @@ Headwolf框架 自动注册hook app的handlers + 修改内容