谈谈HTTP

HTTP又称超文本传输协议,在互联网上广为流传和应用。

今天主要讲这么几个?

a.针对HTTP下细分为:

HTTP概念、Request和Response详解、Request中GET和POST的区别、说说RestFul等。

 

b.面试常考题

比如 当在浏览器上输入www.challengertech.com会发生什么。

 

 

一、HTTP

1.HTTP概念

HTTP协议是Hyper Text Transfer Protocol(超文本传输协议)的缩写,是用于从万维网(WWW:World Wide Web )服务器传输超文本到本地浏览器的传送协议。

HTTP是一个基于TCP/IP通信协议来传递数据(HTML 文件, 图片文件等)。

HTTP是一个属于应用层的面向对象的协议,由于其简捷、快速的方式,适用于分布式超媒体信息系统。

HTTP协议工作于客户端-服务端架构为上。浏览器作为HTTP客户端通过URL向HTTP服务端即WEB服务器发送所有请求。Web服务器根据接收到的请求后,向客户端发送响应信息。

如图:

 

主要特点:

(1)简单快速:客户向服务器请求服务时,只需传送请求方法和路径。请求方法常用的有GET、HEAD、POST。每种方法规定了客户与服务器联系的类型不同。由于HTTP协议简单,使得HTTP服务器的程序规模小,因而通信速度很快。

(2)灵活:HTTP允许传输任意类型的数据对象。正在传输的类型由Content-Type加以标记。

(3)无连接:无连接的含义是限制每次连接只处理一个请求。服务器处理完客户的请求,并收到客户的应答后,即断开连接。采用这种方式可以节省传输时间。

(4)无状态:HTTP协议是无状态协议。无状态是指协议对于事务处理没有记忆能力。缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。另一方面,在服务器不需要先前信息时它的应答就较快。

(5)支持B/S和C/S模式

B/S模式是目前最流行的,在这里不得不提到B/S模式的两方面优点:

a.统一的客户端(浏览器,比如Chrome、火狐、IE等常用浏览器);

b.统一的HTTP协议;

C/S模式同样支持,比如虽然没有几年前那么火的安卓应用。

 

说到HTTP不得不提到URL(统一资源定位符)

以例子来讲解完整的URL

http://www.challengertech.com:8090/blog/post.jsp?postId=1

从上面的例子可看出,一个完整的URL需要包含如下几部分:

a.协议:例如http

b.端口:比如例子中的8090

c.域名部分:比如www.challengertech.com 其实也可以是IP地址

d.虚拟目录:比如例子中的blog是一个虚拟目录,同样它也是项目名

e.文件名:比如例子中的post.jsp是一个文件

f.参数:通常get请求携带参数,都会追加到请求路径后面

g.锚:从#开始的后面部分都是锚,一般用的非常少

 

URL和URI的区别如下:

URL是uniform resource locator,统一资源定位器,它是一种具体的URI,即URL可以用来标识一个资源,而且还指明了如何locate这个资源。

URL是Internet上用来描述信息资源的字符串,主要用在各种WWW客户程序和服务器程序上
采用URL可以用一种统一的格式来描述各种信息资源,包括文件、服务器的地址和目录等。URL一般由三部组成:
①协议(或称为服务方式)
②存有该资源的主机IP地址(有时也包括端口号)
③主机资源的具体地址。如目录和文件名等

 
URI,是uniform resource identifier,统一资源标识符,用来唯一的标识一个资源。

Web上可用的每种资源如HTML文档、图像、视频片段、程序等都是一个来URI来定位的
URI一般由三部组成:
①访问资源的命名机制
②存放资源的主机名
③资源自身的名称,由路径表示,着重强调于资源。

 
URN,uniform resource name,统一资源命名,是通过名字来标识资源,比如mailto:java-net@java.sun.com。

URI是以一种抽象的,高层次概念定义统一资源标识,而URL和URN则是具体的资源标识的方式。URL和URN都是一种URI。笼统地说,每个 URL 都是 URI,但不一定每个 URI 都是 URL。这是因为 URI 还包括一个子类,即统一资源名称 (URN),它命名资源并不指定如何定位资源。上面的 mailto、news 和 isbn URI 都是 URN 的示例。

在Java的URI中,一个URI实例可以代表绝对的,也可以是相对的,只要它符合URI的语法规则。而URL类则不仅符合语义,还包含了定位该资源的信息,因此它不能是相对的。
在Java类库中,URI类不包含任何访问资源的方法,它唯一的作用就是解析。
相反的是,URL类可以打开一个到达资源的流。

 

2.Request和Response参数详解

(1)Request

客户端发送一个HTTP请求到服务器的请求消息包括以下格式:

请求行、请求头、空行、请求数据等四部分

如图:

 

第一部分:请求行,用来说明请求类型,要访问的资源以及所使用的HTTP版本.

GET说明请求类型为GET,[/562f25980001b1b106000338.jpg]为要访问的资源,该行的最后一部分说明使用的是HTTP1.1版本。

第二部分:请求头部,紧接着请求行(即第一行)之后的部分,用来说明服务器要使用的附加信息

从第二行起为请求头部,HOST将指出请求的目的地.User-Agent,服务器端和客户端脚本都能访问它,它是浏览器类型检测逻辑的重要基础.该信息由你的浏览器来定义,并且在每个请求中自动发送等等

这个User-Agent很重要,比如我再关于微信如何识别是电脑端还是手机端,关键就是这个User-Agent,根据它来判断,如果是电脑端直接就下载,非电脑端,如果是微信的话,需要打开浏览器重定向到对应的地址下载App。

第三部分:空行,请求头部后面的空行是必须的

即使第四部分的请求数据为空,也必须有空行。

第四部分:请求数据也叫主体,可以添加任意的其他数据。

此例子为空

 

(2)Response

一般情况下,服务器接收并处理客户端发过来的请求后会返回一个HTTP的响应消息。

 Response也由四部分组成,状态行、消息报头、空行、响应文

第一部分:状态行,由HTTP协议版本号, 状态码, 状态消息 三部分组成。

第一行为状态行,(HTTP/1.1)表明HTTP版本为1.1版本,状态码为200,状态消息为(ok)

 

 

第二部分:消息报头,用来说明客户端要使用的一些附加信息

第二行和第三行为消息报头,
Date:生成响应的日期和时间;Content-Type:指定了MIME类型的HTML(text/html),编码类型是UTF-8

第三部分:空行,消息报头后面的空行是必须的
第四部分:响应正文,服务器返回给客户端的文本信息。

空行后面的html部分为响应正文。

 

3.Request常用的GET和POST区别

这里引用W3CSCHOOL:

 

4.说说RestFul

用我的话来说,将对资源的操作进行归类,比如如果我要添加某个资源时,使用POST,删除使用DELETE,修改使用PUT,获取数据使用GET。

简而言之,如果是涉及对数据的改动,使用POST、DELETE、PUT,POST大家都知道,至于DELETE、PUT其实和POST是一样的,数据不可见,安全性高。

对于获取数据,使用GET就行了。

 

 

二、面试常见考题

当你在浏览器输入:www.challengertech.com会发生什么?

这里我引用《深入分析JavaWeb技术内幕》的截图,这本书也是我最近在看的。

我觉得这个图,可以很好的解释这个问题的答案。

 

小结:HTTP是目前B/S模式开发常用的协议,不管是使用Java开发还是C#开发或者是目前流行的Python,所开发的Web应用大多遵循HTTP协议,所以正如上学时的一句名言,“学好数理化,走遍天下都不怕”。

在HTTP中同样使用。当然了,HTTP只是TCP/IP的一个应用层协议之一,还有UDP,FTP,SMTP等等。但是那些都不是关键,关键就是TCP/IP,把这个关键点,把好了,理解透彻了,是大有裨益的。自毕业后,愈发觉得基础的重要性。技术永远都是日新月异的,不变的就是那些看似不起眼的,把握好它们,意味着你成为自己职业发展的主宰。正所谓“万变不离其宗”,就是这么个理。

 

HTTP部分主要参考了这篇文章:http://www.cnblogs.com/ranyonsue/p/5984001.html

我认为该作者写的挺不错的,将其推荐给大家。

 

当然了,希望这篇文章能给你们带来有益的启发和收获。

posted @ 2018-09-06 22:00  挑战者V  阅读(497)  评论(0编辑  收藏  举报