07_android入門_採用HttpClient的POST方式、GET方式分別實現登陸案例
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; @Override protected 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) { //獲取控件id int id = v.getId(); switch (id) { case R.id.btn_login: // 獲取控件的文本內容 final String userName = et_name.getText().toString();// username final 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() { @Override public 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. 讀 response if(response.getStatusLine().getStatusCode()==200){//推斷狀態碼 InputStream is = response.getEntity().getContent();//獲取內容 final String result = StreamTools.streamToStr(is); // 通過工具類轉換文本 LoginActivity.this.runOnUiThread(new Runnable() { //通過runOnUiThread方法處理 @Override public void run() { //設置控件的內容(此內容是從server端獲取的) tv_result.setText(result); } }); } } catch (Exception e) { // TODO Auto-generated catch block e.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 AbstractHttpClient try { // 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. 讀 response int statusCode = response.getStatusLine() .getStatusCode();// 讀取狀態行中的狀態碼 if (statusCode == 200) { //假設等於200 一切ok HttpEntity entity = response.getEntity();// 返回實體對象 InputStream is = entity.getContent(); // 讀取實體中內容 final String result = StreamTools.streamToStr(is); // 通過工具類轉換文本 LoginActivity.this.runOnUiThread(new Runnable() { //通過runOnUiThread方法處理 @Override public void run() { //設置控件的內容(此內容是從server端獲取的) tv_result.setText(result); } }); } } catch (Exception e) { e.printStackTrace(); } finally { // 5.釋放連接。不管運行方法是否成功,都必須釋放連接 client.getConnectionManager().shutdown();// 釋放鏈接 } } }
5.運行效果例如以下圖
希望能對你有所幫助!
07_android入門_採用HttpClient的POST方式、GET方式分別實現登陸案例