Данные с сервера sql - PullRequest
       3

Данные с сервера sql

0 голосов
/ 03 января 2012

Я хочу, чтобы приложение для Android получало данные из онлайн-базы данных.Вот два сценария:

  • Когда я создаю свою базу данных с помощью xampp и использую функцию httpost с ip своих локальных машин в качестве аргумента, я вижу в качестве вывода то, что ожидаю увидеть (база данных на logcat).

Мой вопрос: если я запустил приложение с моего телефона, оно подключится к серверу локальной машины или нет?

  • Iтакже есть сайт (скажем, mysite.com), и чтобы не покупать другой сервер, я размещаю файл php и базу данных на этом сервере.Но затем мое приложение для Android подключается (или я так думаю) к серверу, но распечатывает на logcat весь HTML-сайт.Я думаю, что это потому, что сервер требует имя пользователя и пароль, и я не знаю, предоставил ли я их или нет?

Итак, что вы предлагаете сделать?Я хочу, чтобы моя база данных была отправлена ​​в мое приложение (чтобы использовать ее позже).

Мой код показан ниже (у меня в комментариях только то, что меняется между двумя сценариями)

public class MainActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    setImageClickListener();

}

private void setImageClickListener() {
    ImageView map_image=(ImageView)findViewById(R.id.map_icon);
    map_image.setOnTouchListener(new ImageView.OnTouchListener() {
    //OnTouchListener listener = new OnTouchListener() {
        public boolean onTouch(View v, MotionEvent event) {
            if(!(event.getAction() == MotionEvent.ACTION_DOWN))
                return false; //If the touch event was not putting the finger down on the screen, return false(Actions may be move, up, and so on)
            final float x = event.getX();
            final float y = event.getY();
            //System.out.println("Coordinates of button pressed are: X is %d"+x+" and Y is %d"+ y);
            if(x>335 && x<395 && y>225 && y< 235)
                DoFirst();

           return true;
        }

});

}
@SuppressWarnings("null")
private void DoFirst() {
    Log.d("SnowReportApp","Do first thing");
    setContentView(R.layout.layout_1);
    String result = "";
    InputStream is = null;
    StringBuilder sb=null;
    //the year data to send
    ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();//() before
    nameValuePairs.add(new BasicNameValuePair("year","1980"));
    //http post
    try{
            HttpClient httpclient = new DefaultHttpClient();
            HttpPost httppost = new HttpPost("192.168.1.67/test.php"); // only this changes to my server url : mysite.com/httpdocs/test.php
            httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
            HttpResponse response = httpclient.execute(httppost);
            HttpEntity entity = response.getEntity();
            is = entity.getContent();
    }catch(Exception e){
            Log.e("log_tag", "Error in http connection "+e.toString());
    }
    //convert response to string
    try{
            BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
            sb = new StringBuilder();
            String line = null;
            while ((line = reader.readLine()) != null) {
                    sb.append(line + "\n");
            }
            is.close();

            result=sb.toString();
    }catch(Exception e){
            Log.e("log_tag", "Error converting result "+e.toString());
    }

    //parse JSON data
    try{
            //JSONObject json_data_1 = new JSONObject(result); 
            JSONArray jArray = new JSONArray(result);
            for(int i=0;i<jArray.length();i++){
                   JSONObject json_data = jArray.getJSONObject(i);
                    Log.i("log_tag","id: "+json_data.getInt("id")+
                            ", name: "+json_data.getString("name")+
                            ", sex: "+json_data.getInt("sex")+
                            ", birthyear: "+json_data.getInt("birthyear")
                    );
            }

    }catch(JSONException e){
            Log.e("log_tag", "Error parsing data "+e.toString());
    }

} 

Мой php-файл, расположенный на c:\xampp\htdocs или на сервере mysite, выглядит так:

<?php

  mysql_connect("127.0.0.1","root","");

  mysql_select_db("peopledata");

  $q=mysql_query("SELECT * FROM people WHERE birthyear>'".$_REQUEST['year']."'");

  while($e=mysql_fetch_assoc($q))

          $output[]=$e;

       print(json_encode($output));

mysql_close();?>

1 Ответ

2 голосов
/ 04 января 2012

У меня вопрос: если я запусту приложение со своего телефона, будет ли оно подключиться к серверу моей локальной машины или нет?

Ответ , вероятно, не . Это действительно все зависит от:

  • Используете ли вы Wi-Fi или данные оператора (3G и т. Д.)
  • Открыты ли порты БД (брандмауэр ПК)
  • Если данные Carrier, ваш компьютер доступен из Интернета (статический IP)

Вам лучше использовать mysite.com для своей БД и любого необходимого бэкэнда.

Что касается других ваших вопросов, я не могу на них ответить, поскольку они довольно расплывчаты. Подумайте над тем, чтобы исследовать вашу проблему, и, возможно, вернитесь с целым набором вопросов.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...