Commit b12fe3f8 by konghaorui

修复线上bug

parent bbb23593
...@@ -63,17 +63,17 @@ class MainActivity : BaseLceActivity<DemoContract.View, DemoContract.Presenter>( ...@@ -63,17 +63,17 @@ class MainActivity : BaseLceActivity<DemoContract.View, DemoContract.Presenter>(
override fun initDataAndEvent() { override fun initDataAndEvent() {
YDLavManager.instances.init(this, "3387e9b251f3491e9221a9877e8f7830") //YDLavManager.instances.init(this, "3387e9b251f3491e9221a9877e8f7830")
bindService() bindService()
reLoadData() reLoadData()
requestPermission() requestPermission()
tv_user.setOnClickListener { tv_user.setOnClickListener {
reLoadData() mPresenter.loadFmMusic()
} }
tv_home.setOnClickListener { tv_home.setOnClickListener {
mPresenter?.loadHome() mPresenter.loadHome()
} }
bt_to_other.setOnClickListener { bt_to_other.setOnClickListener {
......
...@@ -26,8 +26,8 @@ public final class DemoGlobalConfig implements IConfigModule { ...@@ -26,8 +26,8 @@ public final class DemoGlobalConfig implements IConfigModule {
@Override @Override
public void applyOptions(@NotNull Context context, @NotNull GlobalConfig.Builder builder) { public void applyOptions(@NotNull Context context, @NotNull GlobalConfig.Builder builder) {
// String env = YDLConstants.ENV_AUTO_TEST; // String env = YDLConstants.ENV_AUTO_TEST;
// String env = YDLConstants.ENV_PROD; String env = YDLConstants.ENV_PROD;
String env = YDLConstants.ENV_TEST; // String env = YDLConstants.ENV_TEST;
builder.setFrom( "ydl".equals(BuildConfig.FLAVOR) ?YDLConstants.FROM_YDL :YDLConstants.FROM_XLZX) builder.setFrom( "ydl".equals(BuildConfig.FLAVOR) ?YDLConstants.FROM_YDL :YDLConstants.FROM_XLZX)
.addUrl("github", APP_DOMAIN) .addUrl("github", APP_DOMAIN)
......
...@@ -20,7 +20,9 @@ class DemoModel : BaseModel(), DemoContract.Model { ...@@ -20,7 +20,9 @@ class DemoModel : BaseModel(), DemoContract.Model {
return YDLHttpUtils.obtainApi(DemoService::class.java) return YDLHttpUtils.obtainApi(DemoService::class.java)
.getFMData() .getFMData()
.compose(RxUtils.resultJavaData()) .compose(RxUtils.resultJavaData())
.map {
throw RuntimeException("runtime exception")
}
} }
override fun getHome(): Observable<JsonObject> { override fun getHome(): Observable<JsonObject> {
......
...@@ -7,6 +7,7 @@ import com.ydl.media.audio.AudioPlayer ...@@ -7,6 +7,7 @@ import com.ydl.media.audio.AudioPlayer
import com.ydl.media.audio.model.Music import com.ydl.media.audio.model.Music
import com.ydl.ydlcommon.data.http.RxUtils import com.ydl.ydlcommon.data.http.RxUtils
import com.ydl.ydlcommon.mvp.base.BasePresenter import com.ydl.ydlcommon.mvp.base.BasePresenter
import com.ydl.ydlcommon.utils.LogUtil
import com.ydl.ydlnet.client.observer.CommonObserver import com.ydl.ydlnet.client.observer.CommonObserver
/** /**
...@@ -21,15 +22,18 @@ class DemoPresenter : BasePresenter<DemoContract.View,DemoContract.Model>(), ...@@ -21,15 +22,18 @@ class DemoPresenter : BasePresenter<DemoContract.View,DemoContract.Model>(),
.compose(RxUtils.applySchedulers(mView)) .compose(RxUtils.applySchedulers(mView))
.subscribe(object : CommonObserver<HomeFMBean>() { .subscribe(object : CommonObserver<HomeFMBean>() {
override fun onError(errorMsg: String) { override fun onError(errorMsg: String) {
LogUtil.d("RxJava loadUsers ---->: $errorMsg")
} }
override fun onSuccess(homeFMBean: HomeFMBean) { override fun onSuccess(homeFMBean: HomeFMBean) {
throw RuntimeException("runtime exception")
homeFMBean.list?.let { homeFMBean.list?.let {
AudioPlayer.get().addPlayList(stringToMusicPlayerList(it)) AudioPlayer.get().addPlayList(stringToMusicPlayerList(it))
mView.setData("") mView.setData("")
} }
} }
}) })
} }
override fun loadHome() = mModel.getHome() override fun loadHome() = mModel.getHome()
...@@ -52,6 +56,7 @@ class DemoPresenter : BasePresenter<DemoContract.View,DemoContract.Model>(), ...@@ -52,6 +56,7 @@ class DemoPresenter : BasePresenter<DemoContract.View,DemoContract.Model>(),
.compose(RxUtils.applySchedulers(mView))//使用 Rxlifecycle,使 Disposable 和 Activity 一起销毁 .compose(RxUtils.applySchedulers(mView))//使用 Rxlifecycle,使 Disposable 和 Activity 一起销毁
.subscribe(object : CommonObserver<JsonArray>() { .subscribe(object : CommonObserver<JsonArray>() {
override fun onError(errorMsg: String) { override fun onError(errorMsg: String) {
LogUtil.d("RxJava loadUsers ---->: $errorMsg")
} }
override fun onSuccess(users: JsonArray) { override fun onSuccess(users: JsonArray) {
......
ext { ext {
kotlin_version = "1.3.21" kotlin_version = "1.3.21"
dev_mode = false dev_mode = true
ydl_app = [ ydl_app = [
appName : "心理咨询壹点灵", appName : "心理咨询壹点灵",
......
...@@ -17,6 +17,7 @@ import com.ydl.ydlnet.client.interfaces.BuildHeadersListener; ...@@ -17,6 +17,7 @@ import com.ydl.ydlnet.client.interfaces.BuildHeadersListener;
import java.io.File; import java.io.File;
import java.io.InputStream; import java.io.InputStream;
import java.util.Collections;
import java.util.Map; import java.util.Map;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
...@@ -25,6 +26,7 @@ import javax.net.ssl.HostnameVerifier; ...@@ -25,6 +26,7 @@ import javax.net.ssl.HostnameVerifier;
import okhttp3.Cache; import okhttp3.Cache;
import okhttp3.Interceptor; import okhttp3.Interceptor;
import okhttp3.OkHttpClient; import okhttp3.OkHttpClient;
import okhttp3.Protocol;
/** /**
* Created by haorui on 2019-09-02 . * Created by haorui on 2019-09-02 .
...@@ -45,7 +47,7 @@ public class OkHttpConfig { ...@@ -45,7 +47,7 @@ public class OkHttpConfig {
private static OkHttpClient okHttpClient; private static OkHttpClient okHttpClient;
public OkHttpConfig() { public OkHttpConfig() {
okHttpClientBuilder = new OkHttpClient.Builder(); okHttpClientBuilder = new OkHttpClient.Builder().protocols(Collections.singletonList(Protocol.HTTP_1_1));
} }
public static OkHttpConfig getInstance() { public static OkHttpConfig getInstance() {
......
...@@ -29,7 +29,11 @@ public abstract class BaseObserver<T> implements Observer<T>, ISubscriber<T> { ...@@ -29,7 +29,11 @@ public abstract class BaseObserver<T> implements Observer<T>, ISubscriber<T> {
@Override @Override
public void onNext(@NonNull T t) { public void onNext(@NonNull T t) {
doOnNext(t); try {
doOnNext(t);
} catch (Exception e) {
onError(e);
}
} }
@Override @Override
......
...@@ -2,8 +2,10 @@ package com.yidianling.ydl_pay.toast ...@@ -2,8 +2,10 @@ package com.yidianling.ydl_pay.toast
import android.content.Context import android.content.Context
import android.support.annotation.StringRes import android.support.annotation.StringRes
import android.text.TextUtils
import android.widget.Toast import android.widget.Toast
import com.ydl.ydlcommon.base.BaseApp
import com.ydl.ydlcommon.utils.LogUtil
import com.yidianling.common.tools.ToastUtil
/** /**
* author : Zhangwenchao * author : Zhangwenchao
...@@ -31,16 +33,16 @@ class ToastHelper private constructor() { ...@@ -31,16 +33,16 @@ class ToastHelper private constructor() {
} }
private fun show(context: Context, text: CharSequence) { private fun show(context: Context, text: CharSequence) {
if (TextUtils.isEmpty(text)) return ToastUtil.toastShort(text.toString())
if (toast == null) toast = Toast.makeText(context, text, Toast.LENGTH_SHORT)
else toast?.setText(text)
toast?.show()
} }
private fun show(context: Context, @StringRes resId: Int) { private fun show(context: Context, @StringRes resId: Int) {
if (toast == null) toast = Toast.makeText(context, resId, Toast.LENGTH_SHORT) try {
else toast?.setText(resId) val text = BaseApp.getApp().resources.getString(resId)
toast?.show() ToastUtil.toastShort(text)
} catch (e: Exception) {
LogUtil.e(e.message)
}
} }
private object Holder { private object Holder {
......
...@@ -8,10 +8,13 @@ import com.lzy.imagepicker.view.CropImageView ...@@ -8,10 +8,13 @@ import com.lzy.imagepicker.view.CropImageView
import com.ydl.devicesidlib.DeviceIDHelper import com.ydl.devicesidlib.DeviceIDHelper
import com.ydl.ydlcommon.actions.imagepicker.YdlImageLoader import com.ydl.ydlcommon.actions.imagepicker.YdlImageLoader
import com.ydl.ydlcommon.base.BaseApp import com.ydl.ydlcommon.base.BaseApp
import com.ydl.ydlcommon.data.http.UpLoadLogUtils
import com.ydl.ydlcommon.utils.BuryPointUtils import com.ydl.ydlcommon.utils.BuryPointUtils
import com.ydl.ydlcommon.utils.LogUtil import com.ydl.ydlcommon.utils.LogUtil
import com.ydl.ydlcommon.utils.log.LogHelper import com.ydl.ydlcommon.utils.log.LogHelper
import com.ydl.ydlnet.client.exception.ApiException
import com.yidianling.common.tools.RxTool import com.yidianling.common.tools.RxTool
import io.reactivex.plugins.RxJavaPlugins
/** /**
...@@ -41,6 +44,22 @@ object YdlRepository { ...@@ -41,6 +44,22 @@ object YdlRepository {
// } // }
// refWatcher = LeakCanary.install(app) // refWatcher = LeakCanary.install(app)
initARouter(app, isDebug) initARouter(app, isDebug)
initRxPlugin()
}
private fun initRxPlugin() {
//保障RxJava调用链流程不会崩溃
RxJavaPlugins.setErrorHandler {
LogUtil.e("RxJava ErrorHandler ---->: $it")
try {
val apiException = ApiException.handleException(it)
UpLoadLogUtils.upLoadLog(
"RxJava Error Handler ", apiException.code, apiException.message?:""
)
} catch (e: Exception) {
LogUtil.d("RxJava ErrorHandler UpLoad Log Error ---->: $it")
}
}
} }
/** /**
......
package com.ydl.ydlcommon.data.http package com.ydl.ydlcommon.data.http
import android.text.TextUtils import android.text.TextUtils
import com.ydl.ydlcommon.R
import com.ydl.ydlcommon.base.BaseApp import com.ydl.ydlcommon.base.BaseApp
import com.yidianling.common.tools.LogUtil import com.yidianling.common.tools.LogUtil
import com.yidianling.common.tools.RxNetTool import com.yidianling.common.tools.RxNetTool
import com.ydl.ydlcommon.R
import io.reactivex.functions.Consumer import io.reactivex.functions.Consumer
/** /**
......
package com.ydl.ydlcommon.utils.remind package com.ydl.ydlcommon.utils.remind
import android.support.annotation.StringRes import android.support.annotation.StringRes
import android.text.TextUtils
import android.widget.Toast
import com.ydl.ydlcommon.base.BaseApp import com.ydl.ydlcommon.base.BaseApp
import com.ydl.ydlcommon.utils.LogUtil
import com.yidianling.common.tools.ToastUtil
/** /**
* author : Zhangwenchao * author : Zhangwenchao
...@@ -14,8 +14,6 @@ import com.ydl.ydlcommon.base.BaseApp ...@@ -14,8 +14,6 @@ import com.ydl.ydlcommon.base.BaseApp
*/ */
class ToastHelper private constructor() { class ToastHelper private constructor() {
private var toast: Toast? = null
companion object { companion object {
private fun getInstance(): ToastHelper { private fun getInstance(): ToastHelper {
return Holder.INSTANCE return Holder.INSTANCE
...@@ -31,16 +29,16 @@ class ToastHelper private constructor() { ...@@ -31,16 +29,16 @@ class ToastHelper private constructor() {
} }
private fun show(text: CharSequence) { private fun show(text: CharSequence) {
if (TextUtils.isEmpty(text)) return ToastUtil.toastShort(text.toString())
if (toast == null) toast = Toast.makeText(BaseApp.getApp(), text, Toast.LENGTH_SHORT)
else toast?.setText(text)
toast?.show()
} }
private fun show(@StringRes resId: Int) { private fun show(@StringRes resId: Int) {
if (toast == null) toast = Toast.makeText(BaseApp.getApp(), resId, Toast.LENGTH_SHORT) try {
else toast?.setText(resId) val text = BaseApp.getApp().resources.getString(resId)
toast?.show() ToastUtil.toastShort(text)
} catch (e: Exception) {
LogUtil.e(e.message)
}
} }
private object Holder { private object Holder {
......
package com.yidianling.common.tools; package com.yidianling.common.tools;
import android.content.Context; import android.content.Context;
import android.graphics.Color;
import android.os.Handler; import android.os.Handler;
import android.os.Looper; import android.os.Looper;
import android.text.TextUtils; import android.text.TextUtils;
...@@ -42,6 +41,7 @@ public class ToastUtil { ...@@ -42,6 +41,7 @@ public class ToastUtil {
handler.post(() -> toastShort(RxTool.getContext(), msg)); handler.post(() -> toastShort(RxTool.getContext(), msg));
} }
} }
private static void showShortToast(Context mContext, String msg) { private static void showShortToast(Context mContext, String msg) {
if (toast == null) { if (toast == null) {
toast = Toast.makeText(mContext.getApplicationContext(), msg, Toast.LENGTH_SHORT); toast = Toast.makeText(mContext.getApplicationContext(), msg, Toast.LENGTH_SHORT);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment