【Android开发】网络编程及Internet应用-通过HTTP访问网络

简介:
通有线互联网一样,移动互联网也可以使用HTTP访问网络。在Android中,针对HTTP进行网络通信的方法主要有两种,一种是使用HttpURLConnection实现;另一种是使用HttpClient实现。下面分别进行介绍

1.使用HttpURLConnection访问网络

HttpURLConnection位于java.net包中,用于发送HTTP请求和获取HTTP响应。由于该类是抽象类,不能直接实例化对象,则需要使用URL的openConnection()方法来获得。例如,要创建一个http://www.baidu.com网站对应的HttpURLConnection对象,可以使用下面的代码:
URL url=new URL("http://www.baidu.com");
HttpURLConnection urlConnection=(HttpURLConnection)url.openConnection();

创建了HttpURLConnection对象后,就可以使用该对象发送HTTP请求了。HTTP请求分为GET请求和POST请求。下面分别进行介绍。

a.发送GET请求

使用HttpURLConnection发送请求默认使用GET。使用比较简单,将需要传递的参数通过在url路径后方加入"?参数名=参数值"进行传递(多个参数用"&"或","分隔),然后获取流中的数据,并关闭连接即可。

下面通过一个具体的实例说明如何使用HttpURLConnection发送GET请求
功能:在编辑框中输入信息,点击“send”按钮,就会将信息发到服务器端,且在客户端的文字框控件中查看。

界面:模拟发微博,上面是编辑框和发送按钮,下面是从服务器读取的微博内容
res/layout/main.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/ll1"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >
	<EditText android:id="@+id/content"
	    android:layout_width="match_parent"
	    android:layout_height="wrap_content"/>
	<Button android:id="@+id/button"
	    android:layout_width="wrap_content"
	    android:layout_height="wrap_content"
	    android:text="send"/>
	<ScrollView android:id="@+id/scrollView1"
	    android:layout_width="match_parent"
	    android:layout_height="wrap_content"
	    android:layout_weight="1">
	    <LinearLayout android:id="@+id/ll2"
	        android:layout_width="match_parent"
	        android:layout_height="match_parent">
	        <TextView android:id="@+id/result"
	            android:layout_width="match_parent"
	            android:layout_height="wrap_content"
	            android:layout_weight="1"/>
	    </LinearLayout>
	</ScrollView>

</LinearLayout>

界面效果如图



主界面:
MainActivity:
package com.example.test;  
  
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLEncoder;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.util.Base64;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.Window;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;
  
public class MainActivity extends Activity{  
	private EditText content;//声明一个输入文本内容的编辑框对象
	private Button button;//声明一个"发表"按钮对象
	private Handler handler;//声明一个Handler对象
	private String result="";//声明一个代表显示内容的字符串
	private TextView resultTV;//声明一个显示结果的文本框对象
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        requestWindowFeature(Window.FEATURE_NO_TITLE);//设置全屏显示
        setContentView(R.layout.main);
        
        content=(EditText)findViewById(R.id.content);
        resultTV=(TextView)findViewById(R.id.result);
        button=(Button)findViewById(R.id.button);
        //为按钮添加单击事件监听
        button.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View arg0) {
				 if("".equals(content.getText().toString())){
					 Toast.makeText(MainActivity.this, "请输入要发表的内容!",
							 Toast.LENGTH_SHORT).show();//显示消息提示
					 return;
				 }
				 //创建一个新线程,用于发送并读取微博信息
				 new Thread(new Runnable() {
					
					@Override
					public void run() {
						send();//发送文本至web服务器,并读取
						Message m=handler.obtainMessage();//获取一个Message
						handler.sendMessage(m);//发送消息
					}
				}).start();//开启线程
				
			}
		});
        
        handler=new Handler(){


			@Override
			public void handleMessage(Message msg) {
				if(result!=null){
					resultTV.setText(result);//显示获得的结果
					content.setText("");//清空编辑框
				}
				super.handleMessage(msg);
			}
        	
        };
    }
    
    /*
     * send()方法用于建立一个HTTP连接,并将输入的内容发送到Web服务器上,
     * 再读取服务器的处理结果
     * */
    public void send() {
		 String target="http://192.168.1.100:8080/WeiXinTest/index.jsp?content="
				 						+base64(content.getText().toString().trim());//要访问的url地址
		 URL url;
		 try {
			url=new URL(target);//创建URL对象
			HttpURLConnection urlConn=(HttpURLConnection)url.openConnection();//创建一个HTTP连接
			InputStreamReader in=new InputStreamReader(urlConn.getInputStream());//获得读取的内容
			BufferedReader buffer=new BufferedReader(in);//获得输入流对象
			String inputLine=null;
		    //通过循环逐行读取输入流中的内容
			while((inputLine=buffer.readLine())!=null){
				result+=inputLine+"\n";
			}
			in.close();//关闭字符输入流对象
			urlConn.disconnect();//断开连接
		} catch (MalformedURLException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}


	}


    /*
     * 用GET方法传递中文参数时,会产生乱码,
     * 需要用Base64编码来解决乱码问题
     * */
	private String base64(String content) {
		try {
			//对字符串进行Base64编码
			content=Base64.encodeToString(content.getBytes("utf-8"),Base64.DEFAULT);
			content=URLEncoder.encode(content);//对字符串进行URL编码
		} catch (UnsupportedEncodingException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return content;
	}
}  

在安卓的配置文件AndroidManifest.xml中别忘记加入访问网络的权限:
<!-- 添加链接网络的权限 -->
<uses-permission android:name="android.permission.INTERNET"/>

在JAVAEE工作台(或MyEclipse)中创建一个名为"WenXinTest"的Web应用,在index.jsp中写下如下关键代码:
<%@ page language="java" import="java.util.*,sun.misc.BASE64Decoder" pageEncoding="UTF-8"%>

<%
   String content="";
   if(request.getParameter("content")!=null){
   	content=request.getParameter("content");//获取输入的微博信息
   	//替换content中的加号,这是由于在进行URL编码时,将"+"号转换为了%2B
   	content=content.replaceAll("%2B","+");
   	BASE64Decoder decoder=new BASE64Decoder();
   	content=new String(decoder.decodeBuffer(content),"utf-8");
   }
 %>
 <%="发一条微博,内容如下:" %>
 <%=content %>

接着将应用部署至tomcat,启动tomcat进行测试。

客户端测试结果如图


证明数据已经由客户端发至Web应用,然后经由服务端处理后发回客户端

b.发送POST请求
由于采用GET方式发送请求只适合发送大小在1024个字节以内的数据,所以当要发送的数据较大时,就需要使用POST方式发送请求。
发送POST请求,需要通过其setRequestMethod()方法进行指定。例如,创建一个HTTP连接,并为该连接指定请求发送的方式为POST,可以使用下面的代码:
URL url=new URL("http://www.baidu.com");
HttpURLConnection urlConnection=(HttpURLConnection)url.openConnection();
urlConnection.setRequestMethod("POST");

发送POST请求要比发送GET请求复杂一些,它通常需要通过HttpURLConnection类以及其父类URLConnection提供的方法设置相关内容,常用的方法如表所示:
setDoInput(boolean newValue)用于设置是否向连接中写入数据,如果参数为true,表示写入数据;否则不写入数据
setDoOutput(boolean newValue)用于设置是否向连接中读取数据,如果参数为true,表示写入数据;否则不读取数据
setUseCaches(boolean newValue)用于设置是否缓存数据,如果参数为true,表示缓存数据;否则不缓存数据
setInstanceFollowRedirects(boolean followRedirects)用于设置是否应该自动执行HTTP重定向,如果参数为true,表示自动执行;否则不自动执行
setRequestProperty(String field,String newVlaue)用于设置一般请求属性,例如要设置内容类型为表单数据,可以进行以下设置:
setRequestProperty("content-Type","applcation/x-www-form-urlencoded");


下面通过一个具体的实例来介绍如何使用HttpURLConnection类发送请求
功能:在编辑框中输入信息和昵称,点击“send”按钮,就会将信息发到服务器端,且在客户端的文字框控件中查看。


界面:模拟发微博,上面是两个编辑框和发送按钮,下面是从服务器读取的微博内容
res/layout/main.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/ll1"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >
    <TextView android:text="信息:"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>
	<EditText android:id="@+id/content"
	    android:layout_width="match_parent"
	    android:layout_height="wrap_content"/>
	<TextView android:text="昵称:"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>
	<EditText android:id="@+id/nickname"
	    android:layout_width="match_parent"
	    android:layout_height="wrap_content"/>
	<Button android:id="@+id/button"
	    android:layout_width="wrap_content"
	    android:layout_height="wrap_content"
	    android:text="send"/>
	<ScrollView android:id="@+id/scrollView1"
	    android:layout_width="match_parent"
	    android:layout_height="wrap_content"
	    android:layout_weight="1">
	    <LinearLayout android:id="@+id/ll2"
	        android:layout_width="match_parent"
	        android:layout_height="match_parent">
	        <TextView android:id="@+id/result"
	            android:layout_width="match_parent"
	            android:layout_height="wrap_content"
	            android:layout_weight="1"/>
	    </LinearLayout>
	</ScrollView>


</LinearLayout>

界面效果如图




主界面:
MainActivity:
package com.example.test;  
  
import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLEncoder;


import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.util.Base64;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.Window;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;
  
public class MainActivity extends Activity{  
	private EditText content;//声明一个输入文本内容的编辑框对象
	private EditText nickname;//声明一个输入昵称的编辑框对象
	private Button button;//声明一个"发表"按钮对象
	private Handler handler;//声明一个Handler对象
	private String result="";//声明一个代表显示内容的字符串
	private TextView resultTV;//声明一个显示结果的文本框对象
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        requestWindowFeature(Window.FEATURE_NO_TITLE);//设置全屏显示
        setContentView(R.layout.main);
        
        content=(EditText)findViewById(R.id.content);
        nickname=(EditText)findViewById(R.id.nickname);
        resultTV=(TextView)findViewById(R.id.result);
        button=(Button)findViewById(R.id.button);
        //为按钮添加单击事件监听
        button.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View arg0) {
				 if("".equals(content.getText().toString())){
					 Toast.makeText(MainActivity.this, "请输入要发表的内容!",
							 Toast.LENGTH_SHORT).show();//显示消息提示
					 return;
				 }
				 //创建一个新线程,用于发送并读取微博信息
				 new Thread(new Runnable() {
					
					@Override
					public void run() {
						send();//发送文本至web服务器,并读取
						Message m=handler.obtainMessage();//获取一个Message
						handler.sendMessage(m);//发送消息
					}
				}).start();//开启线程
				
			}
		});
        
        handler=new Handler(){


			@Override
			public void handleMessage(Message msg) {
				if(result!=null){
					resultTV.setText(result);//显示获得的结果
					content.setText("");//清空编辑框
					nickname.setText("");//清空昵称框
				}
				super.handleMessage(msg);
			}
        	
        };
    }
    
    /*
     * send()方法用于建立一个HTTP连接,并将输入的内容发送到Web服务器上,
     * 再读取服务器的处理结果
     * */
    public void send() {
		 String target="http://192.168.1.113:8080/WeiXinTest/index.jsp";//要访问的url地址
		 URL url;
		 try {
			url=new URL(target);//创建URL对象
			HttpURLConnection urlConn=(HttpURLConnection)url.openConnection();//创建一个HTTP连接
			urlConn.setRequestMethod("POST");//指定使用POST请求方式
			urlConn.setDoInput(true);//设置允许向连接中写入数据
			urlConn.setDoOutput(true);//设置允许从连接中读取数据
			urlConn.setUseCaches(false);//禁止缓存
			urlConn.setInstanceFollowRedirects(true);//自动执行HTTP重定向
			urlConn.setRequestProperty("Content-Type", 
					"application/x-www-form-urlencoded");//设置内容类型
			
			DataOutputStream out=new DataOutputStream(urlConn.getOutputStream());//获取输出流
			String param="nickname="+URLEncoder.encode(nickname.getText().toString(),"utf-8")
					+"&content="+URLEncoder.encode(content.getText().toString(),"utf-8");//连接要提交的数据


			out.writeBytes(param);//将要传递的数据写入数据输出流
			out.flush();//输出缓存
			out.close();//关闭数据输出流
			
			//判断相应是否成功
			if(urlConn.getResponseCode()==HttpURLConnection.HTTP_OK){
				InputStreamReader in=new InputStreamReader(urlConn.getInputStream());//获得读取的内容
				BufferedReader buffer=new BufferedReader(in);//获得输入流对象
				String inputLine=null;
			    //通过循环逐行读取输入流中的内容
				while((inputLine=buffer.readLine())!=null){
					result+=inputLine+"\n";
				}
				in.close();//关闭字符输入流对象
			}
			urlConn.disconnect();//断开连接
		} catch (MalformedURLException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}


	}
    
}    

在安卓的配置文件AndroidManifest.xml中别忘记加入访问网络的权限:
<!-- 添加链接网络的权限 -->
<uses-permission android:name="android.permission.INTERNET"/>

在JAVAEE工作台(或MyEclipse)中创建一个名为"WenXinTest"的Web应用,在index.jsp中写下如下关键代码:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<%
   String content=request.getParameter("content");//获取微博信息
   String nickname=request.getParameter("nickname");//获取昵称
   if(content!=null&&nickname!=null){
       nickname=new String(nickname.getBytes("iso-8859-1"),"utf-8");//转码
       content=new String(content.getBytes("iso-8859-1"),"utf-8");//转码
       String date=new java.util.Date().toLocaleString();//获取系统时间
 %>
 <%="【"+nickname+"】于"+date+"发表一条微博,内容如下:" %>
 <%=content %>
 <% }%>

接着将应用部署至tomcat,启动tomcat进行测试。

客户端测试结果如图


证明数据已经由客户端发至Web应用,然后经由服务端处理后发回客户端


转载请注明出处:http://blog.csdn.net/acmman/article/details/46414315

相关文章
|
1月前
|
安全 网络安全 数据安全/隐私保护
访问控制列表(ACL)是网络安全中的一种重要机制,用于定义和管理对网络资源的访问权限
访问控制列表(ACL)是网络安全中的一种重要机制,用于定义和管理对网络资源的访问权限。它通过设置一系列规则,控制谁可以访问特定资源、在什么条件下访问以及可以执行哪些操作。ACL 可以应用于路由器、防火墙等设备,分为标准、扩展、基于时间和基于用户等多种类型,广泛用于企业网络和互联网中,以增强安全性和精细管理。
207 7
|
1月前
|
JSON Java Apache
非常实用的Http应用框架,杜绝Java Http 接口对接繁琐编程
UniHttp 是一个声明式的 HTTP 接口对接框架,帮助开发者快速对接第三方 HTTP 接口。通过 @HttpApi 注解定义接口,使用 @GetHttpInterface 和 @PostHttpInterface 等注解配置请求方法和参数。支持自定义代理逻辑、全局请求参数、错误处理和连接池配置,提高代码的内聚性和可读性。
148 3
|
3天前
|
Kubernetes 网络协议 应用服务中间件
Kubernetes Ingress:灵活的集群外部网络访问的利器
《Kubernetes Ingress:集群外部访问的利器-打造灵活的集群网络》介绍了如何通过Ingress实现Kubernetes集群的外部访问。前提条件是已拥有Kubernetes集群并安装了kubectl工具。文章详细讲解了Ingress的基本组成(Ingress Controller和资源对象),选择合适的版本,以及具体的安装步骤,如下载配置文件、部署Nginx Ingress Controller等。此外,还提供了常见问题的解决方案,例如镜像下载失败的应对措施。最后,通过部署示例应用展示了Ingress的实际使用方法。
18 2
|
28天前
|
前端开发 UED 开发者
CSS Sprites和图标字体在网页图标加载优化中的应用。CSS Sprites通过合并多图标减少HTTP请求,提升加载速度
本文探讨了CSS Sprites和图标字体在网页图标加载优化中的应用。CSS Sprites通过合并多图标减少HTTP请求,提升加载速度;图标字体则以字体形式呈现图标,便于调整样式。文章分析了两者的优缺点及应用场景,并提供了应用技巧和注意事项,旨在帮助开发者提升页面性能,改善用户体验。
24 5
|
1月前
|
网络协议 安全 文件存储
动态DNS(DDNS)技术在当前网络环境中日益重要,它允许使用动态IP地址的设备通过固定域名访问
动态DNS(DDNS)技术在当前网络环境中日益重要,它允许使用动态IP地址的设备通过固定域名访问,即使IP地址变化,也能通过DDNS服务保持连接。适用于家庭网络远程访问设备及企业临时或移动设备管理,提供便捷性和灵活性。示例代码展示了如何使用Python实现基本的DDNS更新。尽管存在服务可靠性和安全性挑战,DDNS仍极大提升了网络资源的利用效率。
53 6
|
1月前
|
安全 网络安全 数据安全/隐私保护
访问控制列表(ACL)是网络安全管理的重要工具,用于定义和管理网络资源的访问权限。
访问控制列表(ACL)是网络安全管理的重要工具,用于定义和管理网络资源的访问权限。ACL 可应用于路由器、防火墙等设备,通过设定规则控制访问。其类型包括标准、扩展、基于时间和基于用户的ACL,广泛用于企业网络和互联网安全中,以增强安全性、实现精细管理和灵活调整。然而,ACL 也存在管理复杂和可能影响性能的局限性。未来,ACL 将趋向智能化和自动化,与其他安全技术结合,提供更全面的安全保障。
97 4
|
1月前
|
缓存 安全 网络安全
HTTP/2与HTTPS在Web加速中的应用
HTTP/2与HTTPS在Web加速中的应用
|
1月前
|
缓存 安全 前端开发
HTTP 协议的请求方法在实际应用中有哪些注意事项?
【10月更文挑战第29天】HTTP协议的请求方法在实际应用中需要根据具体的业务场景和需求,合理选择和使用,并注意各种方法的特点和限制,以确保网络通信的安全、高效和数据的一致性。
|
10天前
|
SQL 安全 网络安全
网络安全与信息安全:知识分享####
【10月更文挑战第21天】 随着数字化时代的快速发展,网络安全和信息安全已成为个人和企业不可忽视的关键问题。本文将探讨网络安全漏洞、加密技术以及安全意识的重要性,并提供一些实用的建议,帮助读者提高自身的网络安全防护能力。 ####
47 17
|
20天前
|
存储 SQL 安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
随着互联网的普及,网络安全问题日益突出。本文将介绍网络安全的重要性,分析常见的网络安全漏洞及其危害,探讨加密技术在保障网络安全中的作用,并强调提高安全意识的必要性。通过本文的学习,读者将了解网络安全的基本概念和应对策略,提升个人和组织的网络安全防护能力。