Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

Программирование Android

Войти
Регистрация
Восстановить пароль
 
DeZik1
0 / 0 / 0
Регистрация: 08.09.2016
Сообщений: 19
#1

Возникает ошибка при запросе - Программирование Android

08.09.2016, 18:41. Просмотров 349. Ответов 13
Метки нет (Все метки)

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
package com.example.ks;
 
/**
 * Created by Denis on 08.09.2016.
 */
import java.util.ArrayList;
import java.util.List;
 
import com.example.ks.parser.JSONParser;
import org.apache.http.NameValuePair;
import org.apache.http.message.BasicNameValuePair;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
 
import android.app.Activity;
import android.app.ProgressDialog;
import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
 
public class EditProductActivity extends Activity {
 
    TextView txtData;
    TextView txtFio;
    TextView txtTel;
    TextView txtAddress;
    TextView txtComment;
    TextView txtStatus;
 
    Button btnPrinyat;
    Button btnOtmena;
    Button btnDone;
 
    String pid;
 
    private ProgressDialog pDialog;
 
    JSONParser jsonParser = new JSONParser();
 
    // url для получения одного продукта
    private static final String url_product_detials = "http://192.168.1.2/isp/m/get_product_details.php";
 
    // url для обновления продукта
    private static final String url_update_product = "http://test.devcolibri.com/update_product.php";
 
    // url для удаления продукта
    private static final String url_delete_product = "http://test.devcolibri.com/delete_product.php";
 
    // JSON параметры
    private static final String TAG_SUCCESS = "success";
    private static final String TAG_PRODUCT = "product";
    private static final String TAG_1 = "id";
    private static final String TAG_2 = "data";
    private static final String TAG_3 = "fio";
    private static final String TAG_4 = "tel";
    private static final String TAG_5 = "address";
    private static final String TAG_6 = "comment";
    private static final String TAG_7 = "status_id";
 
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.edit_product);
 
        btnPrinyat = (Button) findViewById(R.id.btnPrinyat);
        btnOtmena = (Button) findViewById(R.id.btnOtmena);
        btnDone = (Button) findViewById(R.id.btnDone);
 
        // показываем форму про детальную информацию о продукте
        Intent i = getIntent();
 
        // получаем id продукта (pid) с формы
        pid = i.getStringExtra(TAG_1);
 
        // Получение полной информации о продукте в фоновом потоке
        new GetProductDetails().execute();
 
        // обрабочик на кнопку сохранение продукта
        btnPrinyat.setOnClickListener(new View.OnClickListener() {
 
            @Override
            public void onClick(View arg0) {
                // запускаем выполнение задачи на обновление продукта
                new SaveProductDetails().execute();
            }
        });
 
        // обработчик на кнопку удаление продукта
        btnOtmena.setOnClickListener(new View.OnClickListener() {
 
            @Override
            public void onClick(View arg0) {
                // удалем продукт в фоновом потоке
                new DeleteProduct().execute();
            }
        });
 
    }
 
    /**
     * Фоновая асинхронная задача для получения полной информации о продукте
     **/
    class GetProductDetails extends AsyncTask<String, String, String> {
 
        /**
         * Перед началом показать в фоновом потоке прогресс диалог
         **/
        @Override
        protected void onPreExecute() {
            super.onPreExecute();
            pDialog = new ProgressDialog(EditProductActivity.this);
            pDialog.setMessage("Loading details. Please wait...");
            pDialog.setIndeterminate(false);
            pDialog.setCancelable(true);
            pDialog.show();
        }
 
        /**
         * Получение детальной информации о продукте в фоновом режиме
         **/
        protected String doInBackground(String[] params) {
 
            // обновляем UI форму
            runOnUiThread(new Runnable() {
                public void run() {
                    // проверяем статус success тега
                    int success;
                    try {
                        // Список параметров
                        List<NameValuePair> params = new ArrayList<NameValuePair>();
                        params.add(new BasicNameValuePair("pid", pid));
 
                        // получаем продукт по HTTP запросу
                        JSONObject json = jsonParser.makeHttpRequest(url_product_detials, "GET", params);
 
                        Log.d("Single Product Details", json.toString());
 
                        success = json.getInt(TAG_SUCCESS);
                        if (success == 1) {
                            // Успешно получинна детальная информация о продукте
                            JSONArray productObj = json.getJSONArray(TAG_PRODUCT);
 
                            // получаем первый обьект с JSON Array
                            JSONObject product = productObj.getJSONObject(0);
 
                            // продукт с pid найден
                            // Edit Text
                            txtData=(TextView) findViewById(R.id.EData);
                            txtFio=(TextView) findViewById(R.id.EFio);
                            txtTel=(TextView) findViewById(R.id.ETel);
                            txtAddress=(TextView) findViewById(R.id.EAddress);
                            txtComment=(TextView) findViewById(R.id.EComment);
                            txtStatus=(TextView) findViewById(R.id.EStatus);
 
                            // покаываем данные о продукте в EditText
                            txtData.setText(product.getString(TAG_2));
                            txtFio.setText(product.getString(TAG_3));
                            txtTel.setText(product.getString(TAG_4));
                            txtAddress.setText(product.getString(TAG_5));
                            txtComment.setText(product.getString(TAG_6));
                            txtStatus.setText(product.getString(TAG_7));
 
                        }else{
                            // продукт с pid не найден
                        }
                    } catch (JSONException e) {
                        e.printStackTrace();
                    }
                }
            });
 
            return null;
        }
 
        /**
         * После завершения фоновой задачи закрываем диалог прогресс
         **/
        protected void onPostExecute(String file_url) {
            // закрываем диалог прогресс
            pDialog.dismiss();
        }
    }
 
    /**
     * В фоновом режиме выполняем асинхроную задачу на сохранение продукта
     **/
    class SaveProductDetails extends AsyncTask<String, String, String> {
 
        /**
         * Перед началом показываем в фоновом потоке прогрксс диалог
         **/
        @Override
        protected void onPreExecute() {
            super.onPreExecute();
            pDialog = new ProgressDialog(EditProductActivity.this);
            pDialog.setMessage("Update ...");
            pDialog.setIndeterminate(false);
            pDialog.setCancelable(true);
            pDialog.show();
        }
 
        /**
         * Сохраняем продукт
         **/
        protected String doInBackground(String[] args) {
 
            // получаем обновленные данные с EditTexts
//            String name = txtName.getText().toString();
//            String price = txtPrice.getText().toString();
//            String description = txtDesc.getText().toString();
 
            // формируем параметры
            List<NameValuePair> params = new ArrayList<NameValuePair>();
//            params.add(new BasicNameValuePair(TAG_PID, pid));
//            params.add(new BasicNameValuePair(TAG_NAME, name));
//            params.add(new BasicNameValuePair(TAG_PRICE, price));
//            params.add(new BasicNameValuePair(TAG_DESCRIPTION, description));
 
            // отправляем измененные данные через http запрос
            JSONObject json = jsonParser.makeHttpRequest(url_update_product, "POST", params);
 
            // проверяем json success тег
            try {
                int success = json.getInt(TAG_SUCCESS);
 
                if (success == 1) {
                    // продукт удачно обнавлён
                    Intent i = getIntent();
                    // отправляем результирующий код 100 чтобы сообщить об обновлении продукта
                    setResult(100, i);
                    finish();
                } else {
                    // продукт не обновлен
                }
            } catch (JSONException e) {
                e.printStackTrace();
            }
 
            return null;
        }
 
        /**
         * После окончания закрываем прогресс диалог
         **/
        protected void onPostExecute(String file_url) {
            // закрываем прогресс диалог
            pDialog.dismiss();
        }
    }
 
    /**
     * Фоновая асинхронная задача на удаление продукта
     **/
    class DeleteProduct extends AsyncTask<String, String, String> {
 
        /**
         * На начале показываем прогресс диалог
         **/
        @Override
        protected void onPreExecute() {
            super.onPreExecute();
            pDialog = new ProgressDialog(EditProductActivity.this);
            pDialog.setMessage("уДАЛЕМ ПРОДУКТ...");
            pDialog.setIndeterminate(false);
            pDialog.setCancelable(true);
            pDialog.show();
        }
 
        /**
         * Удаление продукта
         **/
        protected String doInBackground(String[] args) {
 
            int success;
            try {
                List<NameValuePair> params = new ArrayList<NameValuePair>();
                params.add(new BasicNameValuePair("pid", pid));
 
                // получение продукта используя HTTP запрос
                JSONObject json = jsonParser.makeHttpRequest(url_delete_product, "POST", params);
 
                Log.d("Delete Product", json.toString());
 
                success = json.getInt(TAG_SUCCESS);
                if (success == 1) {
                    // Продукт удачно удален
                    Intent i = getIntent();
                    // отправляем результирующий код 100 для уведомления об удалении продукта
                    setResult(100, i);
                    finish();
                }
            } catch (JSONException e) {
                e.printStackTrace();
            }
 
            return null;
        }
 
        /**
         * После оконачния скрываем прогресс диалог
         **/
        protected void onPostExecute(String file_url) {
            pDialog.dismiss();
        }
    }
}
Ошибка такая
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
09-08 11:40:01.427 8168-8168/com.example.ks E/AndroidRuntime: FATAL EXCEPTION: main
                                                              Process: com.example.ks, PID: 8168
                                                              android.os.NetworkOnMainThreadException
                                                                  at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1145)
                                                                  at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
                                                                  at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
                                                                  at libcore.io.IoBridge.connect(IoBridge.java:112)
                                                                  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
                                                                  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
                                                                  at java.net.Socket.connect(Socket.java:843)
                                                                  at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
                                                                  at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
                                                                  at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
                                                                  at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
                                                                  at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
                                                                  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
                                                                  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
                                                                  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
                                                                  at com.example.ks.parser.JSONParser.makeHttpRequest(JSONParser.java:60)
                                                                  at com.example.ks.EditProductActivity$GetProductDetails$1.run(EditProductActivity.java:140)
                                                                  at android.os.Handler.handleCallback(Handler.java:733)
                                                                  at android.os.Handler.dispatchMessage(Handler.java:95)
                                                                  at android.os.Looper.loop(Looper.java:136)
                                                                  at android.app.ActivityThread.main(ActivityThread.java:5017)
                                                                  at java.lang.reflect.Method.invokeNative(Native Method)
                                                                  at java.lang.reflect.Method.invoke(Method.java:515)
                                                                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
                                                                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
                                                                  at dalvik.system.NativeStart.main(Native Method)
В манифесте класс объявлен

Не могу понять в чем проблема
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.09.2016, 18:41
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Возникает ошибка при запросе (Программирование Android):

Возникает ошибка при builder.parse - Программирование Android
Возникает ошибка 02-02 17:13:38.465: D/tagmy(32259): error org.xml.sax.SAXParseException: Unexpected token (position:TEXT . В чем может...

Возникает ошибка при попытке регистрации - Программирование Android
Здравствуйте, недавно начал изучать андроид, и его взаимодействие с php скриптом, а также БД MySQL. В интернете нашел урок по созданию...

При переходе между активити возникает ошибка - Программирование Android
Здравствуйте, уважаемые программисты! Не могли бы вы мне помочь? Дело в том, что при вызове активити в моем приложении возникает...

Ошибка в запросе к БД - Программирование Android
Есть класс для работы с БД, в нем организовал метод (GetUsers) выборки пользователей: public class DBHelper extends SQLiteOpenHelper...

Ошибка в запросе - Программирование Android
Нужен такой запрос: SELECT WORDRUS FROM WORd_level3 WHERE WORDENG=&quot;borrow&quot; (слово к примеру). При выполнении такого запроса в DB Browser...

Ошибка в POST запросе, retrofit2 googledrive - Программирование Android
Здравствуйте, хочу выполнить запрос На сохранение картинки на сервер GoogleDrive Api с помощью Retrofit2, помогите найти ошибку, ошибка в...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
DeZik1
0 / 0 / 0
Регистрация: 08.09.2016
Сообщений: 19
09.09.2016, 07:59  [ТС] #2
Все перерыл - ошибка в строке

C
1
                HttpResponse httpResponse = httpClient.execute(httpGet);
В чем проблема не могу понять...
C
1
2
                                                                    at com.example.ks.parser.JSONParser.makeHttpRequest(JSONParser.java:63)
                                                                    at com.example.ks.EditProductActivity$GetProductDetails$1.run(EditProductActivity.java:149)
Не ужели никто не может подсказать?
0
vxg
Модератор
3163 / 1966 / 221
Регистрация: 13.01.2012
Сообщений: 7,528
09.09.2016, 08:41 #3
DeZik1, в тексте ошибки прямо сказано - не выполняйте запрос в UI потоке - вынесете запрос в отдельный поток
0
DeZik1
0 / 0 / 0
Регистрация: 08.09.2016
Сообщений: 19
09.09.2016, 10:50  [ТС] #4
Я пока только разбираюсь с Android Studio
По-моему он и так в отдельном потоке.
C
1
class GetProductDetails extends AsyncTask<String, String, String>
В первом сообщении весь текст

Если я не прав, подскажите или пример дайте пожалуйста.
0
fraley
106 / 106 / 40
Регистрация: 24.05.2015
Сообщений: 320
09.09.2016, 11:16 #5
Цитата Сообщение от DeZik1 Посмотреть сообщение
В первом сообщении весь текст
Не вникал в код, но... в первом сообщение на 130 строчке runOnUiThread - это исполняется в основном потоке.
Из него вы же пытаетесь выполнять запрос - 140 строка jsonParser.makeHttpRequest.
0
vxg
Модератор
3163 / 1966 / 221
Регистрация: 13.01.2012
Сообщений: 7,528
09.09.2016, 11:18 #6
DeZik1, вы правы - в том тексте что вы дали все гладко однако смущает ваш пост где ошибка в строке
Java
1
HttpResponse httpResponse = httpClient.execute(httpGet)
которой в тексте как бы и нет.. может что то не копировалось или я плохо смотрю?
1
xaat
43 / 16 / 6
Регистрация: 05.12.2015
Сообщений: 65
09.09.2016, 11:20 #7
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
Ты запустил runOnUiThread(new Runnable(), выполнение кода в UI-потоке, а потом делаешь сетевые запросы
Java
1
2
 // получаем продукт по HTTP запросу
                        JSONObject json = jsonParser.makeHttpRequest(url_product_detials, "GET", params);
1
DeZik1
0 / 0 / 0
Регистрация: 08.09.2016
Сообщений: 19
09.09.2016, 11:41  [ТС] #8
А как тогда правильно написать?
0
xaat
43 / 16 / 6
Регистрация: 05.12.2015
Сообщений: 65
09.09.2016, 11:46 #9
выкинь runOnUiThread, оставь в doInBackground только сетевой запрос, это все вынеси в onPostExecute

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// Успешно получинна детальная информация о продукте
                            JSONArray productObj = json.getJSONArray(TAG_PRODUCT);
 
                            // получаем первый обьект с JSON Array
                            JSONObject product = productObj.getJSONObject(0);
 
                            // продукт с pid найден
                            // Edit Text
                            txtData=(TextView) findViewById(R.id.EData);
                            txtFio=(TextView) findViewById(R.id.EFio);
                            txtTel=(TextView) findViewById(R.id.ETel);
                            txtAddress=(TextView) findViewById(R.id.EAddress);
                            txtComment=(TextView) findViewById(R.id.EComment);
                            txtStatus=(TextView) findViewById(R.id.EStatus);
 
                            // покаываем данные о продукте в EditText
                            txtData.setText(product.getString(TAG_2));
                            txtFio.setText(product.getString(TAG_3));
                            txtTel.setText(product.getString(TAG_4));
                            txtAddress.setText(product.getString(TAG_5));
                            txtComment.setText(product.getString(TAG_6));
                            txtStatus.setText(product.getString(TAG_7));
2
DeZik1
0 / 0 / 0
Регистрация: 08.09.2016
Сообщений: 19
09.09.2016, 12:14  [ТС] #10
Еще раз спасибо. Сделал )))

А вопрос такой - как обновить форму?
0
xaat
43 / 16 / 6
Регистрация: 05.12.2015
Сообщений: 65
09.09.2016, 12:20 #11
Цитата Сообщение от DeZik1 Посмотреть сообщение
А вопрос такой - как обновить форму?
А что и когда с ней должно происходить?
0
DeZik1
0 / 0 / 0
Регистрация: 08.09.2016
Сообщений: 19
09.09.2016, 21:35  [ТС] #12
Допустим после обновления БД при возвращении в предыдущее активити - обновлять
0
REALIST07
Автор FAQ
Автор FAQ
176 / 176 / 13
Регистрация: 11.06.2010
Сообщений: 932
10.09.2016, 20:04 #13
Используй broadcastReceiver как вариант? смысл в том, чтобы послать самому себе сообщение в активити
Java
1
2
3
4
public  boolean sendLocalBroadcastMessage(String action) {
        Intent sendIntent = new Intent(action);
        return LocalBroadcastManager.getInstance(context).sendBroadcast(sendIntent);
    }
1) После обновления вызываешь так:
Java
1
 sendLocalBroadcastMessage("REFRESH");
2) В своем активити ловишь вот так:
Java
1
2
3
4
5
6
7
8
9
10
11
Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
 
        LocalBroadcastManager.getInstance(getApplicationContext()).registerReceiver(new BroadcastReceiver() {
            @Override
            public void onReceive(Context context, Intent intent) {
                // тут обновляешь свои данные в активити
            }
        },"REFRESH");
0
DeZik1
0 / 0 / 0
Регистрация: 08.09.2016
Сообщений: 19
11.09.2016, 19:41  [ТС] #14
А еще вопрос в рамках данной ошибки как вынести json полученный в бэкграудне в PostExecute, надо его туда перенести, я это понял, но как это сделать не понимаю

Добавлено через 19 часов 28 минут
Я правильно дкмаю

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public class CategoryTask extends AsyncTask<Void, String, String> {
...
    @Override
    public String doInBackground(Void... params) {
            JSONObject json = jParser.makeHttpRequest(url_all_products, "POST", params);
            try {
                int success = json.getInt(TAG_SUCCESS);
                if (success == 1) {
                  return json.toString()
...
 
        protected void onPostExecute(String strProduct) {
           super.onPostExecute(strProduct);
           try {                           
           JSONArray product = new JSONArray(strProduct);
???

Добавлено через 3 часа 2 минуты
на последнюю строку ругается

C
1
Error:(290, 33) error: cannot find symbol method JSONObject(String)
Добавлено через 38 минут
Сам тупой - разобрался
Надо было использовать
try {
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.09.2016, 19:41
Привет! Вот еще темы с ответами:

Крашиться при запросе String number = c.getString(c.getColumnIndex("address"); - Программирование Android
http://rghost.ru/6FKfffYZG крашится на 88 строке почему? проект - http://rghost.ru/6FKfffYZG package com.vrs.smsapp;

Ошибка при загрузки изображений с карты памяти при повороте экрана - Программирование Android
Здравствуйте! Вопрос в следующем. Загружаю в активити фотки с камеры. Имя файла передаю следующим кодом: Intent captureIntent = new...

Ошибка при запуске AsyncTask при нажатии на пункт ActionBar - Программирование Android
Здравствуйте, почему при нажатии на пункт Action Bar'а вылетает ошибка? @Override public boolean onCreateOptionsMenu(Menu menu)...

При запросе на php возникает ошибка - PHP
Добрый день всем участникам! Облазил весь интернет, но так и не нашел, что можно поправить в моем случае. *Сразу говорю, в php не...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
11.09.2016, 19:41
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru