【发布时间】:2016-02-10 15:32:20
【问题描述】:
我正在使用改造库来检查登录凭据我包含响应的 php 文件如下 登录.php
...
if ($user["invalid credentials"] != "true"){
$response["error"] = FALSE;
$response["id"] = $user["credentials"]["admin_id"];
$response["username"] = $user["credentials"]["username"];
$response["password"] = $user["credentials"]["password"];
$response["email"] = $user["credentials"]["email"];
echo json_encode($response);
}
else {
$response["error"] = TRUE;
$response["error_msg"] = "Τα στοιχεία εισόδου είναι λάθος. Παρακαλώ ξαναπροσπάθησε.";
echo json_encode($response);
}
...
POJO 类
public class User {
private int id;
private String error, error_msg, username, email, password;
public String getError(){
return this.error;
}
public String getError_msg(){
return this.error_msg;
}
public int getId(){
return this.id;
}
public String getUsername(){
return this.username;
}
public String getPassword(){
return this.password;
}
public String getEmail(){
return this.email;
}
}
我的api服务接口,其中validateUser方法有用户输入的用户名和密码 接口服务
public interface ApiService {
@FormUrlEncoded
@POST("/login/login.php/")
Call<User> validateUser(@Field("username") String username, @Field("password") String password);
}
以及我创建 Retrofit 对象的 checkLogin 方法
private void checkLogin(String username, String password){
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(AppConfig.BASE_URL)
.addConverterFactory(GsonConverterFactory.create())
.build();
ApiService apiService = retrofit.create(ApiService.class);
Call<User> call = apiService.validateUser(username, password);
call.enqueue(new Callback<User>() {
@Override
public void onResponse(retrofit.Response<User> response, Retrofit retrofit) {
String email = response.body().getEmail();
Log.d(debugTag, "email: " + email);
}
@Override
public void onFailure(Throwable t) {
}
});
}
当我尝试获取用户的电子邮件时发生错误(如果凭据有效)。我得到一个空指针异常...我的 POJO 类有问题吗?
致命异常:主要 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem
E/AndroidRuntime:进程:com.votingsystem.tsiro.votingsystem,PID:21558 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem
E/AndroidRuntime: java.lang.NullPointerException 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem
E/AndroidRuntime:at com.votingsystem.tsiro.fragments.LoginFragment$4.onResponse(LoginFragment.java:175) 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem
E/AndroidRuntime:at retrofit.ExecutorCallAdapterFactory$ExecutorCallback$1.run(ExecutorCallAdapterFactory.java:86) 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem E/Android运行时:在 android.os.Handler.handleCallback(Handler.java:733) 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem E/AndroidRuntime:
在 android.os.Handler.dispatchMessage(Handler.java:95) 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem E/AndroidRuntime:在 android.os.Looper.loop(Looper.java:136) 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem E/Android运行时:在 android.app.ActivityThread.main(ActivityThread.java:5146) 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem E/AndroidRuntime:在 java.lang.reflect.Method.invokeNative(Native 方法)11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem E/AndroidRuntime:
在 java.lang.reflect.Method.invoke(Method.java:515) 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem E/AndroidRuntime:
在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:732) 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem E/Android运行时:在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:566) 11-09 22:51:06.152 21558-21558/com.votingsystem.tsiro.votingsystem E/AndroidRuntime: at dalvik.system.NativeStart.main(Native Method)
【问题讨论】:
-
发布异常的堆栈跟踪和您的网络服务的响应