EApplication.java 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308
  1. package com.edufound.reader.application;
  2. import android.app.Activity;
  3. import android.app.ActivityManager;
  4. import android.app.Application;
  5. import android.content.Context;
  6. import android.content.Intent;
  7. import android.content.pm.ApplicationInfo;
  8. import android.content.pm.PackageManager;
  9. import android.os.Build;
  10. import android.os.Bundle;
  11. import android.os.Handler;
  12. import android.os.Looper;
  13. import androidx.annotation.RequiresApi;
  14. import com.baidu.duer.botsdk.BotSdk;
  15. import com.baidu.duer.botsdk.util.HeartBeatReporter;
  16. import com.edufound.reader.activity.CrashDialogActivity;
  17. import com.edufound.reader.activity.SplashActivity;
  18. import com.edufound.reader.bean.ChannelCodeEnum;
  19. import com.edufound.reader.botsdk.BotConstants;
  20. import com.edufound.reader.botsdk.BotMessageListener;
  21. import com.edufound.reader.botsdk.BotSDKUtils;
  22. import com.edufound.reader.support.CrashLog;
  23. import com.edufound.reader.support.DebugSafeModeTipActivity;
  24. import com.edufound.reader.support.DebugSafeModeUI;
  25. import com.edufound.reader.util.Cockroach;
  26. import com.edufound.reader.util.Consts;
  27. import com.edufound.reader.util.DeviceUuidFactory;
  28. import com.edufound.reader.util.ExceptionHandler;
  29. import com.edufound.reader.util.OkHttpClient;
  30. import com.orhanobut.logger.AndroidLogAdapter;
  31. import com.orhanobut.logger.FormatStrategy;
  32. import com.orhanobut.logger.Logger;
  33. import com.orhanobut.logger.PrettyFormatStrategy;
  34. import com.tencent.mmkv.MMKV;
  35. import com.umeng.analytics.MobclickAgent;
  36. import com.umeng.commonsdk.UMConfigure;
  37. import com.umeng.commonsdk.listener.OnGetOaidListener;
  38. import org.xmlpull.v1.XmlPullParserException;
  39. import org.xmlpull.v1.XmlPullParserFactory;
  40. import java.util.ArrayList;
  41. import java.util.List;
  42. import io.reactivex.rxjava3.functions.Consumer;
  43. import io.reactivex.rxjava3.plugins.RxJavaPlugins;
  44. public class EApplication extends Application {
  45. private int activityAount = 0;
  46. public boolean isForeground = false;
  47. public static long APP_START_TIME = 0;
  48. public static List<Activity> mActivityList = new ArrayList<>();
  49. @Override
  50. public void onCreate() {
  51. super.onCreate();
  52. try {
  53. Consts.setIsDebug(false);
  54. Consts.setmApplicAtion(this);
  55. //初始化异常监听
  56. initException();
  57. XmlPullParserFactory.newInstance().setFeature("http://apache.org/xml/features/disallow-doctype-decl", true);
  58. //初始化OKhttp3
  59. OkHttpClient.initOkHttpUtil(getApplicationContext());
  60. //初始化logger
  61. FormatStrategy formatStrategy = PrettyFormatStrategy.newBuilder()
  62. .showThreadInfo(false) // 是否显示线程信息,默认为ture
  63. .methodCount(3) // 显示的方法行数,默认为2
  64. // .methodOffset(1) // 隐藏内部方法调用到偏移量,默认为5
  65. // .logStrategy() // 更改要打印的日志策略。
  66. .tag(getPackageName()) // 每个日志的全局标记。默认PRETTY_LOGGER
  67. .build();
  68. Logger.addLogAdapter(new AndroidLogAdapter(formatStrategy));
  69. //初始化友盟
  70. UMConfigure.setLogEnabled(true);
  71. UMConfigure.preInit(this, getUmengAppKey(), getUmengChannel());
  72. UMConfigure.init(this, getUmengAppKey(), getUmengChannel(), UMConfigure.DEVICE_TYPE_PHONE, "");
  73. UMConfigure.getOaid(this, new OnGetOaidListener() {
  74. @Override
  75. public void onGetOaid(String s) {
  76. // Logger.e("umeng_oaid:" + s);
  77. }
  78. });
  79. MobclickAgent.setPageCollectionMode(MobclickAgent.PageMode.AUTO);
  80. // UMConfigure.preInit(this,"");
  81. //初始化MMKV
  82. MMKV.initialize(this);
  83. //初始化DeviceUuidFactory
  84. if (DeviceUuidFactory.getUuid() == null) {
  85. new DeviceUuidFactory(getApplicationContext());
  86. }
  87. Consts.setUID("test");
  88. //初始化activity监听
  89. registerActivityLifecycleCallbacks(activityLifecycleCallbacks);
  90. if (Consts.getUmengChannel().equals(ChannelCodeEnum.BAIDU.getChannelCode())) {
  91. /** 接入益智乐园的App,需要删掉下面这一行。保证益智乐园的付费等逻辑正常执行,不知道益智乐园是啥的,不要删掉这一行 */
  92. HeartBeatReporter.getInstance().setShouldUploadHeartBeatByApp(false);
  93. // 初始化BotSDK
  94. BotSdk.getInstance().init(this);
  95. // 打开BotSDK的Log开关,开发阶段建议打开Log开关,便于排查问题
  96. // BotSdk.enableLog(BuildConfig.DEBUG);
  97. String random1 = BotConstants.RANDOM1_PREFIX + Math.random();
  98. String random2 = BotConstants.RANDOM2_PREFIX + Math.random();
  99. // 在线校验示例3
  100. BotSdk.getInstance().register(BotMessageListener.getInstance(), BotConstants.BOTID,
  101. random1, BotSDKUtils.sign(random1), random2, BotSDKUtils.sign(random2));
  102. }
  103. } catch (XmlPullParserException e) {
  104. e.printStackTrace();
  105. }
  106. }
  107. public static void killAppProcess(Context context) {
  108. for (int i = 0; i < EApplication.mActivityList.size(); i++) {
  109. EApplication.mActivityList.get(i).finish();
  110. }
  111. //注意:不能先杀掉主进程,否则逻辑代码无法继续执行,需先杀掉相关进程最后杀掉主进程
  112. MobclickAgent.onKillProcess(context.getApplicationContext());
  113. ActivityManager mActivityManager = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);
  114. List<ActivityManager.RunningAppProcessInfo> mList = mActivityManager.getRunningAppProcesses();
  115. if (mList != null) {
  116. for (ActivityManager.RunningAppProcessInfo runningAppProcessInfo : mList) {
  117. if (runningAppProcessInfo.pid != android.os.Process.myPid()) {
  118. android.os.Process.killProcess(runningAppProcessInfo.pid);
  119. }
  120. }
  121. android.os.Process.killProcess(android.os.Process.myPid());
  122. }
  123. // System.exit(0);
  124. }
  125. ActivityLifecycleCallbacks activityLifecycleCallbacks = new ActivityLifecycleCallbacks() {
  126. @Override
  127. public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
  128. }
  129. @Override
  130. public void onActivityStarted(Activity activity) {
  131. if (activityAount == 0) {
  132. //app回到前台
  133. isForeground = true;
  134. // ToastUtil.showToast("app回到前台了");
  135. APP_START_TIME = System.currentTimeMillis();
  136. }
  137. activityAount++;
  138. }
  139. @Override
  140. public void onActivityResumed(Activity activity) {
  141. }
  142. @Override
  143. public void onActivityPaused(Activity activity) {
  144. }
  145. @Override
  146. public void onActivityStopped(Activity activity) {
  147. activityAount--;
  148. if (activityAount == 0) {
  149. isForeground = false;
  150. }
  151. }
  152. @Override
  153. public void onActivitySaveInstanceState(Activity activity, Bundle outState) {
  154. }
  155. @Override
  156. public void onActivityDestroyed(Activity activity) {
  157. }
  158. };
  159. private void initException() {
  160. RxJavaPlugins.setErrorHandler(new Consumer<Throwable>() {
  161. @Override
  162. public void accept(Throwable throwable) throws Exception {
  163. throwable.printStackTrace();//这里处理所有的Rxjava异常
  164. CrashLog.saveCrashLog(getApplicationContext(), throwable);
  165. }
  166. });
  167. final Thread.UncaughtExceptionHandler sysExcepHandler = Thread.getDefaultUncaughtExceptionHandler();
  168. DebugSafeModeUI.init(this);
  169. Cockroach.install(this, new ExceptionHandler() {
  170. @Override
  171. protected void onUncaughtExceptionHappened(Thread thread, Throwable throwable) {
  172. CrashLog.saveCrashLog(getApplicationContext(), throwable);
  173. new Handler(Looper.getMainLooper()).post(new Runnable() {
  174. @Override
  175. public void run() {
  176. // toast.setText("Cockroach.install:onUncaughtExceptionHappened");
  177. // toast.show();
  178. Logger.e("Cockroach.install:onUncaughtExceptionHappened");
  179. }
  180. });
  181. }
  182. @Override
  183. protected void onBandageExceptionHappened(Throwable throwable) {
  184. throwable.printStackTrace();//打印警告级别log,该throwable可能是最开始的bug导致的,无需关心
  185. // toast.setText("Cockroach Worked");
  186. // toast.show();
  187. }
  188. @Override
  189. protected void onEnterSafeMode() {
  190. // int tips = R.string.safe_mode_tips;
  191. // Toast.makeText(Consts.getmApplicAtion(), getResources().getString(tips), Toast.LENGTH_LONG).show();
  192. // DebugSafeModeUI.showSafeModeUI();
  193. if (Consts.isIsDebug()) {
  194. Intent intent = new Intent(Consts.getmApplicAtion(), DebugSafeModeTipActivity.class);
  195. intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK | Intent.FLAG_ACTIVITY_NEW_TASK);
  196. startActivity(intent);
  197. } else {
  198. Intent intent = new Intent(Consts.getmApplicAtion(), CrashDialogActivity.class);
  199. intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK | Intent.FLAG_ACTIVITY_NEW_TASK);
  200. startActivity(intent);
  201. }
  202. }
  203. @RequiresApi(api = Build.VERSION_CODES.N)
  204. @Override
  205. protected void onMayBeBlackScreen(Throwable e) {
  206. Thread thread = Looper.getMainLooper().getThread();
  207. e.printStackTrace();
  208. //黑屏时建议直接杀死app
  209. sysExcepHandler.uncaughtException(thread, new RuntimeException("black screen"));
  210. for (int i = 0; i < mActivityList.size(); i++) {
  211. mActivityList.get(i).finish();
  212. }
  213. killAppProcess(Consts.getmApplicAtion());
  214. }
  215. });
  216. }
  217. public String getUmengChannel() {
  218. String channelName = null;
  219. try {
  220. PackageManager packageManager = getPackageManager();
  221. if (packageManager != null) {
  222. //注意此处为ApplicationInfo 而不是 ActivityInfo,因为友盟设置的meta-data是在application标签中,而不是某activity标签中,所以用ApplicationInfo
  223. ApplicationInfo applicationInfo = packageManager.
  224. getApplicationInfo(getPackageName(), PackageManager.GET_META_DATA);
  225. if (applicationInfo != null) {
  226. if (applicationInfo.metaData != null) {
  227. channelName = String.valueOf(applicationInfo.metaData.get("UMENG_CHANNEL"));
  228. Consts.setUmengChannel(channelName);
  229. }
  230. }
  231. }
  232. } catch (Exception e) {
  233. e.printStackTrace();
  234. }
  235. return channelName;
  236. }
  237. public String getUmengAppKey() {
  238. String appkey = null;
  239. try {
  240. PackageManager packageManager = getPackageManager();
  241. if (packageManager != null) {
  242. //注意此处为ApplicationInfo 而不是 ActivityInfo,因为友盟设置的meta-data是在application标签中,而不是某activity标签中,所以用ApplicationInfo
  243. ApplicationInfo applicationInfo = packageManager.
  244. getApplicationInfo(getPackageName(), PackageManager.GET_META_DATA);
  245. if (applicationInfo != null) {
  246. if (applicationInfo.metaData != null) {
  247. appkey = String.valueOf(applicationInfo.metaData.get("UMENG_APPKEY"));
  248. }
  249. }
  250. }
  251. } catch (Exception e) {
  252. e.printStackTrace();
  253. }
  254. return appkey;
  255. }
  256. public static void reloadApp(int defaultIndex) {
  257. for (int i = 0; i < EApplication.mActivityList.size(); i++) {
  258. EApplication.mActivityList.get(i).finish();
  259. }
  260. System.gc();
  261. Intent intent = new Intent(Consts.getmApplicAtion(), SplashActivity.class);
  262. if (defaultIndex != -1) {
  263. intent.putExtra("defaultIndex", defaultIndex);
  264. }
  265. intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
  266. Consts.getmApplicAtion().startActivity(intent);
  267. }
  268. }