http协议
什么是BS架构
浏览器/服务器模式
优点 分布性强 易维护
什么是协议
信号的传输总要基于一定的规则,这个规则就是协议
协议很多 http https ws DNS FTP SMTP
什么是http协议
http定义(超文本传输协议)
http特点
- 一定是浏览器主动向服务器发起请求
- 一次请求都会对应一次响应
- 服务器响应时间不一定是即时的,但它一定会响应
http状态码
由三个数字组成,第一个数字是响应的类别,分五种类别
- 1XX:我已经收到你的消息了,我正在处理
- 2XX:表示我们的请求已经被成功接收,接受
- 3XX:重定向
- 4XX:客户端错误–请求语法或者请求无法实现
- 5XX:服务器端错误
请求方式
GET/POST/PUT/DELETE
区别 (一个数据包还是两个数据包,传参方式不同)
浏览器对地址长度的限制
- IE浏览器对URL的限制为2048字节
- 360极速浏览器对URL的限制为2118字节
- Firefox(Browser)对URL的长度限制为65536字节
- Safari(Browser)对URL的长度限制为80000字节
- Opera(Browser)对URL的长度限制为190000字节
http工作原理
首先客户端连接服务器
发送http请求
服务器接收请求并返回http响应
客户端解析HTML内容
http通信
http通信机制是在一次完整的http通信过程中,Web浏览器与Web服务器之间将完成下列7个步骤
- 建立TCP连接
在HTTP工作开始之前,Web浏览器首先要通过网络与Web服务器建立连接,该连接是通过TCP来完成的,该协议与IP协议共同构建Internet,即著名的TCP/IP协议族,因此Internet又被称作是TCP/IP网络。HTTP是比TCP更高层次的应用层协议,根据规则,只有低层协议建立之后才能进行更深层协议的连接,因此,首先要建立TCP连接,一般TCP连接的端口号是80。
- Web浏览器向Web服务器发送请求命令
一旦建立了TCP连接,Web浏览器就会向Web服务器发送请求命令
例如:GET/sample/hello.jsp HTTP/1.1。
- Web浏览器发送请求头信息
浏览器发送其请求命令之后,还要以头信息的形式向Web服务器发送一些别的信息,之后浏览器发送了一空白行来通知服务器,它已经结束了该头信息的发送。
- Web服务器应答
客户机向服务器发出请求后,服务器会客户机回送应答,
HTTP/1.1 200 OK
应答的第一部分是协议的版本号和应答状态码。
- Web服务器发送应答头信息
正如客户端会随同请求发送关于自身的信息一样,服务器也会随同应答向用户发送关于它自己的数据及被请求的文档。
- Web服务器向浏览器发送数据
Web服务器向浏览器发送头信息后,它会发送一个空白行来表示头信息的发送到此为结束,接着,它就以Content-Type应答头信息所描述的格式发送用户所请求的实际数据。
- Web服务器关闭TCP连接
一般情况下,一旦Web服务器向浏览器发送了请求数据,它就要关闭TCP连接,然后如果浏览器或者服务器在其头信息加入了这行代码
Connection:keep-alive
TCP连接在发送后将仍然保持打开状态,于是,浏览器可以继续通过相同的连接发送请求。保持连接节省了为每个请求建立新连接所需的时间,还节约了网络带宽。
B/S想要通信
- 确定基于什么协议(http)
- 表明请求方式(协商数据发送的方式)
- 建立连接(进行三次握手)
- 开始通信
- 断开连接(进行四次挥手)
什么是跨域
什么是源?
如果两个页面(接口) 的协议,域名,端口号都相同 我们就认为它们具有相同的 源
什么是同源策略?
同源策略就是浏览器的一个安全限制,它阻止不相同的【域】之间进行数据交互
安全限制具体限制了哪些东西不可以被访问?(非同源限制)
无法读取非同源下的cookie localstorage
无法接触非同源的dom
无法向非同源的地址发送 ajax请求
想要进行数据交互怎么办?
跨【域】
怎么跨域?
- jsonp方式 (利用js访问不受同源策略限制特性)
- 跨域资源共享 ( S端 cors )
- 设置反向代理 ( B端 )