Android volley proguard抛出java.lang.RuntimeException:Stub

时间:2017-01-10 11:20:29

标签: android android-volley twilio proguard

我使用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:

添加用例

  1. 应用程序启动并请求用户允许权限,如位置,短信读取,..
  2. 一旦用户同意这些权限集,用户就可以输入email-id&amp;密码。
  3. 电子邮件ID&amp; password是通过getParam()传递的参数。
  4. 当通过volley StringRequest请求以下内容时,它最终会转到&#34; OnErrorResponse&#34;,其中错误消息为&#34; java.lang.RuntimeException:Stub!&#34;
  5. 更新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
    

1 个答案:

答案 0 :(得分:3)

我发布我的解决方案以防万一有人发现它有用。

&#34; stub的原因!&#34;

  

在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

来源Link to SO answer