HTTP 프로토콜 (III) 여러 데이터 전송

 

HTTP 프로토콜은 일부 기능에 대해 이야기합니다 :

1) 스테이트리스

그것은 자기 HTTP 프로토콜 요청 및 프로토콜, 즉, 무 상태 프로토콜에 저장된 응답 사이의 통신 상태가 아니다.

이 설정의 장점은 다음과 같습니다 더 빨리 더 많은 요청의 업무를 처리, 확장 성 계약을 보장

그러나 웹의 지속적인 개발과 함께, 때때로, 우리는 다음 기술 쿠키의 도입에 쿠키 기술은 클라이언트를 제어 할 수있는 요청 및 응답 패킷의 상태 쿠키 정보에 의해 기록이 상태를 유지해야합니다.

쿠키의 내용에 대해 다시 우리는 말한다. . .

2) 휘발성

HTTP를 보낼 때 일반적으로, 당신은 TCP 연결을 설정 한 다음 메시지를 보내야합니다.

 

때마다 당신이 HTTP 메시지를 보내려면 대부분의 시간을 설정하고 연결을 분리하는 과정에서 소비 될 수 있도록,이 과정을 통과해야합니다.

따라서 지정된 연결에 대한 속성 모드를 사용하여 HTTP 연결.

연결 유지로 설정하면, HTTP 영구 연결을 설정합니다 다음 중단, 연결마다 시간을 설정할 필요가 없습니다.

이것의 장점은 : 시간의 일부의 비용을 줄이기 위해, 서버 측의 부하를 줄이고, HTTP 요청과 응답이 빠른 단, 해당 웹 페이지 표시 속도가 상대적으로 향상 될 수있다.

3) 파이프 라이닝

이미지 및 기타 대용량 파일의 큰 숫자와 HTTP 요청은 어떻게 다른 HTTP 요청을 할 경우?

이제 기술은보다 신속하고 영구적 인 접속을보다 HTTP 요청을 만드는이 파이프 라인, 즉 특징 : 요청의 많은 수는, 시간 차이가 더 분명하다.

4) 콘텐츠 인코딩

메시지의 내용 중 일부는 너무 크기 때문에, 순서에 따라 전송이 전송 시간을 단축 할 수 있도록하는 경우, 압축은 어떤 조치를 취할 것입니다.

이러한 상기 메시지 정보로 수락 부호화 정의 내용 인코딩 형식 : GZIP

다음과 같은 몇 가지 방법이 있습니다 :

GZIP : GNU 압축 형식

압축 : 표준 UNIX 시스템 압축 형식을

폐 : 허프만 부호화 및 LZ77 무손실 압축 포맷의 사용은

신분 : 비 압축

여러 부분 개체 5) 세트

때로는 혼합 된 콘텐츠 컨텐츠 제공뿐만 아니라 일부 문자열, 일부 사진, 문자, 음악 및 기타 바이너리가있을 수 있습니다.

자바 웹 업로드 파일을 사용하여 코드를 작성할 때이 예를 들어 객체, 다중의 다중 집합의 사용을 요구, 당신은의 형태로 형태로 인코딩 형식을 지정해야합니다.

设置form的enctype属性的值为multipart/form-data。

这是因为默认的情况下form使用的编码格式是:applicatin/x-www-form-urlencoded,这种编码格式会把所有的内容进行编码,不适合上传文件这种情况。

这两种编码格式的区别主要是:

multipart/form-data 会以控件为基准,编码form中的内容。

application/x-www-form-urlencoded 会把form中的内容编码成键值对的形式。

6)范围请求

有些场景下,http报文请求一些很大的图片,但是加载过程很慢。

比如我们登录一些大图片的网址,会发现有时候图片是一块一块加载的。

这就是因为设置了http请求的长度,这样就可以分块的加载资源文件。

在请求报文中使用Range属性,在响应报文中使用Content-Type属性都可以指定一定字节范围的http请求。

 

接下来,说说几种http协议的数据传输方式

http协议的传输方式有很多种,处于安全考虑,常用的一般都是GET和POST两种,先来介绍下这两种

1)GET:获取资源

GET方法用来请求访问已被URL识别的资源

2)POST:传输实体主体

POST方法用来请求服务器传输信息实体的主体

GET和POST的区别:

首先,使用目标不同:GET方法只是用来查询,不会对浏览器上的信息产生影响,每次GET的方法都是相同的

其次,大小不同:GET是放在URL首部,因此大小随着浏览器而定,而POST则是在报文中,只要没有具体限制,文件的大小是没限制的

然后,安全性不同:GET采用的是明文传输,而POST是放在报文内部,无法看到

从使用场景的角度来说,一般像用户注册登录这种信息都是私密的,采用POST,而针对查询等,为了快速,大多采用GET传输。

(关于关于GET和POST的区别,最近重新看了很多别人写的博客啊资料什么的,发现上面的解释比较模糊,我就在下面的评论区里面将区别清晰的描述一下,当然,后面的博客也会详细的解释)

 

接下来介绍其他几种数据传输方式:

3)PUT:传输文件

PUT要求在请求报文的主体中包含文件内容,然后保存到请求URL指定的位置

处于安全考虑,一般web网站不使用此方法,若配合web的安全验证机制,或者架构采用REST标准的网站,就可能开放使用此方法

4)HEAD:获得报文首部

HEAD和GET方法一样,只不过不返回报文主体部分,用于确认URI的有效性及资源更新的日期时间等

5)DELETE:删除文件

DELETE是与PUT相反的方法,是按请求URI删除指定的资源

处于安全考虑,一般web网站不使用此方法,若配合web的安全验证机制,或者架构采用REST标准的网站,就可能开放使用此方法

6)OPTIONS:询问支持的方法

用来查询针对请求URI指定的资源支持的方法

7)TRACE:追踪路径

是让web服务器端将之前的请求通信还回给客户端的方法

发送请求时,在Max-Frowards首部字段中填入数值,每经过一个服务器端就-1,当数值为0时,停止传输,最后收到服务器返回状态码200 OK的响应

但是,这种方法基本很少使用,而且很容易引起XST(跨站追踪)攻击,就更不会用到了。

8)CONNECT:要求采用隧道协议连接代理

该方法要求在于代理服务器通信时建立隧道,实现用隧道协议进行TCP通信,主要使用SSL(安全套接层)和TLS(传输层安全)协议把通信内容加密后经过网络传输。

 

最后,附上一张http1.1和http1.0版本各自支持的方法,另外,注意用大写。。。。。。

其中,LINK和UNLINK已被HTTP1.1废弃,不再支持!

 

 

说说http协议的一些特点:

1)无状态

http协议是一种自身不对请求和响应之间的通信状态进行保存的协议,即无状态协议。

这种设置的好处是:更快的处理更多的请求事务,确保协议的可伸缩性

不过随着web的不断发展,有时候,需要将这种状态进行保持,随即,就引入了cookie技术,cookie技术通过在请求和响应报文中写入cookie信息来控制客户端的状态。

有关cookie的内容后面我们再说。。。

2)持久性

正常在发送http时,都需要建立TCP的连接,再发送报文。

 

如果每次想要发送http报文都需要经过这个过程,那么时间大部分都会消耗在建立和断开连接的过程中。

因此http中使用了connection属性,用于指定连接的方式。

当设置成keep-alive,http就会建立一条持久化的连接,不需要每次都建立连接,再中断。

这样做的好处是:减轻了服务器端的负载,减少开销的那部分时间,使http请求和响应都能更快的结束,相应的,web页面显示速度也就相对提升了。

3)管线化

如果一个http请求,请求了大量的图片等大文件,那么其他的http请求怎么办呢?

现在,管线化技术的出现,使得http请求比持久性连接更要快;特点在于:请求数越多,时间差越明显。

4)内容编码

由于某些报文的内容过大,因此在传输时,为了减少传输的时间,会采取一些压缩的措施。

例如上面的报文信息中,Accept-Encoding就定义了内容编码的格式:gzip

有下面几种方式:

gzip:GNU压缩格式

compress:UNIX系统的标准压缩格式

deflate:是一种同时使用了LZ77和哈弗曼编码的无损压缩格式

identity:不进行压缩

5)多部分对象集合

有的时候传输的内容,不仅仅是一些字符串,还有可能是一些图片,字符,音乐二进制等混杂的内容。

这就需要使用多部分对象集合,multipart,例如在使用java编写web上传文件的代码时,需要在form中指定form的编码格式。

设置form的enctype属性的值为multipart/form-data。

这是因为默认的情况下form使用的编码格式是:applicatin/x-www-form-urlencoded,这种编码格式会把所有的内容进行编码,不适合上传文件这种情况。

这两种编码格式的区别主要是:

multipart/form-data 会以控件为基准,编码form中的内容。

application/x-www-form-urlencoded 会把form中的内容编码成键值对的形式。

6)范围请求

有些场景下,http报文请求一些很大的图片,但是加载过程很慢。

比如我们登录一些大图片的网址,会发现有时候图片是一块一块加载的。

这就是因为设置了http请求的长度,这样就可以分块的加载资源文件。

在请求报文中使用Range属性,在响应报文中使用Content-Type属性都可以指定一定字节范围的http请求。

 

接下来,说说几种http协议的数据传输方式

http协议的传输方式有很多种,处于安全考虑,常用的一般都是GET和POST两种,先来介绍下这两种

1)GET:获取资源

GET方法用来请求访问已被URL识别的资源

2)POST:传输实体主体

POST方法用来请求服务器传输信息实体的主体

GET和POST的区别:

首先,使用目标不同:GET方法只是用来查询,不会对浏览器上的信息产生影响,每次GET的方法都是相同的

其次,大小不同:GET是放在URL首部,因此大小随着浏览器而定,而POST则是在报文中,只要没有具体限制,文件的大小是没限制的

然后,安全性不同:GET采用的是明文传输,而POST是放在报文内部,无法看到

从使用场景的角度来说,一般像用户注册登录这种信息都是私密的,采用POST,而针对查询等,为了快速,大多采用GET传输。

(关于关于GET和POST的区别,最近重新看了很多别人写的博客啊资料什么的,发现上面的解释比较模糊,我就在下面的评论区里面将区别清晰的描述一下,当然,后面的博客也会详细的解释)

 

接下来介绍其他几种数据传输方式:

3)PUT:传输文件

PUT要求在请求报文的主体中包含文件内容,然后保存到请求URL指定的位置

处于安全考虑,一般web网站不使用此方法,若配合web的安全验证机制,或者架构采用REST标准的网站,就可能开放使用此方法

4)HEAD:获得报文首部

HEAD和GET方法一样,只不过不返回报文主体部分,用于确认URI的有效性及资源更新的日期时间等

5)DELETE:删除文件

DELETE是与PUT相反的方法,是按请求URI删除指定的资源

处于安全考虑,一般web网站不使用此方法,若配合web的安全验证机制,或者架构采用REST标准的网站,就可能开放使用此方法

6)OPTIONS:询问支持的方法

用来查询针对请求URI指定的资源支持的方法

7)TRACE:追踪路径

是让web服务器端将之前的请求通信还回给客户端的方法

发送请求时,在Max-Frowards首部字段中填入数值,每经过一个服务器端就-1,当数值为0时,停止传输,最后收到服务器返回状态码200 OK的响应

但是,这种方法基本很少使用,而且很容易引起XST(跨站追踪)攻击,就更不会用到了。

8)CONNECT:要求采用隧道协议连接代理

该方法要求在于代理服务器通信时建立隧道,实现用隧道协议进行TCP通信,主要使用SSL(安全套接层)和TLS(传输层安全)协议把通信内容加密后经过网络传输。

 

最后,附上一张http1.1和http1.0版本各自支持的方法,另外,注意用大写。。。。。。

其中,LINK和UNLINK已被HTTP1.1废弃,不再支持!

 

추천

출처www.cnblogs.com/zhengyao9236/p/11583520.html