我使用Android Volley网络库,在保持调试+发布模式时工作完全正常,直到我添加 Twilio客户端SDK 。现在它在调试模式下工作正常但在发布模式下抛出此错误
E/Volley: [105358] NetworkDispatcher.run: Unhandled exception java.lang.RuntimeException: Stub!
java.lang.RuntimeException: Stub!
at org.apache.a.h.<init>(SourceFile:6)
at com.android.volley.toolbox.HurlStack.performRequest(SourceFile:109)
at com.android.volley.toolbox.BasicNetwork.performRequest(SourceFile:97)
at com.android.volley.NetworkDispatcher.run(SourceFile:114)
从Android排球字符串reqiest
的error
界面获取的日志
01-10 16:42:27.330 522-522/? D/LOGINACTIVITY: java.lang.RuntimeException: Stub!-java.lang.RuntimeException: Stub!-java.lang.RuntimeException: Stub!
在他们要求将JUint
保持在依赖项列表的顶部时,已经查找了相同的内容并得到了一些响应。仍然存在错误。任何形式的帮助将不胜感激。 TIA
更新1:
添加了代码库
StringRequest strReq = new StringRequest(Request.Method.POST,
AppConfig.URL_LOGIN, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
....
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Log.d("LOGINACTIVITY", error.getLocalizedMessage() + "-" + error.getMessage() + "-" + error.getCause());
}
}) {
@Override
protected Map<String, String> getParams() {
// Posting parameters to login url
Map<String, String> params = new HashMap<String, String>();
params.put("email", email);
params.put("password", password);
return params;
}
};
// Adding request to request queue
strReq.setShouldCache(false);
strReq.setRetryPolicy(new DefaultRetryPolicy(AppConfig.DEFAULT_RETRY_TIME, DefaultRetryPolicy.DEFAULT_MAX_RETRIES, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));
AppController.getInstance().addToRequestQueue(strReq, tag_string_req);
更新2:
添加用例
更新3:
添加了Proguard规则
# Twilio Client
-keep class com.twilio.** { *; }
# Apache HttpClient
-dontwarn org.apache.http.**
-keepattributes InnerClasses
-keep public class android.net.http.SslError
-keep public class android.webkit.WebViewClient
-dontwarn android.webkit.WebView
-dontwarn android.net.http.SslError
-dontwarn android.webkit.WebViewClient
-keepattributes EnclosingMethod
答案 0 :(得分:3)
我发布我的解决方案以防万一有人发现它有用。
在Android SDK 23中使用Proguard和 com.apache.http.legacy 库时会发生这种情况。
事实上,当你调用它们时,所有方法都被删除,以便在消息“Stub!”中抛出异常。多可爱啊。
真正的android.jar实现存在于模拟器或真正的Android设备上。
所以改变proguard规则解决了以下问题,似乎twilio正在使用旧的http库或者不确定的东西。
所以,这是我目前的解决方案
# Twilio Client
-keep class com.twilio.** { *; }
-keep class org.webrtc.** { *; }
-keep class com.twilio.video.** { *; }
-keepattributes InnerClasses
-keep class org.apache.http.** { *; }
-keep class org.apache.commons.codec.** { *; }
-keep class org.apache.commons.logging.** { *; }
-keep class android.net.compatibility.** { *; }
-keep class android.net.http.** { *; }
-keep class com.android.internal.http.multipart.** { *; }
-dontwarn org.apache.http.**
-dontwarn android.webkit.**
-keepattributes EnclosingMethod