編輯:關於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 {
//封裝傳遞參數的集合
List parameters = 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動態加載插件APK
問題起因我曾經在開發Android Application的過程中遇到過那個有名的65k方法數的問題。如果你開發的應用程序變得非常龐大,你八成會遇到這個問題。這個問題實際
Android AsyncTask使用以及源碼解析
綜述 在Android中,我們需要進行一些耗時的操作,會將這個操作放在子線程中進行。在子線程操作完成以後我們可以通過Handler進行發送消息,通知UI進行一些更新操作
Mina SSL Filter安全加密過濾器相關知識介紹
原文地址:Mina SSLFilter(Apahce Mina user guide Chapter11 SSL Filter)SslFilter過濾器是負責管理數據的加
用原生VideoView進行全屏播放時的問題
之前參加了一個課程,裡面有一節講到了用視頻作為啟動界面。講師用的是自定義VideoView,重寫onMeasure方法,因為原生的VideoView在那情況下不能實現全屏