TShopping

 找回密碼
 註冊
搜索
查看: 1902|回復: 0

[教學] ANDROID 利用 PHP 連結 MYSQL

[複製鏈接]
發表於 2016-2-24 12:42:56 | 顯示全部樓層 |閱讀模式
 
Push to Facebook Push to Plurk Push to Twitter 
網路上有許多連結資料庫的方法,像是利用JDBC直接連結資料庫或是透過 web server 代為取得資料,在這裡提到的是後者,下圖為實際的操作環境。

AndroidToDB.png

本篇所使用的環境套件為 Mysql、Apache、PHP,在此除了利用PHP向DB要資料外並將取回的資料轉成 JSON 格式,接著利用 HTTP 協定傳遞給 Android 程式,接下來將詳細介紹中間的執行步驟及該注意的事項。

首先我們來看一下 PHP 如何向 Mysql 取得資料:


  1. <?php
  2. mysql_connect("資料庫位置","使用者名稱","使用者密碼");
  3. mysql_select_db("資料庫名稱");
  4. mysql_query("set names utf8");
  5. $q=mysql_query("SELECT  phone_value  from news where id='".$_POST['id']."'");
  6. while($e=mysql_fetch_assoc($q))
  7. $output[]=$e;
  8. print(json_encode($output));
  9. mysql_close();
  10. ?>
複製代碼

mysql_connect : 建立與mysql的連線。
mysql_select_db : 選擇要使用哪一個資料庫。
mysql_query : 設定語系,避免取回的文字呈現亂碼,並且設定 SQL 語法。
mysql_fetch_assoc : 利用 SQL 語法取回要求的資料。
json_encode : 利用 json 編碼將取回的資料轉換成 json 格式。
mysql_close : 最後記得要將 mysql 的連線關閉。

當然在檔案格式的選擇方面並不一定只能使用 JSON ,例如使用 XML 或是要自訂格式也都可以,差別在於使用 JSON 或是 XML 的格式,在Android端我們不需要再自己寫parser,並且Android的開發套件裡已經包含了許多工具可以直接使用。

接下來我們來看一下 Android 端該如何的發送參數與接收資訊;此處我們使用的是HTTP協定並利用POST的方式將參數傳至PHP網頁,並取得PHP傳回的資訊,最後將取得的JSON檔案解析出來使用,所以在 Android 端我們將分成三個部分來處理。

第一個部分主要的功能在於使用HTTP傳遞參數並取得資料:
原始碼如下:

1. HttpClient httpclient = new DefaultHttpClient();
2. HttpPost httppost = new HttpPost("php網址");
3. ArrayList<NameValuePair> nameValuePairs =
   new ArrayList<NameValuePair>();
4. nameValuePairs.add(new BasicNameValuePair("參數名","參數值"));
5. httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));  
6. HttpResponse response = httpclient.execute(httppost);
7. HttpEntity entity = response.getEntity();
8. is = entity.getContent();


第1、2行 : 使用的是Apache的功能,首先建立一個HttpClient的實體,並且使用Post的方式
           傳遞參數。
第3、4行 : 建立了一個存放NameValuePair型別的ArrayList容器,並且將之後要POST的參數名和
           參數值放入容器中。
第5、6行 : 實際送出請求,並取得傳回狀態等資訊。
第7、8行 : 取得收到的內容。


接下來將剛剛所取得的Content利用StringBuilder轉換為字串

  1. BufferedReader reader = new BufferedReader(
  2.                         new InputStreamReader(is, "iso-8859-1"),8
  3. );
  4. StringBuilder sb = new StringBuilder();
  5. String line = null;
  6. while ((line = reader.readLine()) != null) {
  7.         sb.append(line);
  8. }
  9. is.close();
  10. result = sb.toString();
複製代碼


最後取得每個JSON物件與值,先利用JSONArray.getJSONObject取得需要的JSON物件,之後再利用此物件的getString或getInt等方法取得相對應的值。

  1. JSONArray jArray = new JSONArray(result);
  2. for(int i = 0;i<jArray.length();i++){
  3.      JSONObject json_data = jArray.getJSONObject(i);
  4.      data1 = json_data.getString("鍵值名稱");
  5.      data2 = json_data.getInt("鍵值名稱");
  6.      data3 = json_data.getDouble("鍵值名稱");
  7. }
複製代碼



以上為利用PHP取得MySQL資料的大略流程,中間還有許多可以做變化,像是最後取值的部分是不是一定要全部取?還是當有需要時再取所需的部分?這些都可以做一些規劃,讓整體系統更有擴充性或是賦予物件該負的責任。

在MAP的開發過程中,這個連線與取值的部分我是獨立成一個類別,類別中所需要POST的參數與值經由實際創立物件時再另外做設定,要對哪支PHP做呼叫甚至取回哪些值都是等到物件建立後再依照需求作建立,這樣作雖然在建立物件時會多了許多需要設定的步驟,但相對的可以將PHP頁面與Android程式做適當的分割,以減少其耦合度,除此之外這支類別的責任也就很清楚的定義為Android與PHP兩大單位的中間人,未來兩邊有變異,將可以只修改這個類別作對應動作。
文章出處

 

臉書網友討論
您需要登錄後才可以回帖 登錄 | 註冊 |

本版積分規則



Archiver|手機版|小黑屋|免責聲明|TShopping

GMT+8, 2016-12-9 06:12 , Processed in 0.060941 second(s), 25 queries .

本論壇言論純屬發表者個人意見,與 TShopping綜合論壇 立場無關 如有意見侵犯了您的權益 請寫信聯絡我們。

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回復 返回頂部 返回列表