`

Java web程序之客户端和服务器端交互原理

 
阅读更多

1. 协议

a. TCP/IP整体构架概述

TCP/IP协议并不完全符合OSI的七层参考模型。传统的开放式系统互连参考模型,是一种通信协议的7层抽象的参考模型,其中每一层执行某一特定任务。该模型的目的是使各种硬件在相同的层次上相互通信。这7层是:物理层、数据链路层、网路层、传输层、话路层、表示层和应用层。而TCP/IP通讯协议采用了4层的层级结构,每一层都呼叫它的下一层所提供的网络来完成自己的需求。这4层分别为:

i. 应用层:应用程序间沟通的层,如超文本传送协议(HTTP)、简单电子邮件传输(SMTP)、文件传输协议(FTP)、网络远程访问协议(Telnet)等。

ii. 传输层:在此层中,它提供了节点间的数据传送服务,如传输控制协议(TCP)、用户数据报协议(UDP)等,TCP和UDP给数据包加入传输数据并把它传输到下一层中,这一层负责传送数据,并且确定数据已被送达并接收。

iii. 互连网络层:负责提供基本的数据封包传送功能,让每一块数据包都能够到达目的主机(但不检查是否被正确接收),如网际协议(IP)。

iv. 网络接口层:对实际的网络媒体的管理,定义如何使用实际网络(如Ethernet、Serial Line等)来传送数据。

b. HTTP协议介绍:

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

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

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

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

c. 协议的java实现方式

不论是TCP/IP协议也好,还是HTTP协议也好,java都是通过套接字(java.net.Socket)来实现的,可以参考我的另一篇技术博客:一个项目看java TCP/IP Socket编程(1.3版)

2. HTTP报文接口及客户端和服务器端交互原理

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

i. 建立连接:

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

在Java底层代码中是这样实现的,只不过它们已经帮我们做了。

  1. Socket socket = new Socket("cuishen.iteye.com",80);    
  2. InputStream in = socket.getInputStream();    
  3. OutputStream out = socket.getOutputStream();   

ii. 客户端发送HTTP请求报文(request)

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

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

1)请求行

请求行由三个标记组成:请求方法、请求URL和HTTP版本,中间用空格分开

例如: GET cuishen.iteye.com/blog/242842 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 -- 请求的哪一个服务器端地址,主地址,比如:我的技术blog:cuishen.iteye.com
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 /blog/242842 HTTP1.1
HOST: cuishen.iteye.com/
User-Agent: Mozilla/4.0
Accpt: image/gif,text/html,application/pdf,image/png...
key=value&key=value&key=value...... (POST()请求的数据)

 

这上面的一个例子意思是:

 

我要去访问的服务器端的地址是cuishen.iteye.com/ 它下面的资源 /blog/242842
连起来就是: cuishen.iteye.com/blog/242842
这个页面用的是 HTTP1.1 规范,我的浏览器版本是Mozilla/4.0
可以支持的MIME格式为 image/gif,text/html,application/pdf,image/png...等等
这个MIME格式我们在servlet中写法是:response.setContentType("text/html;charset=gb2312");
或者在jsp中写法是:<%@ page contentType="text/html;charset=gb2312"%>
或者在html中写法是:<meta http-equiv="content-Type" content="text/html; charset=gb2312">

 

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

  1. GET /blog/242842?key=value&key=value&key=value......HTTP1.1 

实际上用 GET 是这样传递数据的:

  1. http://cuishen.iteye.com/?page=2...... 

iii.服务器端响应请求生成结果并回发(response)

Web 服务器解析请求,定位指定的资源 http://cuishen.iteye.com/blog/242842

1)根据请求时的 GET/POST 对应的用servlet里的 doGet() / doPost()方法来处理(有可能是一些业务逻辑,也有可能是一些验证等等,也有可能是一些数据查询,提交等等)其有效的数据就来源于key=value&key=value&key=value......,以及其它的一些封装在 request 对象中的数据资源。

2)处理请求之后,由 response 对象得到 java.io.PrintWriter 输出流对象out,通过 out.println(); 将数据以指定的格式,如按照response.setcontentType("text/html;charset=gb2312");的格式输出到输出流。

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

3)一个响应报文由四个部分组成:状态行、响应头标、空行、响应数据:

(a).状态行:

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

 

HTTP1.1 --- 100 --- continue //继续追加后继内容
HTTP1.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: 服务器端的错误

 

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

 

Date: Sat, 31 Dec 2005 23:59:59 GMT --响应生成的日期和时间
ContentType: 'text/html;charset=gb2312'
Content-Length: 122 --响应中的字节数,只在浏览器使用永久(Keep-alive)HTTP连接时需要。

 

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

(d).响应数据:HTML文档和图像等,也就是HTML本身。out.println("<html>......");写到客户端。

  1. <html>    
  2. <head>    
  3. <title>Welcome to cuishen's IT blog</title>    
  4. </head>    
  5. <body>    
  6. <!-- 这里是具体的内容,看到了这里    
  7. 相信大家对 HTTP 工作原理及客户端与服务器交互过程已经很清楚了吧    
  8. -->     
  9. </body>    
  10. </html> 

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

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)数据传送完毕,服务器端关闭连接,即无状态协议。

3. 总结

不要被高深的名词和理论吓到,其实HTTP客户端和服务器端的交互原理很简单:即先是浏览器和服务器端建立Socket无状态连接,也就是短连接,然后通过IO流进行报文信息(这个报文是严格遵循HTTP报文接口的)的交互,最后会话结束后就关闭连接。对于这些底层的协议和报文的打包解包交互的实现,其实java和浏览器早都已经封装好了,程序员只要专注于业务逻辑的实现就行啦,这些都不必关心!!

原文链接:http://www.cnblogs.com/lys_013/archive/2012/05/05/2484561.html

分享到:
评论

相关推荐

    浅析Java_web程序之客户端和服务器端交互原理.doc

    Java Web程序中的客户端和服务器端交互是Web开发的基础,它涉及到网络通信协议、HTTP协议以及Java编程中的Socket编程。在本文中,我们将深入探讨这两个主要方面:协议和HTTP报文接口,以及它们如何在Java Web应用...

    Java-web客户端和服务器端交互的原理.doc

    Java-web客户端和服务器端交互的原理 Java-web客户端和服务器端交互的原理可以分为三个部分:客户端、服务器端和协议。客户端和服务器端之间通过socket无状态连接进行交互,通过IO流进行报文信息交互,最后会话结束...

    客户端和服务器端的简单通信

    本教程将深入讲解如何使用Java的Socket API来实现客户端与服务器端的简单通信,实现一个基础的聊天功能。 首先,我们要理解客户端和服务器端的概念。客户端是发起请求的一方,而服务器端则是接收并响应请求的一方。...

    Android客户端和服务器端数据交互Demo01.zip

    这个"Android客户端和服务器端数据交互Demo01.zip"应该包含一个示例项目,展示了如何在Android平台上进行这种交互。下面,我们将深入探讨这个主题,并基于"参考博客.txt"和"Android客户端和服务器端数据交互Demo01...

    详解Android客户端与服务器交互方式

    最近的Android项目开发过程中一个问题困扰自己很长时间,Android客户端与服务器交互有几种方式,最常见的就是webservices和json。要在Android手机客户端与pc服务器交互,需要满足下面几种条件:跨平台、传输数据格式...

    android客户端与后台服务器交互

    在项目中,`androidweb`可能是服务器端的代码,包括Struts、Hibernate和Spring的配置文件、Java源代码等。而`AndroidCLient`则是Android客户端应用的代码,包含AndroidManifest.xml、布局文件、Activity、Service等...

    android客户端和服务器端交互

    总的来说,Android客户端与服务器端交互的过程涉及网络请求、数据格式处理、安全性措施以及用户体验优化等多个技术点。开发者需要熟练掌握这些知识,并在实际项目中灵活运用,以构建稳定、安全的移动应用。

    Android 客户端与服务器端进行数据交互Demo(包含服务器端和客户端)

    在Android开发中,客户端与服务器端的数据交互是应用程序的核心功能之一。这个Demo涵盖了从客户端到服务器端的基本数据发送和接收,以及验证过程。下面将详细解释这个Demo涉及到的知识点。 1. **Android网络请求库*...

    Java 客户端服务器程序 学习笔记

    在这个“Java客户端服务器程序学习笔记”中,我们将深入探讨这一主题,包括如何设计、实现和交互这两个关键组件。 首先,客户端是用户与系统进行交互的部分,它发送请求到服务器并接收响应。服务器端则处理这些请求...

    Android通过get,post方式客户端与服务器端交互实例

    总结,Android客户端与服务器端交互涉及HTTP协议中的GET和POST方法,可以通过原生的HttpURLConnection或者第三方库如OkHttp实现。GET用于获取资源,POST则用于提交数据。在实际应用中,还需要考虑安全性和性能优化。...

    客户端与服务器的对话程序,有UI界面

    综上所述,这个项目涵盖了客户端编程、服务器端编程以及两者之间的交互,是学习和理解Java网络编程、Servlet技术以及UI设计的宝贵实践案例。通过深入研究和分析,开发者可以进一步提升自己的技能,并应用于更复杂的...

    Android客户端和服务器端数据交互Demo03.zip

    综上所述,"Android客户端和服务器端数据交互Demo03"这个项目覆盖了Android应用开发中的诸多核心概念,包括网络请求、数据解析、错误处理、后台任务以及安全实践等。通过这个Demo,开发者可以深入理解并实践这些技术...

    客户端_服务器端使用简单

    在这个主题中,我们将深入探讨客户端-服务器端交互的基本原理、实现方式以及它们在实际应用中的具体细节。 客户端是用户直接接触的部分,它通常运行在用户的设备上,如桌面电脑、智能手机或平板电脑。客户端负责与...

    Java Web应用客户端编程

    Java Web应用客户端编程是开发基于Web的交互式应用程序的关键部分,它主要关注用户与服务器之间的交互逻辑和用户体验。客户端编程通常涉及HTML、CSS、JavaScript,以及一些库和框架,如jQuery、Bootstrap等,来创建...

    客户端与服务端的交互实现(AndroidStudio+JavaEE开发)

    在本文中,我们将深入探讨如何实现客户端与服务端的交互,特别是在Android Studio中构建客户端应用,结合Java EE技术搭建服务端。这个项目涵盖了用户登录、注册功能,以及数据的增删改查操作,通过MySQL数据库进行...

    Android客户端与服务器端通信Demo

    本Demo着重展示了这一核心概念,通过实例来帮助开发者理解和掌握Android客户端与服务器端交互的流程。 首先,我们要了解Android客户端与服务器通信的基本原理。通常,这种通信是基于HTTP或HTTPS协议的,使用RESTful...

    若水新闻客户端和服务器端

    这个标题表明我们正在讨论的是一个名为“若水新闻”的新闻应用,它包含客户端(通常是Android应用程序)和服务器端(负责处理客户端请求和提供数据的服务)。这个系统的设计可能包括用户界面、数据同步、网络通信、...

    Java项目毕设美食相关源代码客户端和服务器端

    本项目是针对Java编程语言的一份毕业设计,主要涉及美食相关的客户端和服务器端应用程序的开发。这个项目旨在帮助学生理解如何构建一个完整的网络应用系统,包括客户端与服务器之间的交互、数据传输以及美食相关功能...

    java调用webservice axis 客户端 服务器端 包含jar包

    总结,Java调用WebService Axis主要涉及到服务器端的部署和客户端的调用,通过Axis提供的工具和API,可以便捷地实现Java与Web服务的交互。在实际项目中,理解并熟练掌握这些步骤和原理,对于提升Web服务的开发效率和...

Global site tag (gtag.js) - Google Analytics