Android截击响应未给出错误

Android截击响应未给出错误,android,android-volley,Android,Android Volley,我正在尝试使用截击进行用户登录和注册,但在尝试登录或注册时遇到问题。我尝试连接的服务器位于我的本地主机上,它已打开并工作,我可以从其他应用程序访问它 当我输入登录/注册的凭据并按下按钮时,我得到一个日志,说明错误消息为空。问题是应用程序没有崩溃,日志猫也没有指向任何导致错误的行,所以我不知道到底出了什么问题 我尝试了不同的截击错误方法,如error.networkResponse和其他一些方法,试图获取更多信息,但没有返回任何信息 我在网站上看到了其他解决类似问题的方法,但似乎没有任何效果 有人

我正在尝试使用截击进行用户登录和注册,但在尝试登录或注册时遇到问题。我尝试连接的服务器位于我的本地主机上,它已打开并工作,我可以从其他应用程序访问它

当我输入登录/注册的凭据并按下按钮时,我得到一个日志,说明错误消息为空。问题是应用程序没有崩溃,日志猫也没有指向任何导致错误的行,所以我不知道到底出了什么问题

我尝试了不同的截击错误方法,如
error.networkResponse
和其他一些方法,试图获取更多信息,但没有返回任何信息

我在网站上看到了其他解决类似问题的方法,但似乎没有任何效果

有人能解释一下我为什么会犯这个错误吗

记录cat日志

Login Error: null
打印日志类-登录活动

import android.app.Activity;
    import android.app.ProgressDialog;
    import android.content.Intent;
    import android.os.Bundle;
    import android.util.Log;
    import android.view.View;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.Toast;

    import com.android.volley.Request.Method;
    import com.android.volley.Response;
    import com.android.volley.VolleyError;
    import com.android.volley.toolbox.StringRequest;

    import org.json.JSONException;
    import org.json.JSONObject;

    import java.util.HashMap;
    import java.util.Map;

    import com.example.rory.pocketchef.R;
    import com.example.rory.pocketchef.app.AppConfig;
    import com.example.rory.pocketchef.app.AppController;
    import com.example.rory.pocketchef.helper.SQLiteHandler;
    import com.example.rory.pocketchef.helper.SessionManager;

    public class LoginActivity extends Activity {
        private static final String TAG = RegisterActivity.class.getSimpleName();
        private Button btnLogin;
        private Button btnLinkToRegister;
        private EditText inputEmail;
        private EditText inputPassword;
        private ProgressDialog pDialog;
        private SessionManager session;
        private SQLiteHandler db;

        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_login);

            inputEmail = (EditText) findViewById(R.id.email);
            inputPassword = (EditText) findViewById(R.id.password);
            btnLogin = (Button) findViewById(R.id.btnLogin);
            btnLinkToRegister = (Button) findViewById(R.id.btnLinkToRegisterScreen);

            // Progress dialog
            pDialog = new ProgressDialog(this);
            pDialog.setCancelable(false);

            // SQLite database handler
            db = new SQLiteHandler(getApplicationContext());

            // Session manager
            session = new SessionManager(getApplicationContext());

            // Check if user is already logged in or not
            if (session.isLoggedIn()) {
                // User is already logged in. Take him to main activity
                Intent intent = new Intent(LoginActivity.this, FirstActivity.class);
                startActivity(intent);
                finish();
            }

            // Login button Click Event
            btnLogin.setOnClickListener(new View.OnClickListener() {

                public void onClick(View view) {
                    String email = inputEmail.getText().toString().trim();
                    String password = inputPassword.getText().toString().trim();

                    // Check for empty data in the form
                    if (!email.isEmpty() && !password.isEmpty()) {
                        // login user
                        checkLogin(email, password);
                    } else {
                        // Prompt user to enter credentials
                        Toast.makeText(getApplicationContext(),
                                "Please enter the credentials!", Toast.LENGTH_LONG)
                                .show();
                    }
                }

            });

            // Link to Register Screen
            btnLinkToRegister.setOnClickListener(new View.OnClickListener() {

                public void onClick(View view) {
                    Intent i = new Intent(getApplicationContext(),
                            RegisterActivity.class);
                    startActivity(i);
                    finish();
                }
            });

        }

        /**
         * function to verify login details in mysql db
         * */
        private void checkLogin(final String email, final String password) {
            // Tag used to cancel the request
            String tag_string_req = "req_login";

            pDialog.setMessage("Logging in ...");
            showDialog();

            StringRequest strReq = new StringRequest(Method.POST,
                    AppConfig.URL_LOGIN, new Response.Listener<String>() {

                @Override
                public void onResponse(String response) {
                    Log.d(TAG, "Login Response: " + response.toString());
                    hideDialog();

                    try {
                        JSONObject jObj = new JSONObject(response);
                        boolean error = jObj.getBoolean("error");

                        // Check for error node in json
                        if (!error) {
                            // user successfully logged in
                            // Create login session
                            session.setLogin(true);

                            // Now store the user in SQLite
                            String uid = jObj.getString("uid");

                            JSONObject user = jObj.getJSONObject("user");
                            String name = user.getString("name");
                            String email = user.getString("email");
                            String created_at = user
                                    .getString("created_at");

                            // Inserting row in users table
                            db.addUser(name, email, uid, created_at);

                            // Launch main activity
                            Intent intent = new Intent(LoginActivity.this, FirstActivity.class);
                            startActivity(intent);
                            finish();
                        } else {
                            // Error in login. Get the error message
                            String errorMsg = jObj.getString("error_msg");
                            Toast.makeText(getApplicationContext(),
                                    errorMsg, Toast.LENGTH_LONG).show();
                        }
                    } catch (JSONException e) {
                        // JSON error
                        e.printStackTrace();
                        Toast.makeText(getApplicationContext(), "Json error: " + e.getMessage(), Toast.LENGTH_LONG).show();
                    }

                }
            }, new Response.ErrorListener() {

                @Override
                public void onErrorResponse(VolleyError error) {
                    Log.e(TAG, "Login Error: " + error.getMessage());
                    Toast.makeText(getApplicationContext(),
                            error.getMessage(), Toast.LENGTH_LONG).show();
                    hideDialog();
                }
            }) {

                @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
            AppController.getInstance().addToRequestQueue(strReq, tag_string_req);
        }

        private void showDialog() {
            if (!pDialog.isShowing())
                pDialog.show();
        }

        private void hideDialog() {
            if (pDialog.isShowing())
                pDialog.dismiss();
        }
    }
日志Cat打印堆栈

02-25 12:28:17.680 9729-9729/com.example.rory.pocketchef W/System.err: com.android.volley.TimeoutError
02-25 12:28:17.680 9729-9729/com.example.rory.pocketchef W/System.err:     at com.android.volley.toolbox.BasicNetwork.performRequest(BasicNetwork.java:147)
02-25 12:28:17.680 9729-9729/com.example.rory.pocketchef W/System.err:     at com.android.volley.NetworkDispatcher.run(NetworkDispatcher.java:114)
02-25 12:28:28.391 9729-9743/com.example.rory.pocketchef I/art: Background sticky concurrent mark sweep GC freed 32313(1656KB) AllocSpace objects, 2(40KB) LOS objects, 35% free, 15MB/23MB, paused 9.512ms total 135.206ms
getMessage()
有时可以为null。这就是我如何阅读volley onErrorResponse(),volley有如下直接/次直接异常类

已知的直接子类
AuthFailureError、NetworkError、ParseError、ServerError、TimeoutError

已知的间接子类
无连接错误

使用
instanceOf

if(error instanceof TimeOutError)
   *show timeout error occured*
else if(error instanceof ServerError)
   *show server error occured*
same for others 
我尝试过不同的截击错误方法,如error.networkResponse

是的,读取错误响应也很好,您可以确定服务器端到底发生了什么。(服务器端发生错误时,服务器必须返回错误响应) 别忘了读书
错误。网络响应。状态代码也

要获取有关此访问的更多信息,请访问

更新
在本地机器服务器上工作时:要记住的事项

  • 始终使用系统IP地址(而不是本地主机)
  • 确保本地路径正确
  • 始终在浏览器上测试API/URL,或者检查并移动到Android项目。 在使用这些东西进行测试时,您可以解决许多服务器错误

  • 经过多次失败的尝试,在巴拉特的帮助下,我找到了问题的症结所在

    我在截击命令中使用了错误的IP地址。我没有使用通过在命令行中键入
    ifconfig
    找到的机器IP地址。添加正确的IP地址是解决方案


    因此,向其他有相同问题的人发出警告,请使用
    ifcong
    查找IP地址,而不要在谷歌上搜索
    我的IP是什么
    ,因为这不会返回机器的IP地址。

    你的url是什么?您是否在使用模拟器?
    错误。getMessage()
    返回空值
    error
    本身不是空的?错误。getMessage()打印
    null
    ,我的URL是我的IP地址是我的IP地址,后跟
    :8888/android\u login\u api/login.php
    ,但我已经三次检查过了,知道这是正确的,当你说你可以用其他应用程序访问它时,你是指其他android应用程序吗?如果您使用一台设备来尝试您的服务器,并且如果您的设备与您的计算机连接到同一个wifi点,那么您的ip大约为192.x.x.x,对吗?你说你的服务器是localWell,我正在尝试实现一个用户登录和注册功能,所以我遵循了一个教程,使其工作正常,现在我正试图将其添加到现有的应用程序中,这是我开始出现错误的时候。是的,我用IP地址尝试了所有常用的东西,确保所有东西都正确连接,但在运行
    错误。getClass()
    后,我发现这是一个
    TimeoutError
    ,对如何解决这个问题有何建议?重试请求并设置更多时间来请求连接TimeOutoops.:(我试着在浏览器中点击,猜猜怎么着,我得到了
    ConnectionTimeout
    错误。我认为服务器端出了问题。我教了它的公共服务器:)
    public void onErrorResponse(VolleyError error){error.printStackTrace();}
    结果将打印在
    logcat
    选项卡中。让我们来看看。
    02-25 12:09:19.558 20001-20001/com.example.rory.loginandregistration E/RegisterActivity: Login Error: null
    02-25 12:09:19.579 20001-20001/com.example.rory.loginandregistration D/Volley: [1] Request.finish: 7636 ms: [ ] http://178.167.255.22:8886/android_login_api/login.php 0x1d219ab4 NORMAL 1
    
    02-25 12:28:17.680 9729-9729/com.example.rory.pocketchef W/System.err: com.android.volley.TimeoutError
    02-25 12:28:17.680 9729-9729/com.example.rory.pocketchef W/System.err:     at com.android.volley.toolbox.BasicNetwork.performRequest(BasicNetwork.java:147)
    02-25 12:28:17.680 9729-9729/com.example.rory.pocketchef W/System.err:     at com.android.volley.NetworkDispatcher.run(NetworkDispatcher.java:114)
    02-25 12:28:28.391 9729-9743/com.example.rory.pocketchef I/art: Background sticky concurrent mark sweep GC freed 32313(1656KB) AllocSpace objects, 2(40KB) LOS objects, 35% free, 15MB/23MB, paused 9.512ms total 135.206ms
    
    if(error instanceof TimeOutError)
       *show timeout error occured*
    else if(error instanceof ServerError)
       *show server error occured*
    same for others