Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/218.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
尽管查询参数正确,但在android studio中使用改型2获取请求似乎不起作用_Android_Retrofit_Gson - Fatal编程技术网

尽管查询参数正确,但在android studio中使用改型2获取请求似乎不起作用

尽管查询参数正确,但在android studio中使用改型2获取请求似乎不起作用,android,retrofit,gson,Android,Retrofit,Gson,我在Android Studio中使用改型2来获取站点信息 来自CUMTDAPI的JSON表单用于停止,出于某种原因,我得到了以下错误java.lang.NullPointerException:尽管我的get请求和查询参数正常,但尝试在空对象引用上调用接口方法“java.lang.Object java.util.List.get(int)” 我的MTD api接口: import java.util.List; import retrofit2.Call; import retrofit2.

我在Android Studio中使用改型2来获取站点信息 来自CUMTDAPI的JSON表单用于停止,出于某种原因,我得到了以下错误java.lang.NullPointerException:尽管我的get请求和查询参数正常,但尝试在空对象引用上调用接口方法“java.lang.Object java.util.List.get(int)”

我的MTD api接口:

import java.util.List;
import retrofit2.Call;
import retrofit2.Retrofit;
import retrofit2.converter.gson.GsonConverterFactory;
import retrofit2.http.GET;
import retrofit2.http.Path;
import retrofit2.http.Query;

/**
 * Class that details the request(s) that we will call
 */

public interface MTDApi{
    @GET("GetStops")
    Call<List<UserModel>> loadStops(
            @Query("api_key") String key,
            @Query("stop name") String stop
    );

    Retrofit retrofit = new Retrofit.Builder()
            .baseUrl("https://developer.cumtd.com/api/v2.2/json/")
            .addConverterFactory(GsonConverterFactory.create())
            .build();

}
我的主要活动:

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;

import java.util.List;
import java.util.Random;

import retrofit2.Call;
import retrofit2.Callback;
import retrofit2.Response;

import static android.R.attr.x;
import static android.media.CamcorderProfile.get;
import static com.example.neelpatel.weatherapp.MTDApi.retrofit;

public class MainActivity extends AppCompatActivity {

    String key= "<APIKEY>";
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);//Starts Retrofit
        final MTDApi mtdApi = MTDApi.retrofit.create(MTDApi.class);

        //Sets up Button and EditText for use in this class
        final EditText edit = (EditText) findViewById(R.id.edit);
        Button requestButton = (Button) findViewById(R.id.button);

        //Behavior once button is clicked
        requestButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                String s = edit.getText().toString();
                //Sets up up the API call
                Call<List<UserModel>> call = mtdApi.loadStops(key,s);

                //Runs the call on a different thread
                call.enqueue(new Callback<List<UserModel>>() {
                    @Override
                    //Once the call has finished

                public void onResponse(Call<List<UserModel>> call, Response<List<UserModel>> response) {
                    //Gets the list of stops
                    List<UserModel> stops = response.body();
                    String text = stops.get(0).getStop_id();
                    edit.setText(text);
                }

                    @Override
                    //If the call failed
                    public void onFailure(Call<List<UserModel>> call, Throwable t) {
                        edit.setText("Request Failed");
                        Log.e("RequestCall", "Request failed");
                    }
                });
            }
        });
    }
}
导入android.support.v7.app.app活动;
导入android.os.Bundle;
导入android.util.Log;
导入android.view.view;
导入android.widget.Button;
导入android.widget.EditText;
导入android.widget.TextView;
导入java.util.List;
导入java.util.Random;
2.电话;;
2.回拨;
2.回应;;
导入静态android.R.attr.x;
导入静态android.media.CamcorderProfile.get;
导入静态com.example.neelpatel.weatherapp.MTDApi.reformation;
公共类MainActivity扩展了AppCompatActivity{
字符串键=”;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);//开始改装
final MTDApi MTDApi=MTDApi.reformation.create(MTDApi.class);
//设置此类中使用的按钮和编辑文本
最终编辑文本编辑=(编辑文本)findViewById(R.id.edit);
按钮请求按钮=(按钮)findViewById(R.id.Button);
//单击按钮后的行为
requestButton.setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图v){
字符串s=edit.getText().toString();
//设置API调用
Call Call=mtdApi.loadStops(键,s);
//在其他线程上运行调用
call.enqueue(新回调(){
@凌驾
//通话结束后
公共void onResponse(调用、响应){
//获取站点列表
List stops=response.body();
String text=stops.get(0.getStop_id();
edit.setText(文本);
}
@凌驾
//如果呼叫失败
失败时公共无效(调用调用,可丢弃的t){
edit.setText(“请求失败”);
Log.e(“请求调用”、“请求失败”);
}
});
}
});
}
}
My activity_main.xml:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.neelpatel.weatherapp.MainActivity">

    <EditText
        android:id="@+id/edit"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_above="@+id/button"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true"
        android:layout_marginBottom="133dp" />

    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Request"
        tools:layout_editor_absoluteX="16dp"
        tools:layout_editor_absoluteY="16dp"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:layout_marginBottom="95dp" />

</RelativeLayout>

在onResponse中,您应该检查该响应。isSuccessful()并检查是否停止!=无效的您的服务器似乎返回了错误。

首先,您应该始终检查响应是否成功(即,它在[200,300]HTTP状态代码范围内)。您可以在
onResponse(…)
方法中执行此操作:

 public void onResponse(Call<List<UserModel>> call, Response<List<UserModel>> response) {
      if (response.isSuccessful()) {
           //Gets the list of stops
           List<UserModel> stops = response.body();
           String text = stops.get(0).getStop_id();
           edit.setText(text);
      } else {
           // show error message
      }
 }
还值得一提的是,您的预期响应与中显示的实际响应结构不匹配。如果您不想手动创建该结构,可以使用JSON到POJO转换器,例如,您可以使用它将示例转换为适当的POJO模型结构。

根据ver返回一个JSON对象,而不是JSON数组,正如您在改型界面中编写类型
列表时所期望的那样。您需要的数组是对象中的
stops
字段,因此您可能需要:

  • 创建一个与返回的JSON对象匹配的POJO,并从中获取数组
  • 创建自定义Gson反序列化器,如中所述

将堆栈跟踪添加到您的问题中,而不仅仅是错误消息。它显示参数的api键,因此我不能将api键作为字符串传递给它?我在回答中澄清了这一部分。还要注意,您预期的模型结构与实际响应的结构不匹配。因此,我应该在主activ中向方法添加键那么当我调用loadstops时,您现在可以通过调用
mtdApi.loadstops(key,s)来执行此操作
。唯一的问题是你不再需要
s
参数。但是我看到你想做某种搜索。你不应该改为使用吗?是的,我把它改为getstopsbysearch这是新问题的链接,显然我现在因为某种原因无法连接,你介意看看这个问题中的代码吗N
 public void onResponse(Call<List<UserModel>> call, Response<List<UserModel>> response) {
      if (response.isSuccessful()) {
           //Gets the list of stops
           List<UserModel> stops = response.body();
           String text = stops.get(0).getStop_id();
           edit.setText(text);
      } else {
           // show error message
      }
 }
@GET("GetStops")
Call<List<UserModel>> loadStops(@Query("key") String key);