2016-08-17 1 views
1

У меня возникли проблемы.android app urlconnection получить запрос не работает

Я не могу понять, почему следующий код не будет работать.

Это простое приложение, которое отправляет запрос GET на некоторый php-фрагмент, который должен вставлять строку в таблицу.

Я не могу понять, почему это не работает.

Пожалуйста, помогите.

Java:

package com.example.michael.biyum; 

import android.app.AlertDialog; 
import android.support.v7.app.AppCompatActivity; 
import android.os.Bundle; 
import android.view.View; 
import android.widget.Button; 
import android.widget.TextView; 
import android.widget.Toast; 

import java.io.InputStream; 
import java.io.InputStreamReader; 
import java.net.HttpURLConnection; 
import java.net.URL; 

public class MainActivity extends AppCompatActivity { 


@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(this); 
    final AlertDialog alertDialog = alertDialogBuilder.create(); 
    Button startBtn = (Button) findViewById(R.id.btn); 
    final TextView t = (TextView) findViewById(R.id.hello); 
    startBtn.setOnClickListener(new View.OnClickListener() { 
     public void onClick(View v) { 
      URL url; 
      HttpURLConnection urlConnection = null; 
      try { 
       url = new URL("http://www.chatty.co.il/biyum.php?q=mkyong"); 
       urlConnection = (HttpURLConnection) url.openConnection(); 
       InputStream in = urlConnection.getInputStream(); 
       InputStreamReader isw = new InputStreamReader(in); 
       int data = isw.read(); 
       while (data != -1) { 
        char current = (char) data; 
        data = isw.read(); 
      Toast.makeText(getApplicationContext(),"GET:"+current,Toast.LENGTH_LONG).show(); 
        System.out.print(current); 
       } 
      } catch (Exception e) { 
       e.printStackTrace(); 
      } finally { 
       if (urlConnection != null) { 
        urlConnection.disconnect(); 
       } 
      } 
     } 


    }); 
    } 
} 

PHP:

<?php 
require('connect.inc.php'); 
$update_offline="INSERT INTO offline_waiters (user_partner,mail,chat_room) VALUES(0,'gavno','gavno')"; 
$query_run= mysqli_query($conn,$update_offline); 

echo "new"; 



?> 

Это простой тест, который должен ввести новую строку в моей таблице.

Когда я делаю запрос вручную через браузер, он отлично работает.

Еще раз, пожалуйста, помогите мне понять, в чем проблема.

ответ

1

Вам необходимо отключить сетевую операцию от основной нити.

Я только что получил эту работу и тестирование с использованием AsyncTask:

class MyAsyncTask extends AsyncTask<Void, Void, String> { 

    @Override 
    protected String doInBackground(Void... params) { 
     StringBuilder result = new StringBuilder(); 
     URL url; 
     HttpURLConnection urlConnection = null; 
     try { 
      url = new URL("http://www.chatty.co.il/biyum.php?q=mkyong"); 
      urlConnection = (HttpURLConnection) url.openConnection(); 
      InputStream in = urlConnection.getInputStream(); 
      InputStreamReader isw = new InputStreamReader(in); 
      int data = isw.read(); 
      while (data != -1) { 
       char current = (char) data; 
       data = isw.read(); 
       result.append(current); 
      } 
     } catch (Exception e) { 
      e.printStackTrace(); 
     } finally { 
      if (urlConnection != null) { 
       urlConnection.disconnect(); 
      } 
     } 

     return result.toString(); 
    } 

    @Override 
    protected void onPostExecute(String result) { 
     Toast.makeText(getApplicationContext(),"GET:"+result,Toast.LENGTH_LONG).show(); 
    } 
} 

Просто запустите AsyncTask от вашего щелчка слушателя:

startBtn.setOnClickListener(new View.OnClickListener(){ 
     @Override 
     public void onClick(View v) { 
      new MyAsyncTask().execute(); 
    }); 

Результат в Toast:

enter image description here