android volley和asynchttpclient在真实设备上失败,但在模拟器上工作

问题描述

大家好,我只是制作了一个使用ICS_OPENVPN库的android应用,但是当我使用SplashActivity检查更新应用时,在模拟器上运行了Currect,但是当我生成签名的APK并将其安装在真实设备上时,它并没有切换到MainActivity。

SplashActivity.java

package com.orangevpninfo.orangevpn;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AlertDialog;
import androidx.appcompat.app.AppCompatActivity;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.Toast;
import com.airbnb.lottie.LottieAnimationView;
import com.android.volley.NetworkResponse;
import com.android.volley.Request;
import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolBox.JsonObjectRequest;
import com.android.volley.toolBox.JsonRequest;
import com.android.volley.toolBox.Volley;
import com.google.android.gms.tasks.OnCompleteListener;
import com.google.android.gms.tasks.Task;
import com.google.firebase.iid.FirebaseInstanceId;
import com.google.firebase.iid.InstanceIdResult;
import com.google.gson.Gson;
import com.google.gson.JsonObject;
import com.loopj.android.http.AsyncHttpClient;
import com.loopj.android.http.JsonHttpResponseHandler;
import com.orangevpninfo.orangevpn.models.Version;
import cz.msebera.android.httpclient.Header;
import org.json.JSONArray;
import org.json.JSONObject;

public class SplashActivity extends AppCompatActivity {

    LottieAnimationView la_animation;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_splash);
        la_animation=findViewById(R.id.la_animation2);
        startAnimation(SplashActivity.this,R.id.la_animation2,R.anim.fade_in_1000,true);
        la_animation.cancelAnimation();
        la_animation.setAnimation(R.raw.loading2);
        la_animation.playAnimation();


        checkupdate2("1");




    }
    private void download(final String Link){
        AlertDialog alertDialog = new AlertDialog.Builder(SplashActivity.this).create();
        alertDialog.setTitle("New Version Available");
        alertDialog.setMessage("There is a New version of this App! Please select Update to Download directly new version and install it");
        alertDialog.setButton(AlertDialog.BUTTON_NEUTRAL,"Not Now",new DialogInterface.OnClickListener() {
                    public void onClick(DialogInterface dialog,int which) {
                        dialog.dismiss();
                        finish();
                    }
                });
        alertDialog.setButton(AlertDialog.BUTTON_POSITIVE,"Update",int which) {
                        Intent a=new Intent(Intent.ACTION_VIEW,Uri.parse(Link));
                        startActivity(a);
                        finish();
                    }
                });
        alertDialog.show();
        //Intent i = new Intent(Intent.ACTION_VIEW);
        //i.setData(Uri.parse(Link));
        //startActivity(i);
    }

    private void checkupdate2(final String version){


        Request<JSONObject> jsonObjectRequest = new JsonObjectRequest(Request.Method.GET,"http://51.89.45.117/version/version.json",null,new Response.Listener<JSONObject>() {
            @Override
            public void onResponse(JSONObject response) {
                Log.d("Success",response.toString());
                Version ver=new Gson().fromJson(response.toString(),Version.class);
                if (ver.getVersion().equals(version)){
                    Intent a=new Intent(SplashActivity.this,MainActivity.class);
                    startActivity(a);
                    finish();

                }else{
                    download(ver.getLink());
                }
            }
        },new Response.ErrorListener() {
            @Override
            public void onErrorResponse(VolleyError error) {
                Log.d("Error",error.toString());

            }

        });
        RequestQueue requestQueue = Volley.newRequestQueue(getApplicationContext());
         requestQueue.add(jsonObjectRequest);

    }
    private void checkupdate(final String version){
        String url="http://51.89.45.117/version/version.json";
        AsyncHttpClient client = new AsyncHttpClient();
        client.setConnectTimeout(30);
        client.get(this,url,new JsonHttpResponseHandler(){
            @Override
            public void onSuccess(int statusCode,Header[] headers,JSONArray response) {
                super.onSuccess(statusCode,headers,response);

                Version[] ver=new Gson().fromJson(response.toString(),Version[].class);
                if (ver[0].getVersion().equals(version)){
                    Intent a=new Intent(SplashActivity.this,MainActivity.class);
                    startActivity(a);
                    finish();

                }else{

                    download(ver[0].getLink());
                }

            }

            @Override
            public void onSuccess(int statusCode,JSONObject response) {
                super.onSuccess(statusCode,response);
                Version ver=new Gson().fromJson(response.toString(),MainActivity.class);
                    startActivity(a);
                    finish();

                }else{
                    download(ver.getLink());
                }
            }

            @Override
            public void onFailure(int statusCode,Throwable throwable,JSONArray errorResponse) {
                super.onFailure(statusCode,throwable,errorResponse);

                Version[] ver=new Gson().fromJson(errorResponse.toString(),MainActivity.class);
                    startActivity(a);
                    finish();

                }else{

                    download(ver[0].getLink());
                }

            }

            @Override
            public void onFailure(int statusCode,JSONObject errorResponse) {
                super.onFailure(statusCode,errorResponse);
                Toast.makeText(SplashActivity.this,"success Jobj",Toast.LENGTH_SHORT).show();
                Version ver=new Gson().fromJson(errorResponse.toString(),MainActivity.class);
                    startActivity(a);
                    SplashActivity.this.finish();

                }else{
                    download(ver.getLink());
                }

            }

            @Override
            public void onFailure(int statusCode,String responseString,Throwable throwable) {
                super.onFailure(statusCode,responseString,throwable);
                Intent a=new Intent(SplashActivity.this,MainActivity.class);
                startActivity(a);
                SplashActivity.this.finish();
            }

            @Override
            public void onSuccess(int statusCode,String responseString) {
                super.onSuccess(statusCode,responseString);
                Intent a=new Intent(SplashActivity.this,MainActivity.class);
                startActivity(a);
                SplashActivity.this.finish();
            }
        });
    }
    public void startAnimation(Context ctx,int view,int animation,boolean show) {
        final View Element = findViewById(view);
        if (show) {
            Element.setVisibility(View.VISIBLE);
        } else {
            Element.setVisibility(View.INVISIBLE);
        }
        Animation anim = AnimationUtils.loadAnimation(ctx,animation);
        Element.startAnimation(anim);
    }
}


Crashlytics中的排球错误

Fatal Exception: java.lang.NullPointerException
Attempt to invoke virtual method 'boolean java.lang.String.equals(java.lang.Object)' on a null object reference
com.orangevpninfo.orangevpn.SplashActivity$3.onResponse (SplashActivity.java:17)
com.android.volley.toolBox.JsonRequest.deliverResponse (JsonRequest.java:17)
com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run (ExecutorDelivery.java:2)
android.os.Handler.handleCallback (Handler.java:751)
android.os.Handler.dispatchMessage (Handler.java:95)
android.os.Looper.loop (Looper.java:154)
android.app.ActivityThread.main (ActivityThread.java:6138)
java.lang.reflect.Method.invoke (Method.java)
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:893)
com.android.internal.os.ZygoteInit.main (ZygoteInit.java:783)

AsyncHttpClient错误Crashlytics

Fatal Exception: java.lang.RuntimeException
java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String org.json.JSONObject.toString()' on a null object reference
com.loopj.android.http.AsyncHttpResponseHandler.onUserException (AsyncHttpResponseHandler.java:28)
com.loopj.android.http.AsyncHttpResponseHandler$ResponderHandler.handleMessage (AsyncHttpResponseHandler.java)
android.os.Handler.dispatchMessage (Handler.java:102)
android.os.Looper.loop (Looper.java:154)
android.app.ActivityThread.main (ActivityThread.java:6138)
java.lang.reflect.Method.invoke (Method.java)
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:893)
com.android.internal.os.ZygoteInit.main (ZygoteInit.java:783)
Caused by java.lang.NullPointerException
Attempt to invoke virtual method 'java.lang.String org.json.JSONObject.toString()' on a null object reference
com.orangevpninfo.orangevpn.SplashActivity$4.onFailure (SplashActivity.java)
com.loopj.android.http.JsonHttpResponseHandler.onFailure (JsonHttpResponseHandler.java:19)
com.loopj.android.http.AsyncHttpResponseHandler.handleMessage (AsyncHttpResponseHandler.java:19)
com.loopj.android.http.AsyncHttpResponseHandler$ResponderHandler.handleMessage (AsyncHttpResponseHandler.java)
android.os.Handler.dispatchMessage (Handler.java:102)
android.os.Looper.loop (Looper.java:154)
android.app.ActivityThread.main (ActivityThread.java:6138)
java.lang.reflect.Method.invoke (Method.java)
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:893)
com.android.internal.os.ZygoteInit.main (ZygoteInit.java:783)

解决方法

您收到的响应似乎为null或ver.getVersion()也可能返回null。由于ver.getVersion().equals(version)上有一个空指针异常。

您可以尝试的两种可能的方法-

  1. 您是否在发布时打开ProGaurd?如果是,请在Version模型类中添加规则或添加@Keep注释。

  2. 如果选中了第一步,则必须检查来自服务器的响应是否有效。检查有效响应始终是一个好习惯。只需添加if (response == null)并使用日志调试代码。