2012-10-04 18 views
5

Estoy tratando de desarrollar una aplicación de Android para mi proyecto de fin de año y estoy en el punto donde necesito conectar una base de datos a mi aplicación. Me he conectado previamente a una base de datos SQLite interna y externa, pero mi supervisor dice que debo usar el servidor local XAMPP para que sea justificable más adelante ya que es muy similar a una situación de la vida real donde se usaría un servidor web. Aquí está el código para mi clase DBHelper, que adapté de un código de muestra que encontré en la red y cambié algunas cosas, pero estoy bastante seguro de que hay un montón de errores. Cuando se presiona el botón para ver los datos, lo que llevaría a esta clase, simplemente mostraría una pantalla en blanco y después de un tiempo largo se bloqueará.Android: conectando mysql (XAMPP) a la aplicación de Android en el emulador

package com.example.parking_guide; 

import java.util.ArrayList; 
import java.util.HashMap; 
import java.util.List; 

import org.apache.http.NameValuePair; 
import org.json.JSONArray; 
import org.json.JSONException; 
import org.json.JSONObject; 

import android.app.ListActivity; 
import android.app.ProgressDialog; 
import android.content.Context; 
import android.content.Intent; 
import android.database.Cursor; 
import android.os.AsyncTask; 
import android.os.Bundle; 
import android.util.Log; 
import android.view.View; 
import android.widget.AdapterView; 
import android.widget.AdapterView.OnItemClickListener; 
import android.widget.ListAdapter; 
import android.widget.ListView; 
import android.widget.SimpleAdapter; 
import android.widget.TextView; 

public class DBHelper extends ListActivity { 


    // Progress Dialog 
    private ProgressDialog pDialog; 

    // Creating JSON Parser object 
    JSONParser jParser = new JSONParser(); 

    ArrayList<HashMap<String, String>> productsList; 

    // url to get all products list 
    private static final String url_all_products = "http://10.0.0.2/android_connect/get_all_products.php"; 

    // JSON Node names 
    private static final String TAG_SUCCESS = "success"; 
    private static final String TAG_PRODUCTS = "products"; 
    private static final String KEY_ROWID = "_id"; 
    private static final String KEY_VACANT = "vacancy"; 

    // products JSONArray 
    JSONArray table = null; 

    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     ListView yourListView = getListView(); 



     // Hashmap for ListView 
     productsList = new ArrayList<HashMap<String, String>>(); 

     // Loading products in Background Thread 
     new LoadAllProducts().execute(); 

    } 
    /** 
    * Background Async Task to Load all product by making HTTP Request 
    * */ 
    class LoadAllProducts extends AsyncTask<String, String, String> { 


     /** 
     * Before starting background thread Show Progress Dialog 
     * */ 
     @Override 

     /** 
     * getting All products from url 
     * */ 
     protected String doInBackground(String... args) { 
      // Building Parameters 
      List<NameValuePair> params = new ArrayList<NameValuePair>(); 
      // getting JSON string from URL 
      JSONObject json = jParser.makeHttpRequest(url_all_products, "GET", params); 

      // Check your log cat for JSON reponse 
      Log.d("Level1: ", json.toString()); 

      try { 
       // Checking for SUCCESS TAG 
       int success = json.getInt(TAG_SUCCESS); 

       if (success == 1) { 
        // products found 
        // Getting Array of Products 
        table = json.getJSONArray(TAG_PRODUCTS); 

        // looping through All Products 
        for (int i = 0; i < table.length(); i++) { 
         JSONObject c = table.getJSONObject(i); 

         // Storing each json item in variable 
         String _id = c.getString(KEY_ROWID); 
         String vacant = c.getString(KEY_VACANT); 

         // creating new HashMap 
         HashMap<String, String> map = new HashMap<String, String>(); 


         // adding each child node to HashMap key => value 
         map.put(KEY_ROWID, _id); 
         map.put(KEY_VACANT, vacant); 

         // adding HashList to ArrayList 
         productsList.add(map); 
        } 
       } 
      } catch (JSONException e) { 
       e.printStackTrace(); 
      } 

      return null; 

     } 


     /** 
     * After completing background task Dismiss the progress dialog 
     * **/ 
     protected void onPostExecute(String file_url) { 
      // dismiss the dialog after getting all products 
      // updating UI from Background Thread 
      runOnUiThread(new Runnable() { 
       public void run() { 
        /** 
        * Updating parsed JSON data into ListView 
        * */ 
        ListAdapter adapter = new SimpleAdapter(
          DBHelper.this, productsList, 
          R.layout.list_item, new String[] { KEY_ROWID, 
            KEY_VACANT}, 
          new int[] { R.id.id, R.id.vac}); 
        // updating listview 
        setListAdapter(adapter); 
       } 
      }); 

     } 


    } 
} 

por lo que no se sabe muy bien lo que está mal ya que no soy tan bueno en androide y simplemente aprendiendo sobre la marcha adelante. ¿Alguien que pueda ayudarme?

+0

compartir mensajes del LogCat – ariefbayu

+0

Necesitamos la salida Logcat ser capaz de ayudarle. – Namphibian

+0

comparta su registro de fallas por favor. – VendettaDroid

Respuesta

3

10.0.2.2 Debe utilizar la imagen para ver su servidor local, no 10.0.0.2 :) http://developer.android.com/tools/devices/emulator.html#networkaddresses

+0

Ha pasado años desde que publiqué esto aquí, pero creo, ¡creo! este fue el problema en aquel entonces también! gracias por la respuesta de cualquier manera –

+0

no es nada, solo estaba en la parte superior de las preguntas sin respuesta, así que respondí :) –

+0

Hola Onur A, si mi localhost en http: // localhost: 8081/phpmyadmin /. ¿Entonces mi 10.0.2.2 debería seguir igual o agregar 10.0.2.2:8081? – whywhy

Cuestiones relacionadas