1. 使用 标准Java接口: 设计的类: java.net.*
基本步骤:
1) 创建 URL 以及 URLConnection / HttpURLConnection 对象
2) 设置连接参数
3) 连接到服务器
4) 向服务器写数据
5)从服务器读取数据

例:


try {// 创建一个 URL 对象URL url = new URL(your_url);// 创建一个 URL 连接,如果有代理的话可以指定一个代理。URLConnection connection = url.openConnection(Proxy_yours);// 对于 HTTP 连接可以直接转换成 HttpURLConnection,这样就可以使用一些 HTTP 连接特定的方法,如 setRequestMethod() 等://HttpURLConnection connection =// (HttpURLConnection)url.openConnection(Proxy_yours);// 在开始和服务器连接之前,可能需要设置一些网络参数connection.setConnectTimeout(10000);connection.addRequestProperty(“User-Agent”,“J2me/MIDP2.0″);// 连接到服务器connection.connect();// 与服务器交互:OutputStream outStream = connection.getOutputStream();ObjectOutputStream objOutput = new ObjectOutputStream(outStream);objOutput.writeObject(new String(“this is a string…”));objOutput.flush();InputStream in = connection.getInputStream();// 处理数据…} catch (Exception e) {// 网络读写操作往往会产生一些异常,所以在具体编写网络应用时// 最好捕捉每一个具体以采取相应措施}

2. 使用 apache 接口:

Apache HttpClient 是一个开源项目,弥补了 java.net.* 灵活性不足的缺点, 支持客户端的HTTP编程.
使用的类包括: org.apache.http.*

步骤:
1) 创建 HttpClient 以及 GetMethod / PostMethod, HttpRequest 等对象;
2) 设置连接参数;
3) 执行 HTTP 操作;
4) 处理服务器返回结果.

例:


try {// 创建 HttpParams 以用来设置 HTTP 参数(这一部分不是必需的)HttpParams params = new BasicHttpParams();// 设置连接超时和 Socket 超时,以及 Socket 缓存大小:HttpConnectionParams.setConnectionTimeout(params, 20 * 1000);HttpConnectionParams.setSoTimeout(params, 20 * 1000);HttpConnectionParams.setSocketBufferSize(params, 8192);// 设置重定向,缺省为 true:HttpClientParams.setRedirecting(params, true);// 设置 user agent:HttpProtocolParams.setUserAgent(params, userAgent);// 创建一个 HttpClient 实例:// 注意: HttpClient httpClient = new HttpClient(); 是Commons HttpClient中的用法,// 在 Android 1.5 中我们需要使用 Apache 的缺省实现 DefaultHttpClient.DefaultHttpClient httpClient = new DefaultHttpClient(params);// 创建 HttpGet 方法,该方法会自动处理 URL 地址的重定向:HttpGet httpGet = new HttpGet (“http://www.test_test.com/”);//执行此方法:HttpResponse response = client.execute(httpGet);if (response.getStatusLine().getStatusCode() != HttpStatus.SC_OK) {// 错误处理,例如可以在该请求正常结束前将其中断:httpGet.abort();}// 读取更多信息Header[] headers = response.getHeaders();HttpEntity entity = response.getEntity();Header header = response.getFirstHeader(“Content-Type”);} catch (Exception ee) {// …} finally {// 释放连接:client.getConnectionManager().shutdown();}以下例子以 HttpGet 方式通过代理访问 HTTPS 网站:try {HttpClient httpClient = new HttpClient();// 设置认证的数据: httpClient好像没有方法getCredentialsProvider()??httpClient.getCredentialsProvider().setCredentials(new AuthScope(“your_auth_host”, 80, “your_realm”),new UsernamePasswordCredentials(“username”, “password”));// 设置服务器地址,端口,访问协议:HttpHost targetHost = new HttpHost(“www.verisign.com”, 443, “https”);// 设置代理:HttpHost proxy = new HttpHost(“192.168.1.1″, 80);httpClient.getParams().setParameter(ConnRoutePNames.DEFAULT_PROXY, proxy);// 创建一个 HttpGet 实例:HttpGet httpGet = new HttpGet(“/a/b/c”);// 连接服务器并获取应答数据:HttpResponse response = httpClient.execute(targetHost, httpGet);// 读取应答数据:int statusCode = response.getStatusLine().getStatusCode();Header[] headers = response.getHeaders();HttpEntity entity = response.getEntity();// …} catch (Exception ee) {// …}

3. 使用 android 接口:

类android.net.http.* 实际上是通过对 Apache 的 HttpClient 的封装来实现的一个 HTTP 编程接口,同时还提供了 HTTP 请求队列管理、以及 HTTP 连接池管理,以提高并发请求情况下(如转载网页时)的处理效率,除此之外还有网络状态监视等接口。

例:(class AndroidHttpClient : Since Android API level

按 Ctrl+C 复制代码
try {
AndroidHttpClient client =
AndroidHttpClient.newInstance(“user_agent__my_mobile_browser”);

// 创建 HttpGet 方法,该方法会自动处理 URL 地址的重定向:
HttpGet httpGet = new HttpGet (“http://www.test_test.com/”);
HttpResponse response = client.execute(httpGet);
if (response.getStatusLine().getStatusCode() != HttpStatus.SC_OK) {
// 错误处理…
}
//…

// 关闭连接:
client.close();
} catch (Exception ee) {
//…
}
A Comparison of java.net.URLConnection and HTTPClient
Since java.net.URLConnection and HTTPClient have overlappingfunctionalities, the question arises of why would you use HTTPClient.Here are a few of the capabilites and tradeoffs.




HttpURLConnection与HttpClient的区别
1.概念

HTTP 协议可能是现在 Internet 上使用得最多、最重要的协议了,越来越多的 Java 应用程序需要直接通过 HTTP 协议来访问网络资源。在 JDK 的 java.net 包中已经提供了访问 HTTP 协议的基本功能:HttpURLConnection。但是对于大部分应用程序来说,JDK 库本身提供的功能还不够丰富和灵活。

除此之外,在Android中,androidSDK中集成了Apache的HttpClient模块,用来提供高效的、最新的、功能丰富的支持 HTTP 协议工具包,并且它支持 HTTP 协议最新的版本和建议。使用HttpClient可以快速开发出功能强大的Http程序。

2.区别

HttpClient是个很不错的开源框架,封装了访问http的请求头,参数,内容体,响应等等,

HttpURLConnection是java的标准类,什么都没封装,用起来太原始,不方便,比如重访问的自定义,以及一些高级功能等。

3.案例

URLConnection

String urlAddress = "http://192.168.1.102:8080/AndroidServer/login.do"; URL url; HttpURLConnection uRLConnection; public UrlConnectionToServer(){ }
//向服务器发送get请求public String doGet(String username,String password){ String getUrl = urlAddress + "?username="+username+"&password="+password; try { url = new URL(getUrl); uRLConnection = (HttpURLConnection)url.openConnection(); InputStream is = uRLConnection.getInputStream(); BufferedReader br = new BufferedReader(new InputStreamReader(is)); String response = ""; String readLine = null; while((readLine =br.readLine()) != null){ //response = br.readLine(); response = response + readLine; } is.close(); br.close(); uRLConnection.disconnect(); return response; } catch (MalformedURLException e) { e.printStackTrace(); returnnull; } catch (IOException e) { e.printStackTrace(); returnnull; } }
//向服务器发送post请求public String doPost(String username,String password){ try { url = new URL(urlAddress); uRLConnection = (HttpURLConnection)url.openConnection(); uRLConnection.setDoInput(true); uRLConnection.setDoOutput(true); uRLConnection.setRequestMethod("POST"); uRLConnection.setUseCaches(false); uRLConnection.setInstanceFollowRedirects(false); uRLConnection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded"); uRLConnection.connect(); DataOutputStream out = new DataOutputStream(uRLConnection.getOutputStream()); String content = "username="+username+"&password="+password; out.writeBytes(content); out.flush(); out.close(); InputStream is = uRLConnection.getInputStream(); BufferedReader br = new BufferedReader(new InputStreamReader(is)); String response = ""; String readLine = null; while((readLine =br.readLine()) != null){ //response = br.readLine(); response = response + readLine; } is.close(); br.close(); uRLConnection.disconnect(); return response; } catch (MalformedURLException e) { e.printStackTrace(); returnnull; } catch (IOException e) { e.printStackTrace(); returnnull; } }

HTTPClient

String urlAddress = "http://192.168.1.102:8080/qualityserver/login.do"; public HttpClientServer(){ } public String doGet(String username,String password){ String getUrl = urlAddress + "?username="+username+"&password="+password; HttpGet httpGet = new HttpGet(getUrl); HttpParams hp = httpGet.getParams(); hp.getParameter("true"); //hp. //httpGet.setp HttpClient hc = new DefaultHttpClient(); try { HttpResponse ht = hc.execute(httpGet); if(ht.getStatusLine().getStatusCode() == HttpStatus.SC_OK){ HttpEntity he = ht.getEntity(); InputStream is = he.getContent(); BufferedReader br = new BufferedReader(new InputStreamReader(is)); String response = ""; String readLine = null; while((readLine =br.readLine()) != null){ //response = br.readLine(); response = response + readLine; } is.close(); br.close(); //String str = EntityUtils.toString(he); System.out.println("========="+response); return response; }else{ return "error"; } } catch (ClientProtocolException e) { // TODO Auto-generated catch block e.printStackTrace(); return "exception"; } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); return "exception"; } } public String doPost(String username,String password){ //String getUrl = urlAddress + "?username="+username+"&password="+password; HttpPost httpPost = new HttpPost(urlAddress); List params = new ArrayList(); NameValuePair pair1 = new BasicNameValuePair("username", username); NameValuePair pair2 = new BasicNameValuePair("password", password); params.add(pair1); params.add(pair2); HttpEntity he; try { he = new UrlEncodedFormEntity(params, "gbk"); httpPost.setEntity(he); } catch (UnsupportedEncodingException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } HttpClient hc = new DefaultHttpClient(); try { HttpResponse ht = hc.execute(httpPost); //连接成功 if(ht.getStatusLine().getStatusCode() == HttpStatus.SC_OK){ HttpEntity het = ht.getEntity(); InputStream is = het.getContent(); BufferedReader br = new BufferedReader(new InputStreamReader(is)); String response = ""; String readLine = null; while((readLine =br.readLine()) != null){ //response = br.readLine(); response = response + readLine; } is.close(); br.close(); //String str = EntityUtils.toString(he); System.out.println("=========&&"+response); return response; }else{ return "error"; } } catch (ClientProtocolException e) { // TODO Auto-generated catch block e.printStackTrace(); return "exception"; } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); return "exception"; } }

servlet端json转化:

resp.setContentType("text/json"); resp.setCharacterEncoding("UTF-8"); toDo = new ToDo(); List<UserBean> list = new ArrayList<UserBean>(); list = toDo.queryUsers(mySession); String body; //设定JSON JSONArray array = new JSONArray(); for(UserBean bean : list) { JSONObject obj = new JSONObject(); try { obj.put("username", bean.getUserName()); obj.put("password", bean.getPassWord()); }catch(Exception e){} array.add(obj); } pw.write(array.toString()); System.out.println(array.toString());

android端接收:

String urlAddress = "http://192.168.1.102:8080/qualityserver/result.do"; String body = getContent(urlAddress); JSONArray array = new JSONArray(body); for(int i=0;i<array.length();i++) { obj = array.getJSONObject(i); sb.append("用户名:").append(obj.getString("username")).append("\t"); sb.append("密码:").append(obj.getString("password")).append("\n"); HashMap<String, Object> map = new HashMap<String, Object>(); try { userName = obj.getString("username"); passWord = obj.getString("password"); } catch (JSONException e) { e.printStackTrace(); } map.put("username", userName); map.put("password", passWord); listItem.add(map); } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } if(sb!=null) { showResult.setText("用户名和密码信息:"); showResult.setTextSize(20); } else extracted(); //设置adapter SimpleAdapter simple = new SimpleAdapter(this,listItem, android.R.layout.simple_list_item_2, new String[]{"username","password"}, newint[]{android.R.id.text1,android.R.id.text2}); listResult.setAdapter(simple); listResult.setOnItemClickListener(new OnItemClickListener() { @Override publicvoid onItemClick(AdapterView<?> parent, View view, int position, long id) { int positionId = (int) (id+1); Toast.makeText(MainActivity.this, "ID:"+positionId, Toast.LENGTH_LONG).show(); } }); } privatevoid extracted() { showResult.setText("没有有效的数据!"); } //和服务器连接 private String getContent(String url)throws Exception{ StringBuilder sb = new StringBuilder(); HttpClient client =new DefaultHttpClient(); HttpParams httpParams =client.getParams(); HttpConnectionParams.setConnectionTimeout(httpParams, 3000); HttpConnectionParams.setSoTimeout(httpParams, 5000); HttpResponse response = client.execute(new HttpGet(url)); HttpEntity entity =response.getEntity(); if(entity !=null){ BufferedReader reader = new BufferedReader(new InputStreamReader (entity.getContent(),"UTF-8"),8192); String line =null; while ((line= reader.readLine())!=null){ sb.append(line +"\n"); } reader.close(); } return sb.toString(); }

URLConnection
HTTPClient

Proxies and SOCKS
Full support in Netscape browser, appletviewer, and applications (SOCKS: Version 4 only); no additional limitations from security policies.
Full support (SOCKS: Version 4 and 5); limited in applets however by security policies; in Netscape can't pick up the settings from the browser.

Authorization
Full support for Basic Authorization in Netscape (can use info given by the user for normal accesses outside of the applet); no support in appletviewer or applications.
Full support everywhere; however cannot access previously given info from Netscape, thereby possibly requesting the user to enter info (s)he has already given for a previous access. Also, you can add/implement additional authentication mechanisms yourself.

Methods
Only has GET and POST.
Has HEAD, GET, POST, PUT, DELETE, TRACE and OPTIONS, plus any arbitrary method.

Headers
Currently you can only set any request headers if you are doing a POST under Netscape; for GETs and the JDK you can't set any headers.
Under Netscape 3.0 you can read headers only if the resource was returned with a Content-length header; if no Content-length header was returned, or under previous versions of Netscape, or using the JDK no headers can be read.
Allows any arbitrary headers to be sent and received.

Automatic Redirection Handling
Yes.
Yes (as allowed by the HTTP/1.1 spec).

Persistent Connections
No support currently in JDK; under Netscape uses HTTP/1.0 Keep-Alive's.
Supports HTTP/1.0 Keep-Alive's and HTTP/1.1 persistence.

Pipelining of Requests
No.
Yes.

Can handle protocols other than HTTP
Theoretically; however only http is currently implemented.
No.

Can do HTTP over SSL (https)
Under Netscape, yes. Using Appletviewer or in an application, no.
No (not yet).

Source code available
No.
Yes.

更多相关文章

  1. Android切换前后置摄像头并录制视频
  2. android实现为PreferenceScreen设置背景图片等
  3. Android(安卓)Arduino 蓝牙模块通信源代码
  4. Android(安卓)onConfigurationChanged 不执行
  5. Android设置输入法
  6. android中,如果使用imageButton可以在drawable 中设置一个selecto
  7. Android(安卓)动画学习 二
  8. PopupWindow软键盘弹出遮挡输入框
  9. android图片上传服务器

随机推荐

  1. Android应用程序使用Localsocket与Linux
  2. Android国际化
  3. 动态设置android:drawableLeft|Right|Top
  4. Activity切换导致的onCreate重复执行
  5. 基于Android客户端的人人网开放平台开发
  6. Android图片下载缓存库picasso解析
  7. ListView.setOnItemClickListener、setOn
  8. Android: 自定义Tab样式
  9. Lock-free atomic operations in Android
  10. Android(安卓)各层中日志打印功能的应用