你们好,我是Java最全面试题库
的提裤姐,今天这篇是JavaWeb系列的第二篇,主要总结了JavaWeb中HTTP
相关的问题,在后续,会沿着第一篇开篇的知识线路一直总结下去,作到日更!若是我能作到百日百更,但愿你也能够跟着百日百刷,一百天养成一个好习惯。web
一、域名解析
二、发起TCP的三次握手
三、创建TCP链接后发起http请求
四、服务器响应http请求,浏览器获得HTML代码
五、浏览器解析HTML代码,并请求HTML代码中的资源
六、浏览器对页面进行渲染呈现给用户
七、链接结束面试
GET:浏览器
field(字段) = value
的形式,置于URL后,并用“?”
链接,多个请求数据间用“&”
链接传输数据量小
,由于受URL长度限制,可是效率高不安全
的,由于URL是可见的,可能会泄漏私密信息只能支持ASCII字符
,向服务器传的中文字符可能会乱码POST:缓存
向服务器发送数据
。传输大量数据
,因此上传文件时只能用post标准字符集
,能够正确传递中文字符安全性高
常见的状态码:安全
200
:请求被正常处理204
:请求被受理但没有资源能够返回206
:客户端只是请求资源的一部分,服务器只对请求的部分资源执行GET方法,相应报文中经过Content-Range指定范围的资源。301
:永久性重定向302
:临时重定向303
:与302状态码有类似功能,只是它但愿客户端在请求一个URI的时候,能经过GET方法重定向到另外一个URI上304
:发送附带条件的请求时,条件不知足时返回,与重定向无关307
:临时重定向,与302相似,只是强制要求使用POST方法400
:请求报文语法有误,服务器没法识别401
:请求须要认证403
:请求的对应资源禁止被访问404
:服务器没法找到对应资源500
:服务器内部错误503
:服务器正忙本质区别:服务器
重定向特色:两次请求,浏览器地址发生变化,能够访问本身 web 以外的资源,传输的数据会丢失。
请求转发特色:一次强求,浏览器地址不变,访问的是本身自己的 web 资源,传输的数据不会丢失。cookie
HTTPS = HTTP + SSL
session
请求报文:
a、请求行:包含请求方法、URI、HTTP版本信息
b、请求首部字段
c、请求内容实体post
响应报文:
a、状态行:包含HTTP版本、状态码、状态码的缘由短语
b、响应首部字段
c、响应内容实体网站
无状态协议对于事物处理没有记忆能力。缺乏状态意味着后续的处理须要前面的信息。
经过cookie和session解决
一、客户使用HTTPS的URL访问web服务器,要求与web服务器创建SSL链接
二、web服务器收到客户端请求后,将网站的证书信息(证书中包含公钥)传送一份给客户端
三、客户端的浏览器与web服务器开始协商SSL链接的安全等级,也就是信息的加密等级
四、客户端的浏览器根据双方赞成的安全等级,创建会话秘钥,而后利用网站的公钥将会话秘钥加密,并传送给网站
五、web服务器利用本身的私钥解密出会话秘钥
六、web服务器利用会话秘钥加密与客户端之间的通讯
通用首部字段(请求报文与响应报文都会使用的首部字段)
Date:建立报文时间
Connection:链接的管理
Cache-Control:缓存的控制
Transfer-Encoding:报文主体的传输编码方式
请求首部字段(请求报文会使用的首部字段)
Host:请求资源所在服务器
Accept:可处理的媒体类型
Accept-Charset:可接收的字符集
Accept-Encoding:可接受的内容编码
Accept-Language:可接受的天然语言
响应首部字段(响应报文会使用的首部字段)
Accept-Ranges:可接受的字节范围
Location:令客户端从新定向到的URI
Server:HTTP服务器的安装信息
实体首部字段(请求报文与响应报文的的实体部分使用的首部字段)
Allow:资源可支持的HTTP方法
Content-Type:实体主类的类型
Content-Encoding:实体主体适用的编码方式
Content-Language:实体主体的天然语言
Content-Length:实体主体的的字节数
Content-Range:实体主体的位置范围,通常用于发出部分请求时使用
三次握手:
为了准确无误地把数据送达目标处,TCP协议采用了三次握手策略。
用TCP协议把数据包送出去后,TCP不会对传送后的状况置之不理,它必定会向对方确认是否成功送达。握手过程当中使用了TCP的标志:SYN和ACK
注意:若在握手过程当中某个阶段莫名中断,TCP协议会再次以相同的顺序发送相同的数据包
四次挥手:
断开一个TCP链接则须要四次挥手