HTTP协议的概念作用和特点
Web交互的基本流程
请求:客户端根据服务器地址把数据发送给服务器的过程叫请求。
相应:服务器将请求的处理结果发送给浏览器的过程叫响应。
什么是HTTP?
概念:超文本传输协议。
HTTP有什么作用?
作用:规范了浏览器和服务器的数据交互格式。
HTTP有什么特点?
特点:简单快捷,灵活,无连接,无状态。
HTTP1.1版本后支持可持续连接。
HTTP请求与服务器
客户端与服务器:
CS与BS 软件使用方式上两种划分:
客户端,服务器架构Client/Server:
特点:在服务器当中就主要是一个数据库,把所有的业务逻辑以及界面都交给客户端完成
优点:较为安全,用户界面丰富,用户体验好
缺点:每次升级都要重新安装,针对于不同的操作系统开发,可移植性差
浏览器/服务器架构Browser/Server:
特点:基于浏览器访问的应用
把业务层交给服务器来完成,客户端仅仅做界面的渲染和数据的交换
优点:只开发服务器端,可以跨平台,移植性很强
缺点:安全性比较低,用户体验较差
Web资源
什么是Web?
WEB网页,它用于表示网络主机上供外界访问的资源.
Web资源分类
静态Web资源
指Web页面中供人们浏览的数据始终是不变.
动态Web资源
指Web页面中供人们浏览的数据是由程序产生的,不同时间点访问Web页面看到的内容各不相同.
Web资源存放在哪里
所有的Web资源都放在一个Web服务器当中
Web服务器就是可以供外界访问Web资源的一个软件
Web资源放到指定的目录当中,就可以通过对应的端口在浏览器当中访问到
URL地址
协议://主机地址:端口号/资源地址
http://www.it666.com:80/index.html
域名资源访问流程
当我们在浏览器当中访问一个地址的时候,为什么就能看到一个页面
BS结构流程图
请求与响应
请求:
把客户端请求发送给服务器
响应:
服务器把你要的数据发送给客户端
请求与响应都要一定的格式:
约定好客户端以什么样的格式把数据给服务器
约定好服务器以什么样的格式把数据给客户端
这个约定使用的就是HTTP协议
客户端
浏览器
Android程序
IOS程序
微信小程序
服务器
PHP服务器
Tomcat服务器
nodeJS服务器
发送http请求方式
http协议
什么是协议:
约束双方规范的一个准测
什么是HTTP协议
HTTP 超文本传输协议(HyperText Transfer Protocol)是互联网上应用最为广泛的一种网络协议
所有的WWW文件都必须遵守这个标准
设计HTTP最初的目的是为了提供一种发布和接收HTML页面的方法
约束请求与响应的规则
HTTP组成部分
请求
响应
请求与响应都是成对存在的
请求的发送方式
- 通过浏览器的地址栏
- 通过html当中的form表单
- 通过a链接的href
- src属性
http请求
请求行和请求头
1. 请求行
请求方式
POST
GET
请求的资源
/Myxq/login.html?username=myxq&pwd=1234
协议版本
HTTP/1.0,发送请求,创建一次连接,获得一个Web资源,连接断开.
HTTP/1.1,发送请求,创建一次连接,获得多个Web资源,保持连接.
2. 请求头
请求头是客户端发送给服务器端的一些信息
使用键值对表示key : value
常见请求头
Referer.浏览器通知服务器,当前请求来自何处。如果是直接访问,则不会有这个头。常用于:防盗链
If-Modified-Since.浏览器通知服务器,本地缓存的最后变更时间
Cookie.用于存放浏览器缓存的cookie信息
User-Agent. 浏览器通知服务器,客户端浏览器与操作系统相关信忘
Connection .保持连接状态, Keep-Alive连接中, close已关闭
Host.请求的服务器主机名
Content-Length.请求体的长展
Content-Type.如果是POST请求,会有这个头,默认值为application/x-www-form-urlencoded,表示请求体内容使用url编码
Accept.浏览器可支持的MIME类型,文件类型的一种描述方式。
Accept-Encoding.浏览器通知服务器,浏览器支持的数据压缩格式.如: GZIP压缩
Accept-Language.浏览器通知服务器,浏览器支持的语
请求体
当请求方式是POST时,请求体会有请求的参数
如果请求方式为get,那么请求参数不会出现在请求体中,会拼接在url地址后面
http响应
响应行
状态码
200:请求成功
302:请求重定向
304:请求资源没有改变,访问本地缓存
404:请求资源不存在,通常是用户路径编写错误,也可能是服务器资源已删除.
500:服务器内部错误.通常程序抛异常.
其它状态码
成功
重定向
客户方错误
服务器错误
响应头
服务器端将信息以键值对的形式返回给客户端
常见请求头
Location:
指定响应的路径,需要与状态码302配合使用,完成跳转
Content-Type:
响应正文的类型(MIME类型)
Content-Disposition:
通过浏览器以下载方式解析正文
Set-Cookie:
服务器向浏览器写入cookie
Content-Encoding:
服务器使用的压缩格式
Content-length:
响应正文的长度
Refresh:
定时刷新
Server:
服务器名称,默认值:Apache-Coyote/1.1.可以通过conf/server.xml配置进行修改
Last-Modified:
服务器通知浏览器,文件的最后修改时间.
响应体
响应体是服务器回写给客户端的页面正文
浏览器将正文加载到内存
然后解析渲染显示页面内容
请求方式
8种请求类型
- 1. OPTIONS
返回服务器针对特定资源所支持的HTTP请求方法,也可以利用向Web服务器发送’*’的请求来测试服务器的功能性
- 2. HEAD
请求指定的页面信息,并返回头部信息
- 3. GET
请求指定的页面信息,并返回实体主体
- 4. POST
向指定资源提交数据进行处理请求
- 5. PUT
向指定资源位置上传其最新内容
- 6. DELETE
请求服务器删除Request-URL所标识的资源
- 7. TRACE
回显服务器收到的请求,主要用于测试或诊断
- 8. CONNECT
HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器
常用两种请求
面试可能问的************************
GET
GET方法向页面请求发送参数
地址和参数信息中间用?字符分隔http://www.it666.com/hello?key1 =value1&key2=value2
查询宁符串会显示在地址栏的URL中,不安全,请不要使用GET请求提交敏感数据
GET方法有大小限制:请求字符串中最多只能有1024个字符
GET请求能够被缓存
GET请求会保存在浏览器的浏览记录中
可以添加书签
编码类型为application/x-www-form-urlencoded
只允许ASCII字符类型,不能用二进制流
点击刷新时,不会有反应
GET请求主要用以获取数据
POST
POST方法向页面请求发送参数
使用POST方法时,查询字符串在POST信息中单独存在,和HTTP请求一起发送到服务器
编码类型为:application/x-www-form-urlencoded or multipart/form-data.请为二进制数据使
用multipart编码
没有历史记录
参数类型没有限制,可以是字符串也可以是二进制流
数据不会显示在地址栏中,也不会缓存下来或保存在浏览记录中,所以
看POST求情比GET请求安全,但也不是最安全的方式。如需要传送敏
感数据,请使用加密方式传输
查询字符串不会显示在地址栏中
Post传输的数据量大,可以达到2M,而Get方法由于受到URL长度限制,只能传递大约1024字节。
Post就是为了将数据传送到服务器段,Get就是为了从服务器段取得数据
HTTP协议的概念作用和特点的更多相关文章
- (转载)OC学习篇之---协议的概念和用法
在前一篇文章中我们介绍了OC中类的延展,这一篇文章我们在来看一下OC中协议的概念以及用法,协议也是OC中的一个重点,Foundation框架以及我们后面在写代码都会用到. OC中的协议就是相当于Jav ...
- OC中协议的概念以及用法
OC中协议的概念以及用法,协议也是OC中的一个重点,Foundation框架以及我们后面在写代码都会用到. OC中的协议就是相当于Java中的接口(抽象类),只不过OC中的名字更形象点,因为我们在学习 ...
- OC学习篇之---协议的概念和用法
这一篇文章我们在来看一下OC中协议的概念以及用法,协议也是OC中的一个重点,Foundation框架以及我们后面在写代码都会用到. OC中的协议就是相当于Java中的接口(抽象类),只不过OC中的名字 ...
- 软件授权协议有什么作用,例如GPL、Apache License、CDDL、EPL这些协议有什么区别?
1.授权协议有什么作用:授权协议就是授予你使用或修改软件等权利,由于软件受到著作权保护,未经授权使用即是侵犯著作权,属于违法行为,所以同意或签署软件授权协议是你使用或修改软件的前提条件.既然是授权协议 ...
- 全面解读Oracle同义词的概念作用、创建删除查看及Oracle的db link
Oracle的同义词(synonyms)从字面上理解就是别名的意思,和视图的功能类似,就是一种映射关系. 在Oracle中对用户的管理是使用权限的方式来管理的,也就是说,如果我们想使用数据库,我们就必 ...
- nonce和timestamp在Http安全协议中的作用
前段时间给客户网站做新浪微博账号登录功能,对OAuth协议以及相关的一些安全协议做了一些研究,顺便就记录一下学习心得吧.在这里就不打算具体讲OAuth的协议流程了,而是针对OAuth请求头里的nonc ...
- HTTP 协议基础概念和报文结构
基础概念 1.WWW(World Wide Web,万维网)构建技术有3项: (1)把SGML(Standard Generalized Markup Language,标准通用标记语言)作为页面的文 ...
- 【TCP/IP】二、协议的概念
一.概念 1.tcp/ip是通信协议的统称. 2.协议就是计算机与计算机之间通过网络实现通信时,事先达成的一种约定.这种约定,使那些不同厂商的设备,不同的CPU以及不同的操作系统组成的计算机之间,只要 ...
- Java 之 Serializable 序列化和反序列化的概念,作用的通俗易懂的解释
遇到这个 Java Serializable 序列化这个接口,我们可能会有如下的问题a,什么叫序列化和反序列化b,作用.为啥要实现这个 Serializable 接口,也就是为啥要序列化c,seria ...
随机推荐
- AOP 实现日志
package com.foen.foensys.config; import com.alibaba.fastjson.JSON;import com.foen.foensys.model.SysL ...
- python re.search方法
re.search 扫描整个字符串并返回第一个成功的匹配. 函数语法: re.search(pattern, string, flags=0) 函数参数说明: 参数 描述 pattern 匹配的正则表 ...
- 翻译我去issues提问的回答内容
我提问的原因主要是我要做.net core ABP的Token刷新功能,基本都根据网上的文章整合进ABP了,在如何存储的时候,总觉得系统的AbpUserTokens表为啥不利用进来,但是又找不到相关介 ...
- CodeForces - 28C Bath Queue 概率与期望
我概率期望真是垃圾--,这题搞了两个钟头-- 题意 有\(n\)个人,\(m\)个浴室,每个浴室里有\(a_i\)个浴缸.每个人会等概率随机选择一个浴室,然后每个浴室中尽量平分到每个浴缸.问期望最长排 ...
- 【转载】使用 scikit-learn 进行特征选择
[转载]使用 scikit-learn 进行特征选择 Read more: http://bluewhale.cc/2016-11-25/use-scikit-learn-for-feature-se ...
- Unit Test in SpringBoot
此处的Unit Test in SpringBoot 包括: SpringApplication Test Service Test ControllerTest 测试项目结构如下: 代码如下: PO ...
- Docker入门-Dockerfile的使用
使用Dockerfile定制镜像 镜像的定制实际上就是定制每一层所添加的配置.文件.我们可以把每一层修改.安装.构建.操作的命令都写入一个脚本,这个脚本就是Dockerfile. Dockerfile ...
- windows spark1.6
jdk1.7 scala 2.10.5 spark 1.6.1 http://spark.apache.org/downloads.html hadoop 2.6.4 只需要留bin https:// ...
- 最长不重复子串长度,时间复杂度O(n),空间复杂度O(n),Python实现
def lengthOfLongestSubstring(s): res = 0 d = {} tmp = 0 start = 0 for i in range(len(s)): if s[i] in ...
- C# 截取屏幕局部
//截取全屏图象 private void btnFullScreen_Click(object sender, EventArgs e) { //创建图象,保存将来截取的图象 Bitmap imag ...