標籤:host getc gravity relative 地址 cal buffer size 檔案
1.簡單介紹
HttpClient 是 Apache Jakarta Common 下的子項目,能夠用來提供高效的、最新的、功能豐富的支援 HTTP 協議的用戶端編程工具包,而且它支援 HTTP 協議最新的版本號碼和建議。
2.功能介紹
? ? 下面列出的是 HttpClient 提供的基本的功能,要知道很多其它具體的功能能夠參見 HttpClient 的首頁。
(1)實現了全部 HTTP 的方法(GET,POST,PUT,HEAD 等)(2)支援自己主動轉向(3)支援 HTTPS 協議(4)支援代理server等3.處理步驟
1.建立 HttpClient 的執行個體
2. 建立某種串連方法的執行個體,比方:HttpGet。
在 HttpGet 的建構函式中傳入待串連的地址
3. 調用第一步中建立好的執行個體的 execute 方法來運行第二步中建立好的 method 執行個體
4. 讀 response
5. 釋放串連。不管運行方法是否成功。都必須釋放串連
6. 對得到後的內容進行處理
4.具體案例說明
1.繼續採用03_android入門_採用RelativeLayout實現登陸介面為該案例的布局檔案?
2.server端的代碼採用04_android入門_採用HttpURLConnection的GET方式實現登陸案例中的server程式碼片段(5.關於server中我僅寫一個Servlet進行處理對應的請求處理)
3.我對server端,返回的流對象的處理,寫了一個工具類(StreamTools) 代碼例如以下:
package www.csdn.net.util;import java.io.ByteArrayOutputStream;import java.io.IOException;import java.io.InputStream;public class StreamTools {/** * 把流對象轉換成字串對象 * * @param is * @return */public static String streamToStr(InputStream is) {try {// 定義位元組數組輸出資料流對象ByteArrayOutputStream os = new ByteArrayOutputStream();// 定義讀取的長度int len = 0;// 定義讀取的緩衝區byte buffer[] = new byte[1024];// 依照定義的緩衝區進行迴圈讀取。直到讀取完成為止while ((len = is.read(buffer)) != -1) {// 依據讀取的長度寫入到位元組數組輸出資料流對象中os.write(buffer, 0, len);}// 關閉流is.close();os.close();// 把讀取的位元組數組輸出資料流對象轉換成位元組數組byte data[] = os.toByteArray();// 依照指定的編碼進行轉換成字串(此編碼要與服務端的編碼一致就不會出現亂碼問題了。android預設的編碼為UTF-8)return new String(data, "UTF-8");} catch (IOException e) {e.printStackTrace();return null;}}}
4.LoginActivity的代碼(代碼中具體加了凝視,請細緻閱讀)
package www.csdn.net.lesson03;import java.io.InputStream;import java.util.ArrayList;import java.util.List;import org.apache.http.HttpEntity;import org.apache.http.HttpResponse;import org.apache.http.NameValuePair;import org.apache.http.client.HttpClient;import org.apache.http.client.entity.UrlEncodedFormEntity;import org.apache.http.client.methods.HttpGet;import org.apache.http.client.methods.HttpPost;import org.apache.http.impl.client.DefaultHttpClient;import org.apache.http.message.BasicNameValuePair;import www.csdn.net.util.StreamTools;import android.app.Activity;import android.os.Bundle;import android.text.TextUtils;import android.view.View;import android.widget.EditText;import android.widget.TextView;import android.widget.Toast;public class LoginActivity extends Activity {// 聲明控制項private EditText et_name, et_pass;private TextView tv_result;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_login);// 擷取控制項對象et_name = (EditText) findViewById(R.id.et_name); //username控制項et_pass = (EditText) findViewById(R.id.et_pass);//password控制項tv_result = (TextView) findViewById(R.id.tv_result);//server端返回資料顯示的控制項}/** * button點擊事件處理 * @param v */public void login(View v) {//擷取控制項idint id = v.getId();switch (id) {case R.id.btn_login:// 擷取控制項的常值內容final String userName = et_name.getText().toString();// usernamefinal String userPass = et_pass.getText().toString();// 使用者password//推斷username和password是否為空白if (TextUtils.isEmpty(userName.trim())|| TextUtils.isEmpty(userPass.trim())) {Toast.makeText(this, "username或者password不可為空", Toast.LENGTH_LONG).show();} else {// 開啟線程處理new Thread(new Runnable() {@Overridepublic void run() {//調用:loginByHttpClientGet(userName, userPass);//調用:loginByHttpClientPost(userName, userPass);loginByHttpClientGet(userName, userPass);//測試}}).start();}break;default:break;}}/** * HttpClient中POST方式的處理 * @param userName * @param userPass */public void loginByHttpClientPost(String userName, String userPass) {//1.建立 HttpClient 的執行個體HttpClient client = new DefaultHttpClient();//2. 建立某種串連方法的執行個體。在這裡是HttpPost。在 HttpPost 的建構函式中傳入待串連的地址String uri="http://172.16.237.200:8080/video/login.do";HttpPost httpPost = new HttpPost(uri);try {//封裝傳遞參數的集合List<NameValuePair> parameters = new ArrayList<NameValuePair>();//往這個集合中加入你要傳遞的參數parameters.add(new BasicNameValuePair("username", userName));parameters.add(new BasicNameValuePair("userpass", userPass));//建立傳遞參數封裝 實體物件UrlEncodedFormEntity entity = new UrlEncodedFormEntity(parameters, "UTF-8");//設定傳遞參數的編碼//把實體物件存入到httpPost對象中httpPost.setEntity(entity);//3. 調用第一步中建立好的執行個體的 execute 方法來運行第二步中建立好的 method 執行個體HttpResponse response = client.execute(httpPost); //HttpUriRequest的後代對象 //在瀏覽器中敲一下斷行符號//4. 讀 responseif(response.getStatusLine().getStatusCode()==200){//推斷狀態代碼InputStream is = response.getEntity().getContent();//擷取內容final String result = StreamTools.streamToStr(is); // 通過工具類轉換文本LoginActivity.this.runOnUiThread(new Runnable() {//通過runOnUiThread方法處理@Overridepublic void run() {//設定控制項的內容(此內容是從server端擷取的)tv_result.setText(result);}});}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}finally{//6. 釋放串連。不管運行方法是否成功,都必須釋放串連client.getConnectionManager().shutdown();}}/** * 通過httpClient中的GET方式處理的 * @param userName * @param userPass */public void loginByHttpClientGet(String userName,String userPass){// HttpClient 發請求 GET方式處理// 1.建立 HttpClient 的執行個體 開啟一個瀏覽器HttpClient client = new DefaultHttpClient(); // DefaultHttpClient extends AbstractHttpClienttry {// 2. 建立某種串連方法的執行個體。在這裡是HttpGet。在 HttpGet// 的建構函式中傳入待串連的地址 String uri = "http://172.16.237.200:8080/video/login.do?username="+ userName + "&userpass=" + userPass;//強調 地址不能夠出現 localhost:操作HttpGet httpGet = new HttpGet(uri);// 3. 調用第一步中建立好的執行個體的 execute 方法來運行第二步中建立好的 method 執行個體HttpResponse response = client.execute(httpGet); // 在瀏覽器中敲了一下斷行符號// 4. 讀 responseint statusCode = response.getStatusLine().getStatusCode();// 讀取狀態行中的狀態代碼if (statusCode == 200) { //假設等於200 一切okHttpEntity entity = response.getEntity();// 返回實體物件InputStream is = entity.getContent(); // 讀取實體中內容final String result = StreamTools.streamToStr(is); // 通過工具類轉換文本LoginActivity.this.runOnUiThread(new Runnable() {//通過runOnUiThread方法處理@Overridepublic void run() {//設定控制項的內容(此內容是從server端擷取的)tv_result.setText(result);}});}} catch (Exception e) {e.printStackTrace();} finally {// 5.釋放串連。不管運行方法是否成功,都必須釋放串連client.getConnectionManager().shutdown();// 釋放連結}}}
5.運行效果例如以
希望能對你有所協助!
07_android入門_採用HttpClient的POST方式、GET方式分別實現登陸案例