編輯:關於Android編程
最近的Android項目開發過程中一個問題困擾自己很長時間,Android客戶端與服務器交互有幾種方式,最常見的就是webservices和json。要在Android手機客戶端與pc服務器交互,需要滿足下面幾種條件:跨平台、傳輸數據格式標准、交互方便。
為了與服務器通訊其實無非就兩種協議HTTP和TCP,TCP的學習Socket,HTTP的話熟悉一下HTTP協議和相關Java API。而下面的幾種方式就是從這兩種協議擴展出來的:webservices soap、SSH的JSON(可參考:該鏈接)、xmlrpc(wordpress for android)......
Socket 不推薦 ,HTTP RESTful 推薦。跟服務器傳數據的話,一般都是采用 RESTful API 來傳輸。這樣首先要對 HTTP 協議有初步的理解,至少知道 GET / POST 分別是干嘛的有什麼區別。
如果沒有特殊要求,使用webservices傳輸XML文件比較簡單及通用,如果對數據大小及傳輸速度有要求的話就用json更合適。
【Socket與HTTP連接的區別】
HTTP連接使用的是“請求—響應”的方式,不僅在請求時需要先建立連接,而且需要客戶端向服務器發出請求後,服務器端才能回復數據。
socket是可以監聽,因此Socket連接一旦建立,通信雙方即可開始相互發送數據內容,直到雙方連接斷開。保持客戶端與服務器數據的實時與同步。
xml rpc是使用http協議做為傳輸協議的rpc機制,使用xml文本的方式傳輸命令和數據。
RPC是Remote Procedure Call的縮寫,翻譯成中文就是遠程過程調用,是一種在本地的機器上調用遠端機器上的一個過程(方法)的技術,這個過程也被大家稱為“分布式計算”
網上有很多例子來演示Android客戶端和服務器端數據如何實現交互。不過這些例子大多比較繁雜,對於初學者來說這是不利的,現在介紹一種代碼簡單、邏輯清晰的交互例子:
使用webservices傳輸XML文件:
一、服務器端:
代碼1:添加名為“AndroidServerServlet.java”的文件
package com.ghj.packageofservlet; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class AndroidServerServlet extends HttpServlet { private static final long serialVersionUID = 6792396567928634227L; public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException { response.setContentType(text/plain; charset=UTF-8); request.setCharacterEncoding(UTF-8); System.err.println(request.getParameter(clientData)); PrintWriter printWriter = response.getWriter(); printWriter.print(您好Android客戶端!); printWriter.flush(); printWriter.close(); } }
代碼2:修改名為“web.xml”的文件
<!--?xml version=1.0 encoding=UTF-8?--> <web-app http:="java.sun.com=" javaee="ns=" version="2.5" web-app_2_5.xsd="xml=" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemalocation="http://java.sun.com/xml/ns/javaee"><servlet> <servlet-name>AndroidServerServlet</servlet-name> <servlet-class>com.ghj.packageofservlet.AndroidServerServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>AndroidServerServlet</servlet-name> <url-pattern>/AndroidServerServlet</url-pattern> </servlet-mapping> </web-app>
二、Android手機客戶端:
代碼1:添加名為“AndroidClientActivity.java”的文件
package com.example.androidclient; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.util.ArrayList; import java.util.List; import org.apache.http.HttpResponse; import org.apache.http.NameValuePair; import org.apache.http.client.ClientProtocolException; import org.apache.http.client.HttpClient; import org.apache.http.client.entity.UrlEncodedFormEntity; import org.apache.http.client.methods.HttpPost; import org.apache.http.impl.client.DefaultHttpClient; import org.apache.http.message.BasicNameValuePair; import org.apache.http.protocol.HTTP; import org.apache.http.util.EntityUtils; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.Toast; public class AndroidClientActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.android_client); Button sendButton = (Button) findViewById(R.id.send_button); sendButton.setOnClickListener(new OnClickListener(){ @Override public void onClick(View v) { new Thread(new Runnable(){ @Override public void run() { HttpPost httpRequest = new HttpPost(http://172.16.99.207:8080/AndroidServer/AndroidServerServlet); List<namevaluepair> params = new ArrayList<namevaluepair>(); params.add(new BasicNameValuePair(clientData, 您好服務器端!)); try { Message message = new Message(); Bundle bundle = new Bundle(); httpRequest.setEntity(new UrlEncodedFormEntity(params, HTTP.UTF_8));//設置請求參數項 HttpClient httpClient = new DefaultHttpClient(); HttpResponse httpResponse = httpClient.execute(httpRequest);//執行請求返回響應 if(httpResponse.getStatusLine().getStatusCode() == 200){//判斷是否請求成功 bundle.putString(msg, EntityUtils.toString(httpResponse.getEntity())); }else{ bundle.putString(msg, 沒有獲取到Android服務器端的響應!); } message.setData(bundle); handler.sendMessage(message); } catch (ClientProtocolException e) { e.printStackTrace(); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } }).start(); } }); } private Handler handler = new Handler(){ @Override public void handleMessage(Message message) { super.handleMessage(message); Bundle bundle = message.getData(); String msg = bundle.getString(msg); Toast.makeText(getApplicationContext(), msg, Toast.LENGTH_LONG).show(); } }; }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
前面兩篇文章,我們分析了Activity的布局文件加載、繪制流程,算是對整個Android系統中界面的顯示流程有了一個大概的了解,其實Android系統中所有的顯示控件(
本示例演示在Android中實現圖片左右滑動效果。關於滑動效果,在Android中用得比較多,本示例實現的滑動效果是使用ViewFlipper來實現的,當然也可以使用其它
序言上一篇中我們介紹了幾個簡單的新UI控件,相信很多小伙伴對Materil Design的視覺效果有了一定的了解,今天我們就繼續介紹其他幾個控件的玩兒法,讓我們一探Mat
最近的一個實驗用到東西挺多,特地總結一下。 要求功能: 1、第一個頁面添加歌曲名和歌手,跳到第二個頁面列表顯示所有記錄,使用sqlite數據庫