EApplication.java 12 KB

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