編輯:關於Android編程
1.簡介
HttpClient 是 Apache Jakarta Common 下的子項目,可以用來提供高效的、最新的、功能豐富的支持 HTTP 協議的客戶端編程工具包,並且它支持
HTTP 協議最新的版本和建議。
2.功能介紹
以下列出的是 HttpClient 提供的主要的功能,要知道更多詳細的功能可以參見 HttpClient 的主頁。
(1)實現了所有 HTTP 的方法(GET,POST,PUT,HEAD 等) (2)支持自動轉向 (3)支持 HTTPS 協議 (4)支持代理服務器等 3.處理步驟1.創建 HttpClient 的實例
2. 創建某種連接方法的實例,比如:HttpGet。在 HttpGet 的構造函數中傳入待連接的地址
3. 調用第一步中創建好的實例的 execute 方法來執行第二步中創建好的 method 實例
4. 讀 response
5. 釋放連接。無論執行方法是否成功,都必須釋放連接6. 對得到後的內容進行處理
4.具體案例說明
1.繼續采用03_android入門_采用RelativeLayout實現登陸界面為該案例的布局文件
2.服務器端的代碼采用04_android入門_采用HttpURLConnection的GET方式實現登陸案例中的服務器代碼片段(5.關於服務器中我僅寫一個Servlet進行處理相應的請求處理)
3.我對服務器端,返回的流對象的處理,寫了一個工具類(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; } } }
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); //用戶名控件 et_pass = (EditText) findViewById(R.id.et_pass);//密碼控件 tv_result = (TextView) findViewById(R.id.tv_result);//服務器端返回數據顯示的控件 } /** * 按鈕點擊事件處理 * @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();// 用戶名 final String userPass = et_pass.getText().toString();// 用戶密碼 //判斷用戶名和密碼是否為空 if (TextUtils.isEmpty(userName.trim()) || TextUtils.isEmpty(userPass.trim())) { Toast.makeText(this, "用戶名或者密碼不能為空", 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 { //封裝傳遞參數的集合 Listparameters = new ArrayList (); //往這個集合中添加你要傳遞的參數 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() { //設置控件的內容(此內容是從服務器端獲取的) 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() { //設置控件的內容(此內容是從服務器端獲取的) tv_result.setText(result); } }); } } catch (Exception e) { e.printStackTrace(); } finally { // 5.釋放連接。無論執行方法是否成功,都必須釋放連接 client.getConnectionManager().shutdown();// 釋放鏈接 } } }
希望能對你有所幫助!
問題起因我曾經在開發Android Application的過程中遇到過那個有名的65k方法數的問題。如果你開發的應用程序變得非常龐大,你八成會遇到這個問題。這個問題實際
綜述 在Android中,我們需要進行一些耗時的操作,會將這個操作放在子線程中進行。在子線程操作完成以後我們可以通過Handler進行發送消息,通知UI進行一些更新操作
原文地址:Mina SSLFilter(Apahce Mina user guide Chapter11 SSL Filter)SslFilter過濾器是負責管理數據的加
之前參加了一個課程,裡面有一節講到了用視頻作為啟動界面。講師用的是自定義VideoView,重寫onMeasure方法,因為原生的VideoView在那情況下不能實現全屏