it-swarm.com.ru

Используйте 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(), "دستگاه شما به اینترنت متصل نیست!", 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

Обновление

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

56
erfan

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

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

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

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

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'
97
Amir

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

7
Ali Gürelli

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

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

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

0
Shabbir Ahmed

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

0
Shubhral

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

У вас может быть такой json, ключи без кавычек "double ....

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

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

Json Validator Online

0
shareef

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

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

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

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

Я надеюсь, что это поможет вам.

0
Momen Zaqout