Подтвердить что ты не робот

Используйте JsonReader.setLenient(true), чтобы принять неверный JSON в строке 1, столбец 1 путь $

Что это за ошибка? Как я могу это исправить? Мое приложение работает, но не может загрузить данные. И это моя ошибка: используйте JsonReader.setLenient(true), чтобы принять искаженный JSON в строке 1, путь 1, столбец $

Это мой фрагмент:

public class news extends Fragment {


private RecyclerView recyclerView;
private ArrayList<Deatails> data;
private DataAdapter adapter;
private View myFragmentView;



@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {

    myFragmentView = inflater.inflate(R.layout.news, container, false);
    initViews();
    return myFragmentView;

}


private void initViews() {
    recyclerView = (RecyclerView) myFragmentView.findViewById(R.id.card_recycler_view);
    RecyclerView.LayoutManager layoutManager = new LinearLayoutManager(getActivity().getApplicationContext());
    recyclerView.setHasFixedSize(true);
    recyclerView.setLayoutManager(layoutManager);
    data = new ArrayList<Deatails>();
    adapter = new DataAdapter(getActivity(), data);
    recyclerView.setAdapter(adapter);

    new Thread()
    {
        public void run()
        {
            getActivity().runOnUiThread(new Runnable() {
                @Override
                public void run() {
                    loadJSON();
                }
            });

        }
    }
    .start();
}

private void loadJSON() {
    if (isNetworkConnected()){

        HttpLoggingInterceptor interceptor = new HttpLoggingInterceptor();
        interceptor.setLevel(HttpLoggingInterceptor.Level.BODY);
        OkHttpClient client = new OkHttpClient.Builder()
                .addInterceptor(interceptor)
                .retryOnConnectionFailure(true)
                .connectTimeout(15, TimeUnit.SECONDS)
                .build();

        Gson gson = new GsonBuilder()
                .setLenient()
                .create();

        Retrofit retrofit = new Retrofit.Builder()
                .baseUrl("http://www.memaraneha.ir/")
                .client(client)
                .addConverterFactory(GsonConverterFactory.create(gson))
                .build();

        RequestInterface request = retrofit.create(RequestInterface.class);
        Call<JSONResponse> call = request.getJSON();
        final ProgressDialog progressDialog = new ProgressDialog(getActivity());
        progressDialog.show();
        call.enqueue(new Callback<JSONResponse>() {
            @Override
            public void onResponse(Call<JSONResponse> call, Response<JSONResponse> response) {
                progressDialog.dismiss();
                JSONResponse jsonResponse = response.body();
                data.addAll(Arrays.asList(jsonResponse.getAndroid()));
                adapter.notifyDataSetChanged();
            }
            @Override
            public void onFailure(Call<JSONResponse> call, Throwable t) {
                progressDialog.dismiss();
                Log.d("Error", t.getMessage());
            }
        });
    }
    else {
        Toast.makeText(getActivity().getApplicationContext(), "Internet is disconnected", Toast.LENGTH_LONG).show();}
}
private boolean isNetworkConnected() {
    ConnectivityManager cm = (ConnectivityManager) getActivity().getSystemService(Context.CONNECTIVITY_SERVICE);
    NetworkInfo ni = cm.getActiveNetworkInfo();
    if (ni == null) {
        // There are no active networks.
        return false;
    } else
        return true;
}
}

RequestInterface:

public interface RequestInterface {

@GET("Erfan/news.php")
Call<JSONResponse> getJSON();
}

a

UPDATE

всегда эта ошибка не о вашем JSON, это может стать вашей ошибкой запрос, для лучшей обработки сначала проверьте ваш запрос в почтальоне, если вы получили ответ, затем сравните ваш ответ json с вашей моделью, если ничего не неправильно, то эта ошибка возникает из-за вашего неправильного запроса, также это может произойти, когда ваш ответ не josn (в некоторых случаях ответ возможно это HTML)

4b9b3361

Ответ 1

Это хорошо известная проблема, и на основе этого ответа вы можете добавить setLenient:

Gson gson = new GsonBuilder()
        .setLenient()
        .create();

Retrofit retrofit = new Retrofit.Builder()
        .baseUrl(BASE_URL)
        .client(client)
        .addConverterFactory(GsonConverterFactory.create(gson))
        .build();

Теперь, если вы добавите это в свою модификацию, это даст вам еще одну ошибку:

com.google.gson.JsonSyntaxException: java.lang.IllegalStateException: Expected BEGIN_OBJECT but was STRING at line 1 column 1 path $

Это еще одна общеизвестная ошибка, вы можете найти ответ здесь (эта ошибка означает, что ответ вашего сервера не отформатирован); Поэтому измените ответ сервера, чтобы вернуть что-то:

{
    android:[
        { ver:"1.5", name:"Cupcace", api:"Api Level 3" }
        ...
    ]
}

Для лучшего понимания сравните ваш ответ с Github api.

Предложение: чтобы узнать, что происходит с вашим request/response добавьте HttpLoggingInterceptor в вашу модификацию.

На основании этого ответа ваш ServiceHelper будет:

private ServiceHelper() {
        httpClient = new OkHttpClient.Builder();
        HttpLoggingInterceptor interceptor = new HttpLoggingInterceptor();
        interceptor.setLevel(HttpLoggingInterceptor.Level.BODY);
        httpClient.interceptors().add(interceptor);
        Retrofit retrofit = createAdapter().build();
        service = retrofit.create(IService.class);
    }

Также не забудьте добавить:

compile 'com.squareup.okhttp3:logging-interceptor:3.3.1'

Ответ 2

Также эта проблема возникает, когда тип содержимого ответа не является application/json. В моем случае тип содержимого ответа был text/html и я столкнулся с этой проблемой. Я изменил его на application/json после чего он заработал.

Ответ 3

У меня была та же проблема, что и у fooobar.com/questions/16346121/..., и обе они были исправлены после исправления google-services.json

Ответ 4

Произошла ошибка в понимании типа возврата. Просто добавьте заголовок, и это решит вашу проблему.

@Headers("Content-Type: application/json")

Ответ 5

В моем случае; что решило мою проблему было.....

Вы можете иметь json, как это, ключи без " двойных кавычек....

{имя: "тест", телефон: "2324234"}

Так что попробуйте любой онлайн Json Validator, чтобы убедиться, что у вас правильный синтаксис...

Json Validator Online

Ответ 6

Я столкнулся с этой проблемой, и я сделал исследование и ничего не получил, поэтому я пытался и, наконец, знал причину этой проблемы. проблема с API, убедитесь, что у вас есть хорошее имя переменной Я использовал $start_date, и это вызвало проблему, поэтому я пытаюсь запустить startdate и работает!

также убедитесь, что вы отправляете все параметры, объявляющие API, например, $ startdate = $_POST ['startdate']; $ enddate = $_POST ['enddate'];

вам нужно передать эту две переменные из модификации.

если вы используете дату в операторе SQL, попробуйте поместить ее в ' например '2017-07-24'

Надеюсь, это поможет вам.

Ответ 7

добавить "/" перед именем api, например

@FormUrlEncoded //to send string data just
@POST("/getMatches")
Call<ResultModelMatches> getMatches(

    @Field("accessToken") String accessToken,
    //08/07/2017
    @Field("date") String date,
    @Field("is_android") int is_android

);

Ответ 8

если ваши форматы JSON в порядке, проверьте запросы к базе данных. Попробуйте изменить их и повторите попытку

Ответ 9

Эта проблема начала возникать у меня внезапно, поэтому я был уверен, что может быть какая-то другая причина. При глубоком копании это была простая проблема, когда я использовал http в BaseUrl Retrofit вместо https. Поэтому изменение его на https решило проблему для меня.

Ответ 10

Также стоит проверить, есть ли какие-либо ошибки в типе возврата методов вашего интерфейса. Я мог бы воспроизвести эту проблему, имея непредвиденный тип возврата, например Call<Call<ResponseBody>>