【轉】連接MySQL資料庫(android,php,MySQL)

来源:http://www.cnblogs.com/ccccfz/archive/2016/01/13/5128849.html
-Advertisement-
Play Games

管理MySQL資料庫最簡單和最便利的方式是PHP腳本。運行PHP腳本使用HTTP協議和android系統連接。我們以JSON格式編碼數據,因為Android和PHP都有現成的處理JSON函數。下麵示例代碼,根據給定的條件從資料庫讀取數據,轉換為JSON數據。通過HTTP協議傳給android,and...


管理MySQL資料庫最簡單和最便利的方式是PHP腳本。
運行PHP腳本使用HTTP協議和android系統連接。
我們以JSON格式編碼數據,因為Android和PHP都有現成的處理JSON函數。

下麵示例代碼,根據給定的條件從資料庫讀取數據,轉換為JSON數據。
通過HTTP協議傳給android,android解析JSON數據。

定義在MySQL有以下表,並有一些數據

1 CREATE TABLE `people` (
2 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
3 `name` VARCHAR( 100 ) NOT NULL ,
4 `sex` BOOL NOT NULL DEFAULT '1',
5 `birthyear` INT NOT NULL
6 )
View Code

我們想要獲得在一個指定年出生的人的數據。
PHP代碼將是非常簡單的:連接到資料庫——運行一個SQL查詢,根據設定WHERE語句塊得到數據——轉換以JSON格式輸出    
例如我們會有這種功能getAllPeopleBornAfter.php文件:

 1 <?php
 2 /* 連接到資料庫 */
 3 mysql_connect("host","username","password");
 4 mysql_select_db("PeopleData");
 5 /* $_REQUEST['year']獲得Android發送的年值,拼接一個SQL查詢語句 */
 6 $q=mysql_query("SELECT * FROM people WHERE birthyear>'".$_REQUEST['year']."'"); 
 7 while($e=mysql_fetch_assoc($q))
 8         $output[]=$e;
 9 /* 轉換以JSON格式輸出  */
10 print(json_encode($output));
11 
12 mysql_close();
13 ?>
View Code

Android部分只是稍微複雜一點:用HttpPost發送年值,獲取數據——轉換響應字元串——解析JSON數據。
最後使用它。

 1 String result = "";
 2 /* 設定發送的年值 */
 3 ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
 4 nameValuePairs.add(new BasicNameValuePair("year","1980"));
 5 
 6 /* 用HttpPost發送年值 */
 7 try{
 8         HttpClient httpclient = new DefaultHttpClient();
 9         HttpPost httppost = new HttpPost("http://example.com/getAllPeopleBornAfter.php");//上面php所在URL
10         httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
11         HttpResponse response = httpclient.execute(httppost);
12         HttpEntity entity = response.getEntity();
13         InputStream is = entity.getContent();
14 }catch(Exception e){
15         Log.e("log_tag", "聯網錯誤 "+e.toString());
16 }
17 /* 轉換響應字元串 */
18 try{
19         BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);//註意"iso-8859-1"編碼不支持中文。
20         /* 如需支持中文,設定MySQL為UTF8格式,在此也設置UTF8讀取 */
21         StringBuilder sb = new StringBuilder();
22         String line = null;
23         while ((line = reader.readLine()) != null) {
24                 sb.append(line + "\n");
25         }
26         is.close();
27 
28         result=sb.toString();
29 }catch(Exception e){
30         Log.e("log_tag", "轉換響應字元串錯誤 "+e.toString());
31 }
32 
33 /* 解析JSON數據 */
34 try{
35         JSONArray jArray = new JSONArray(result);
36         for(int i=0;i<jArray.length();i++){
37                 JSONObject json_data = jArray.getJSONObject(i);
38                 Log.i("log_tag","id: "+json_data.getInt("id")+
39                         ", name: "+json_data.getString("name")+
40                         ", sex: "+json_data.getInt("sex")+
41                         ", birthyear: "+json_data.getInt("birthyear")
42                 );
43         }
44 }
45 }catch(JSONException e){
46         Log.e("log_tag", "解析JSON數據錯誤 "+e.toString());
47 }
View Code

註意:android4.0以上聯網代碼只能放在子線程


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • edgesForExtendedLayout:在IOS7以後 ViewController 開始使用全屏佈局的,而且是預設的行為通常涉及到佈局,就離不開這個屬性edgesForExtendedLayout,它是一個類型為UIExtendedEdge的屬性,指定邊緣要延伸的方向,它的預設值很自然地是U...
  • eMMC主要是針對手機和平板電腦等產品的內嵌式存儲器,由於其在封裝中集成了一個控制器,且提供標準介面並管理快閃記憶體等優勢,越來越受到Android手機廠商的青睞,以eMMC為存儲設備的android手機,其文件系統(system、data分區)一般採用ext4格式。如小米手機的線刷包:一.img解包 之...
  • GridView(網格視圖)講解一、GridView(網格視圖)這個是控制項也是比較多,和listView的很多地方都是一樣的,但是GridView可以顯示多列,而listView只能顯示一列,個人覺得這是最大的區別。常用屬性:android:columnWidth:設置列的寬度android:gra...
  • 註冊JPush賬號 JPush官網下載SDK下載地址:https://www.jpush.cn根據文檔進行集成文檔:http://docs.jpush.io/guideline/ios_guide/文檔介紹的已經很詳細了註意點:App Key需要登錄,添加自己的應用即可獲得,文檔中沒有給出跳轉的鏈接...
  • 首先申明下,本文為筆者學習《OpenGL ES應用開發實踐指南(Android捲)》的筆記,涉及的代碼均出自原書,如有需要,請到原書指定源碼地址下載。 《Android學習筆記——OpenGL ES的基本用法、繪製流程與著色器編譯》中實現了OpenGL ES的Android版HelloWorld,並...
  • 一,效果圖。二,工程圖。三,代碼。RootViewController.h#import @interface RootViewController : [email protected]#import "RootViewController.h"#im...
  • Xcode中的常用快捷鍵
  • 懶載入又叫延遲載入,他有兩個好處,第一:當使用時才載入,而不是一開始就載入,為CPU節省時間做其他的事情,第二:記載之前會判斷數據是否為空,如果空是空的才去載入,避免了重覆載入數據,系統可能會清理記憶體使數組為空,這樣確保數組不為空 有時plist文件不是一層可能兩層甚至多層,記住先建小模型,究竟如....
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...