《老罗Android》学习之 HTTP编程(一)

1. HTTP协议的定义
   WWW是以Internet作为传输媒介的一个应用系统,WWW网上基本的传输单位是Web网页。WWW的工作是基于客户机/服务器计算模型,由Web浏览器和Web服务器构成,即B/S结构,两者之间采用超文本传输协议HTTP进行通信。
   HTTP协议是基于TCP/IP协议之上的协议,是Web浏览器和Web服务器之间的应用层的协议,是通用的、无状态的面向对象的协议。
  如果要实现网络互联我们要思考两个需要解决的技术问题:
第一:浏览器和服务器是通过什么来连接的。
第二:这种连接方式是怎么实现的。

通过Internet去发送到服务器当中,而Internet内部可以通过三种方式来实现发送信息和数据:
第一种:HTTP协议,也是在工作中最常用的,是建立在TCP/IP基础上实现的。
第二种:FTP协议
第三种:TCP/IP协议,它也是最底层的协议,其它的方式必须是要通过它,但是要想实现这种协议必须要实现socket编程,这种方法是用来上传一些比较大的文件,视频,进行断点续传的操作。
2. HTTP协议实例剖析
客户端连接服务器实现内部的原理如下:
 
流程分析:
第一步:在浏览器客户端中得到用户输入的内容。
第二步:浏览器得到这个网址之后,内部会将这个域名发送到DNS上,进行域名解析。得到它的IP之后就会链接到指定的服务器上,假如服务器的地址是:221.104.13.32:80,从浏览器到服务器端口它使用到最底层的TCP/IP协议
第三步:实现TCP/IP协议用Socket来完成,使用了Socket的套接字。
第四步:服务器端的80端口监听客户端的链接,这样客户端到服务器就链接上了。
HTTP请求体的内容介绍
   

  1. <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> 
  2. <%String path = request.getContextPath();%> 
  3. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
  4. <html> 
  5.     <head> 
  6.         <title>测试HTTP协议体的内容</title> 
  7.         <meta http-equiv="pragma" content="no-cache"> 
  8.         <meta http-equiv="cache-control" content="no-cache"> 
  9.         <meta http-equiv="expires" content="0"> 
  10.         <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> 
  11.         <meta http-equiv="description" content="This is my page"> 
  12.         <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> 
  13.     </head> 
  14.     <body> 
  15.         <form name="form1"  method="post" action="<%=path %>/LonginServlet"> 
  16.             用户名: 
  17.             <input type="text" name="username" value="admin" /><br /> 
  18.             密  码: 
  19.             <input type="password" name="password" value="123" /><br /> 
  20.             <input type="submit" name="submit" value="提交表单" /> 
  21.         </form> 
  22.     </body> 
  23. </html> 
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%String path = request.getContextPath();%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
	<head>
		<title>测试HTTP协议体的内容</title>
		<meta http-equiv="pragma" content="no-cache">
		<meta http-equiv="cache-control" content="no-cache">
		<meta http-equiv="expires" content="0">
		<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
		<meta http-equiv="description" content="This is my page">
		<!--	<link rel="stylesheet" type="text/css" href="styles.css">	-->
	</head>
	<body>
		<form name="form1"  method="post" action="<%=path %>/LonginServlet">
			用户名:
			<input type="text" name="username" value="admin" /><br />
			密  码:
			<input type="password" name="password" value="123" /><br />
			<input type="submit" name="submit" value="提交表单" />
		</form>
	</body>
</html>

<form name="form1"  method="post" action="<%=path %>/LonginServlet"> 表单中方法为 post, 所以提交后会跳转到 "<%=path %>/LonginServlet",转换一下是:http://192.168.1.105:8080/MyHTTP/LonginServlet;    并调用 LonginServlet.java 的 doPost()方法.
HTTP响应的内容介绍
   
可以用 HTTPWatch 工具查一下,这个操作的过程, HTTPWatch 是IE 的一个插件,安装后,用IE浏览器打开,查看---> 浏览栏 就可以看到这个HTTPWatch .
 
   在这里面可以测试到响应时间,结果,头部信息等信息.
在这里面有个 Cookies: JSESSIONIDSent 5444476F20784E44DECCC2900186336D
当用户登录时,点击登录按钮后,可能等的时间比较长,就多点了几次,这样就多次登录了. 服务器怎么判断是哪个用户呢? 所有在HTTP的协议体当中要把Cookies的JSESSIONID返回给客户端,客户端就知道是哪个用户登录了.
HTTP返回请求数据的三种方式
服务器接收到这些内容之后,并按照这些请求的路径找到对应的页面,进一步找到对应的网页内容,返回给客户端。
服务器返回客户端的内容有三种方式:
1、以HTML代码内容返回。
2、以XML字符串的形式返回,在以后的android开发中这种形式返回数据比较多。
3、以JSON对象形式返回,在网络流量上考虑JSON要比XML方式要好一些,便于解析。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章