通俗易懂客户端与服务器端交互原理(HTTP数据请求与HTTP响应,包括Servlet部分)

转载 2007年09月25日 17:27:00
通俗易懂客户端与服务器端交互原理(HTTP数据请求与HTTP响应,包括Servlet部分)
 
作者:佚名 文章来源:本站原创 点击数: 46 更新时间:2007-8-20

经 常看到HTTP客户端与服务器端交互原理的各种版本的文章,但是专业术语太多,且流程过于复杂,不容易消化。于是就按照在 Servlet 里面的内容大致做了一些穿插。本来 连 Tomcat 容器 和 Servlet 的生命周期也准备在这里一起写的,但怕过去庞大,于是就简单的 引用了一些 Servlet 对象。这样的一个整个流程看下来,相信至少在理解 HTTP协议 和 request 和  response 是如何完成从请求到生成响应结果回发的。在后续的一些文章里会专门讲一讲 Tomcat  和 Servlet 是如何处理请求和完成响应的,更多的是说明Servlet 的生命周期。

HTTP介绍

1.HTTP是一种超文本传送协议(HyperText Transfer Protocol),是一套计算机在网络中通信的一种规则。在TCP/IP体系结构中,HTTP属于应用层协议,位于TCP/IP协议的顶层。

2.HTTP是一种无状态的的协议,意思是指 在Web 浏览器(客户端)和 Web 服务器之间不需要建立持久的连接。整个过程就是当一个客户端向服务器端发送一个请求(request),然后Web服务器返回一个响应 (response),之后连接就关闭了,在服务端此时是没有保留连接的信息。

3.HTTP 遵循 请求/响应(request/response) 模型的,所有的通信交互都被构造在一套请求和响应模型中。

4.浏览WEB时,浏览器通过HTTP协议与WEB服务器交换信息,Web服务器向Web浏览器返回的文件都有与之相关的类型,这些信息类型的格式由MIME定义。

HTTP定义的事务处理由以下四步组成:

1.建立连接

2.客户端发送HTTP请求头

3.服务器端响应生成结果 回发

4.服务器端关闭连接,客户端解析回发响应头,恢复页面

###############################################################################################

1.建立连接:以下用我的另一篇文章的地址做为例子

Servlet容器(Tomacat)介绍及配置

http://blog.csdn.net/lvpin/archive/2007/06/09/1645767.aspx

客户端,也就是我请求一个地址时 即打开了到 web 服务器的HTTP端口的一个套接字。因为在网络中间作为传递数据的实体介质就是网线,数据实质上是通过IO流进行输出和输入,这就不难理解我们为什么在写 一个Servlet的时候要引用 import java.io.*; 的原因 ,包括我们在向客户端回发结果的时候要用到 PrintWriter 对象的println()方法。

比如我在这里请求CSDN社区的一个地址http://blog.csdn.net

实际上首先要请求这个地址,以及一个端口80(8080)http://blog.csdn.net:80    80可以不写,是因为浏览器网页服务默认的端口号是 80.

在Java底层代码中是这样实现的,只不过它们已经帮我们做了。
Soceet socket=new Socket("blog.csdn.net",8080);
InputStream in=socket.getInputStream();
OutputStream out=socket.getOutputStream();

2.客户端发送HTTP请求头

一旦建立了TCP连接,Web浏览器就会向Web服务器发送请求命令,是一个ASCII文本请求行,后跟0个或多个HTTP头标,一个空行和实现请求的任意数据。

四个部分:请求行,请求头标,空行和请求数据

1)请求行由三个标记组成   请求方法     请求URL        HTTP版本 中间用空格分开

例如:                                      GET   lvpin/archive/2007/06/09/1645767.aspx  HTTP/1.1

HTTP规范定义了8种可能的请求方法:(最常见的就是 GET 和 POST 两种方法)
GET                 检索URI中标识资源的一个简单请求
HEAD               与GET方法相同,服务器只返回状态行和头标,并不返回请求文档
POST                服务器接受被写入客户端输出流中的数据的请求
PUT                 服务器保存请求数据作为指定URI新内容的请求
DELETE            服务器删除URI中命名的资源的请求
OPTIONS          关于服务器支持的请求方法信息的请求
TRACE             Web服务器反馈Http请求和其头标的请求
CONNECT        已文档化但当前未实现的一个方法,预留做隧道处理

2).请求头标:由key :value 健值组成,每行一对。请求头标 通知服务器有关客户端的功能和标识。

HOST               请求的哪一个服务器端地址,主地址 ,比如 我现在所在的CSDN blog.csdn.net/

User-Agent          用户即客户端可以使用的浏览器 ,如 : Mozilla/4.0

Accept                  即客户端可以接受的MIME 类型列表,如image/gif   text/html, application/msword

Content-Length    只适用于POST请求,以字节给出POST数据的尺寸

3)空行  发送回车符和退行,通知服务器以下不再有头标。

4)请求数据 : 使用POST传送数据,最常使用的是Content-Type和Content-Length头标。

总结以上 我们可以这样写出一个标准的 HTTP请求

POST  /lvpin/archive/2007/06/09/1645767.aspx HTTP1.1

HOST: blog.csdn.net/

User-Agent :Mozilla/4.0

Accpt: image/gif,text/html,application/pdf,image/png...

key=value&key=value&key=value.....................................(POST()请求的数据)

那么,这上面的一个例子说明的就是

我要去访问的服务器端的地址是blog.csdn.net/ 它下面的资源 /lvpin/archive/2007/06/09/1645767.aspx

连起来就是    http://blog.csdn.net/lvpin/archive/2007/06/09/1645767.aspx

这个页面用的是 HTTP1.1 规范 我的浏览器版本是Mozilla/4.0 

可以支持的MIME格式为  image/gif,text/html,application/pdf,image/png...等等

这个MIME格式我们在 response.setContentType("text/html;charset=gb2312");

                                       或者在一个 <%@ page contentType="text/html;charset=gb2312"%>

                                       或者<meta .....contentType="text/html;charset=gb2312"..>总能见到

那么在这里如何理解 GET 和 POST 最直观的区别,最明显的就是 GET方法将数据的请求跟在了所请求的URL后面,也就是 在请求行里面我们是这么样来做的:

GET  lvpin/archive/2007/06/09/1645767.aspx?key=value&key=value&key=value......HTTP1.1

也实际上就是 用 GET 如此传递数据 :

http://blog.csdn.net/ lvpin/archive/2007/06/09/1645767.aspxname=simon&password=simonlv........

3.服务器端接受请求,处理数据后生成响应返回数据到客户端 (部分Servlet 内容穿插)

Web 服务器 解析请求,定位指定的资源http://blog.csdn.net/lvpin/archive/2007/06/09/1645767.aspx

1)根据在 请求时的 GET/POST 来按照响应的 doGet() /doPost()方法来处理(有可能是一些业务逻辑,也有可能是一些验证等等,也有可能是一些数据查询,提交等等)其有效的数据就来源于name=simon&password=simonlv,还有 其它的一些封装在 request 对象中的数据资源。

2)处理请求之后,由 response 对象得到 PriterWriter 输出流对象out ,通过 out.println () 将数据以 在客户端提交过的采用的Accpt: 中形式的一种 如 按照 response.setcontentType("text/html;charset=gb2312' )的格式输出流。

它的响应信息与请求信息非常类似,其区别就在于 我们在请求阶段的请求行被状态行给替换了,再来看响应头


一个响应由四个部分组成;状态行、响应头标、空行、响应数据

1.状态行:状态行由三个标记组成:HTTP版本、响应代码和响应描述。

                                                                HTTP1.1    100              continue                          ------继续追加后继内容

                                                                HTTP/1.1   200               OK                                  --------一切正常

                                                                HTTP1.1    301  Moved Permanently    ---请求的文档在其它地方,会自动连接 

                                                                HTTP1.1     403  Forbidden   -------绝对拒绝你访问这个资源,不管授权没有

                                                                HTTP1.1     400    Bad Request  -----客户端请求中的不良语法

                                                                HTTP1.1      404   Not Found  ---最常见,绝对是大名鼎鼎的找不到

HTTP响应码:
1xx:提示性信息,告诉客户端应该对某些其它的动作作出响应

2xx:这些就代表了请求成功
3xx:重定向,为了完成请求,必须进一步执行的动作


4xx:客户端错误

500-599:服务器端的错误

2.响应头标:像请求头标一样,它们指出服务器的功能,标识出响应数据的细节。


Date: Sat, 31 Dec 2005 23:59:59 GMT                   --响应生成的日期和时间
ContentType: text/html;charset=gb2312'                                                                                                                                                               

Content-Length: 122 ---响应中的字节数,只在浏览器使用永久(Keep-alive)HTTP连接时需要。

3.空行:最后一个响应头标之后是一个空行,发送回车符和退行,表明服务器以下不再有头标。


4.响应数据:HTML文档和图像等,也就是HTML本身。out.println("<html>").......写出的。。。

<html>
<head>
<title>Welcom to simon lv 's home</title>
</head>
<body>
<!-- 这里是具体的内容,看到了这里

相信大家对 HTTP 工作原理和服务器交互过程已经很清楚了吧

-->
</body>
</html>

4.服务器端关闭连接,客户端解析回发响应头,恢复页面

1)浏览器先解析状态行,查看请求是否成功的状态代码--HTTP响应码:404 400 200 ....

2) 解析 每一个响应头标 如

ContentType: text/html;charset=gb2312  

                                                                                                                                               

Content-Length: 122 ---响应中的字节数,只在浏览器使用永久(Keep-alive)HTTP连接时需要。

3) 读取响应数据HTML,根据它的语法标签<html></html>等和内容恢复标准的HTML格式页面或者其它。

4)一个HTML 文档可能包含其它的需要被载入的资源,浏览器会识别,并对这些资源再进行额外的请求,这个过程可以一直循环到所有的数据都按照响应头标中规定的格式恢复到页面中。

5)数据传送完毕,服务器端关闭连接,即无状态协议。

写了很长时间,估计里面也有些没有表达清楚的地方,但是整个流程可以清晰的展现,对于大家理解HTTP请求头和响应头的内容以及他们之间的关系应该很有帮助。

 

通俗易懂客户端与服务器端交互原理(HTTP数据请求与HTTP响应,包括Servlet部分

经 常看到HTTP客户端与服务器端交互原理的各种版本的文章,但是专业术语太多,且流程过于复杂,不容易消化。于是就按照在 Servlet 里面的内容大致做了一些穿插。本来 连 Tomcat 容器 和 S...
  • ahngzw77
  • ahngzw77
  • 2015年01月15日 15:20
  • 322

通俗易懂客户端与服务器端交互原理(HTTP数据请求与HTTP响应,包括Servlet部分)

经常看到HTTP客户端与服务器端交互原理的各种版本的文章,但是专业术语太多,且流程过于复杂,不容易消化。于是就按照在 Servlet 里面的内容大致做了一些穿插。本来 连 Tomcat 容器 和 Se...
  • hushup
  • hushup
  • 2014年05月06日 08:49
  • 651

通俗易懂客户端与服务器端交互原理(HTTP数据请求与HTTP响应,包括Servlet部分)

经常看到HTTP客户端与服务器端交互原理的各种版本的文章,但是专业术语太多,且流程过于复杂,不容易消化。于是就按照在 Servlet 里面的内容大致做了一些穿插。本来 连 Tomcat 容器 和 Se...
  • fengshanghere
  • fengshanghere
  • 2017年07月09日 15:33
  • 435

Android客户端和服务器端数据交互的第四种方法

Android客户端和服务器端数据交互的第四种方法
  • wangshuxuncom
  • wangshuxuncom
  • 2015年01月15日 15:29
  • 4025

关于http和serverlet实现服务器和客户端的交互

HttpServlet详解 Servlet的框架是由两个Java包组成:javax.servlet和javax.servlet.http. 在javax.servlet包中定义了所有的Servlet...
  • wangkun__
  • wangkun__
  • 2016年05月15日 22:46
  • 7739

Servlet处理客户端HTTP请求

本篇博客将在上一篇博客《Servlet第一个示例》的基础上继续介绍,Servlet如何处理客户端的请求,获得客户端的请求消息。...
  • jianggujin
  • jianggujin
  • 2016年01月28日 10:26
  • 2706

HTTP服务器与android客户端的json交互

旨在展示Android与Web服务器的Json数据交互过程。
  • shangmingchao
  • shangmingchao
  • 2014年04月11日 22:49
  • 11608

使用Servlet处理HTTP请求

1、使用Servlet接受服务器端请求信息: (1)get/post提交方法:当点击超链接、提交表单、输入URL并回车时,浏览器向Web服务器发送HTTP请求 (2)两种提交方法的比较:get:①...
  • interface2016
  • interface2016
  • 2016年10月24日 22:05
  • 479

Android 客户端与服务器端进行数据交互(二、登录客户端)

概要Android客户端分为User,HttpUtil,HttpCallbackListener,MainActivity四个部分。User model与服务端的一样,一方面是用于本地用户信息的存储m...
  • u012145166
  • u012145166
  • 2016年05月06日 22:54
  • 10150

走进Java Web开发 ——客户端与服务器的交互原理

在web程序中不太容易搞清楚的就是客户端和服务器。这也是B/S结构的一大特点,C/S结构的客户端和服务器非常明了,没有其他的辅助技术。在B/S中将很多技术都分离出来成为独立的技术,让其变得更加灵活。(...
  • pengzhenjie36
  • pengzhenjie36
  • 2016年09月09日 11:18
  • 2278
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:通俗易懂客户端与服务器端交互原理(HTTP数据请求与HTTP响应,包括Servlet部分)
举报原因:
原因补充:

(最多只允许输入30个字)