EApplication.java 12 KB

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