添加取消定时任务的方法
This commit is contained in:
parent
203fccea87
commit
d8dd6e740a
|
@ -29,6 +29,7 @@ import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
import androidx.work.PeriodicWorkRequest;
|
import androidx.work.PeriodicWorkRequest;
|
||||||
import androidx.work.WorkManager;
|
import androidx.work.WorkManager;
|
||||||
|
|
||||||
import com.example.studyapp.autoJS.AutoJsUtil;
|
import com.example.studyapp.autoJS.AutoJsUtil;
|
||||||
import com.example.studyapp.device.ChangeDeviceInfoUtil;
|
import com.example.studyapp.device.ChangeDeviceInfoUtil;
|
||||||
|
|
||||||
|
@ -158,24 +159,7 @@ public class MainActivity extends AppCompatActivity {
|
||||||
LogFileUtil.logAndWrite(Log.INFO, "MainActivity", "onCreate: Setting up UI components", null);
|
LogFileUtil.logAndWrite(Log.INFO, "MainActivity", "onCreate: Setting up UI components", null);
|
||||||
Button runScriptButton = findViewById(R.id.run_script_button);
|
Button runScriptButton = findViewById(R.id.run_script_button);
|
||||||
if (runScriptButton != null) {
|
if (runScriptButton != null) {
|
||||||
// runScriptButton.setOnClickListener(v -> AutoJsUtil.runAutojsScript(this));
|
runScriptButton.setOnClickListener(v -> AutoJsUtil.runAutojsScript(this));
|
||||||
runScriptButton.setOnClickListener(v -> {
|
|
||||||
initializeExecutorService();
|
|
||||||
executorService.submit(() -> {
|
|
||||||
File files1Dir = new File(getExternalFilesDir(null).getAbsolutePath(),"FyZqWrStUvOpKlMn_wsj.reader_sp.zip");
|
|
||||||
File destFile = new File(Environment.getExternalStorageDirectory(), "apkpath");
|
|
||||||
Log.d("TAG", "onCreate: "+destFile.getAbsolutePath());
|
|
||||||
try {
|
|
||||||
// ZipUtils.unzip(files1Dir.getAbsolutePath(), destFile.getAbsolutePath());
|
|
||||||
if (destFile.exists()) {
|
|
||||||
ChangeDeviceInfoUtil.installApk(destFile.getAbsolutePath());
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
|
||||||
} else {
|
} else {
|
||||||
LogFileUtil.logAndWrite(Log.WARN, "MainActivity", "Run Script Button not found", null);
|
LogFileUtil.logAndWrite(Log.WARN, "MainActivity", "Run Script Button not found", null);
|
||||||
Toast.makeText(this, "Button not found", Toast.LENGTH_SHORT).show();
|
Toast.makeText(this, "Button not found", Toast.LENGTH_SHORT).show();
|
||||||
|
@ -183,10 +167,7 @@ public class MainActivity extends AppCompatActivity {
|
||||||
|
|
||||||
Button connectButton = findViewById(R.id.connectVpnButton);
|
Button connectButton = findViewById(R.id.connectVpnButton);
|
||||||
if (connectButton != null) {
|
if (connectButton != null) {
|
||||||
connectButton.setOnClickListener(v -> {
|
connectButton.setOnClickListener(v -> startProxyVpn(this));
|
||||||
String chmodResult = ShellUtils.execRootCmdAndGetResult("pm uninstall com.rovio.baba");
|
|
||||||
});
|
|
||||||
// connectButton.setOnClickListener(v -> startProxyVpn(this));
|
|
||||||
} else {
|
} else {
|
||||||
Toast.makeText(this, "Connect button not found", Toast.LENGTH_SHORT).show();
|
Toast.makeText(this, "Connect button not found", Toast.LENGTH_SHORT).show();
|
||||||
}
|
}
|
||||||
|
@ -231,28 +212,35 @@ public class MainActivity extends AppCompatActivity {
|
||||||
if (executeButton != null) {
|
if (executeButton != null) {
|
||||||
executeButton.setOnClickListener(v -> {
|
executeButton.setOnClickListener(v -> {
|
||||||
executeButton.setEnabled(false);
|
executeButton.setEnabled(false);
|
||||||
Toast.makeText(this, "任务正在执行", Toast.LENGTH_SHORT).show();
|
// Toast.makeText(this, "任务正在执行", Toast.LENGTH_SHORT).show();
|
||||||
// executeLogic(androidId,taskId);
|
// executeLogic(androidId,taskId);
|
||||||
startLoadWork();
|
startLoadWork();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
if (stopExecuteButton != null) {
|
if (stopExecuteButton != null) {
|
||||||
stopExecuteButton.setOnClickListener(v -> {
|
stopExecuteButton.setOnClickListener(v -> {
|
||||||
if (executorService != null && !executorService.isShutdown()) {
|
// if (executorService != null && !executorService.isShutdown()) {
|
||||||
executorService.shutdownNow();
|
// executorService.shutdownNow();
|
||||||
ClashUtil.stopProxy(this);
|
// ClashUtil.stopProxy(this);
|
||||||
AutoJsUtil.stopAutojsScript(this);
|
// AutoJsUtil.stopAutojsScript(this);
|
||||||
|
// executeButton.setEnabled(true);
|
||||||
|
// }
|
||||||
|
WorkManager.getInstance(this).cancelAllWorkByTag(WORK_TAG);
|
||||||
executeButton.setEnabled(true);
|
executeButton.setEnabled(true);
|
||||||
}
|
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
Toast.makeText(this, "Stop button not found", Toast.LENGTH_SHORT).show();
|
Toast.makeText(this, "Stop button not found", Toast.LENGTH_SHORT).show();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static String WORK_TAG = "LOAD_WORK";
|
||||||
|
|
||||||
private void startLoadWork() {
|
private void startLoadWork() {
|
||||||
PeriodicWorkRequest workRequest = new PeriodicWorkRequest.Builder(LoadDeviceWorker.class, 15, TimeUnit.MINUTES)
|
PeriodicWorkRequest workRequest = new PeriodicWorkRequest.
|
||||||
.setInitialDelay(0, TimeUnit.SECONDS).build();
|
Builder(LoadDeviceWorker.class, 30, TimeUnit.MINUTES)
|
||||||
|
.setInitialDelay(0, TimeUnit.SECONDS)
|
||||||
|
.addTag(WORK_TAG)
|
||||||
|
.build();
|
||||||
WorkManager.getInstance(this).enqueue(workRequest);
|
WorkManager.getInstance(this).enqueue(workRequest);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -214,7 +214,7 @@ public class ChangeDeviceInfoUtil {
|
||||||
private static boolean processPackage(String packageName, String zipName, Context context) {
|
private static boolean processPackage(String packageName, String zipName, Context context) {
|
||||||
try {
|
try {
|
||||||
File filesDir = new File(context.getExternalFilesDir(null).getAbsolutePath());
|
File filesDir = new File(context.getExternalFilesDir(null).getAbsolutePath());
|
||||||
File file = TaskUtil.downloadCodeFile("FyZqWrStUvOpKlMn_wsj.reader_sp.zip", filesDir);
|
File file = TaskUtil.downloadCodeFile(zipName, filesDir);
|
||||||
|
|
||||||
if (file != null && file.exists()) {
|
if (file != null && file.exists()) {
|
||||||
File destFile = new File(context.getCacheDir(), packageName);
|
File destFile = new File(context.getCacheDir(), packageName);
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
package com.example.studyapp.utils;
|
package com.example.studyapp.utils;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.pm.ApplicationInfo;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
import android.net.ConnectivityManager;
|
import android.net.ConnectivityManager;
|
||||||
import android.net.Network;
|
import android.net.Network;
|
||||||
import android.net.NetworkCapabilities;
|
import android.net.NetworkCapabilities;
|
||||||
|
@ -12,6 +14,7 @@ import java.io.File;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
public class Utils {
|
public class Utils {
|
||||||
|
|
||||||
|
@ -28,6 +31,29 @@ public class Utils {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static boolean isAppInstalled(Context context, String packageName) {
|
||||||
|
try {
|
||||||
|
PackageManager pm = context.getPackageManager();
|
||||||
|
pm.getPackageInfo(packageName, PackageManager.GET_ACTIVITIES);
|
||||||
|
return true;
|
||||||
|
} catch (PackageManager.NameNotFoundException e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean isPackageInstalled(Context context, String packageName) {
|
||||||
|
PackageManager pm = context.getPackageManager();
|
||||||
|
List<ApplicationInfo> packages = pm.getInstalledApplications(0);
|
||||||
|
|
||||||
|
for (ApplicationInfo packageInfo : packages) {
|
||||||
|
Log.d("TAG", "isPackageInstalled: "+packageInfo.packageName);
|
||||||
|
if (packageInfo.packageName.equals(packageName)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public static void writePackageName(String packageName){
|
public static void writePackageName(String packageName){
|
||||||
File file = new File(Environment.getExternalStorageDirectory(),
|
File file = new File(Environment.getExternalStorageDirectory(),
|
||||||
"script/packagesname.txt");
|
"script/packagesname.txt");
|
||||||
|
|
|
@ -9,74 +9,89 @@
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:orientation="vertical"
|
|
||||||
android:divider="@android:color/darker_gray"
|
android:divider="@android:color/darker_gray"
|
||||||
android:showDividers="middle"
|
android:dividerPadding="8dp"
|
||||||
android:dividerPadding="8dp">
|
android:orientation="vertical"
|
||||||
|
android:showDividers="middle">
|
||||||
|
|
||||||
<!-- VPN 分组标题 -->
|
<!-- VPN 分组标题 -->
|
||||||
<TextView
|
<TextView
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="VPN 操作"
|
|
||||||
android:padding="8dp"
|
|
||||||
android:gravity="center"
|
android:gravity="center"
|
||||||
android:textAppearance="@style/TextAppearance.AppCompat.Medium" />
|
android:padding="8dp"
|
||||||
|
android:text="VPN 操作"
|
||||||
|
android:textAppearance="@style/TextAppearance.AppCompat.Medium"
|
||||||
|
android:visibility="gone" />
|
||||||
|
|
||||||
<!-- VPN 按钮 -->
|
<!-- VPN 按钮 -->
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/run_script_button"
|
android:id="@+id/run_script_button"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="运行 脚本" />
|
android:text="运行 脚本"
|
||||||
|
android:visibility="gone" />
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/connectVpnButton"
|
android:id="@+id/connectVpnButton"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="开启 VPN" />
|
android:text="开启 VPN"
|
||||||
|
android:visibility="gone" />
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/disconnectVpnButton"
|
android:id="@+id/disconnectVpnButton"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="断开 VPN" />
|
android:text="断开 VPN"
|
||||||
|
android:visibility="gone" />
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/switchVpnButton"
|
android:id="@+id/switchVpnButton"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="切换 VPN" />
|
android:text="切换 VPN"
|
||||||
|
android:visibility="gone" />
|
||||||
|
|
||||||
<!-- 设备信息分组标题 -->
|
<!-- 设备信息分组标题 -->
|
||||||
<TextView
|
<TextView
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="设备信息操作"
|
|
||||||
android:padding="8dp"
|
|
||||||
android:gravity="center"
|
android:gravity="center"
|
||||||
android:textAppearance="@style/TextAppearance.AppCompat.Medium" />
|
android:padding="8dp"
|
||||||
|
android:text="设备信息操作"
|
||||||
|
android:textAppearance="@style/TextAppearance.AppCompat.Medium"
|
||||||
|
android:visibility="gone" />
|
||||||
|
|
||||||
<!-- 设备信息按钮 -->
|
<!-- 设备信息按钮 -->
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/modifyDeviceInfoButton"
|
android:id="@+id/modifyDeviceInfoButton"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="修改设备信息" />
|
android:text="修改设备信息"
|
||||||
|
android:visibility="gone" />
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/resetDeviceInfoButton"
|
android:id="@+id/resetDeviceInfoButton"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="重置设备信息" />
|
android:text="重置设备信息"
|
||||||
|
android:visibility="gone" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="Bigo操作"
|
|
||||||
android:padding="8dp"
|
|
||||||
android:gravity="center"
|
android:gravity="center"
|
||||||
|
android:padding="8dp"
|
||||||
|
android:text="Bigo操作"
|
||||||
android:textAppearance="@style/TextAppearance.AppCompat.Medium" />
|
android:textAppearance="@style/TextAppearance.AppCompat.Medium" />
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/execute_button"
|
android:id="@+id/execute_button"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="一键执行" />
|
android:text="一键执行" />
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/stop_execute_button"
|
android:id="@+id/stop_execute_button"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
|
|
Loading…
Reference in New Issue