前端和后端如何通讯

前端:客户端
后端:服务端

职业规划建议

培养自己的人脉圈,以及建立自己的影响力

  • 状态自己的总和能力
  • 经常参加一些活动
  • 开放分享(做讲师分享自己的智慧、写组件的个人博客做技术分享)

当我们在浏览器地址中输入URL地址,到最后看到页面,中间经历了哪些事情?
假设我们访问的是 https://www.baidu.com这个地址,按下enter建后,我们可以看到百度首页

  • 百度页面并没有在我们自己的客服端本地,我们是输入地址后,才请求过来的
  • 输入不同的域名可以看到不同的页面
  • 有的网页是https,有的是http(也有的是ftp)
  • 需要客户端联网才能完成这些事情

image.png

DNS服务器 域名解析服务

1.www.baidu.com 220.163.18.24
域名和服务器关联在一起,是通过DNS解析完成,所谓的DNS解析就是在dns服务上生成一条解析记录,标注了域名和对应的外网ip地址

都经历了哪些事情?

  • 首先根据客户端输入的域名,到DNS服务器上进行反解析(通过域名找到对应服务器的外网ip)
  • 通过找到外网的ip,找到对应的服务器
  • 通过地址栏中输入的端口号(没输入是因为不同协议有自己默认的端口号)找到服务器上发布的对应项目
  • 服务器获取请求资源的地址,例如/stu/index.html,把资源文件中的原代码找到
    • response 响应阶段
  • 服务器端会把找的原代码返回给客户端(通过http等传输协议返回)
  • 客户端接收到原代码后,会交给浏览器的内核(渲染引擎)进行渲染,最后由浏览器绘制出对应的页面
    • 服务器自主渲染

客户端和服务端交互(通讯)模型

image.png

第一部分 传输协议

URL、URI、URN

  • URI : 统一资源标识符
  • URL: 统一资源路径地址
  • URN:统一资源名称
  • URI=URL+URN

一个完整的url包含很多部分
https://www.yuque.com/as-giant/dz5g6s/eh4kdu/edit?name=wang&age=2

传输协议是用来完成客户端和服务端的数据(内存)传输的,类似于快递小哥、负责把客户和商家的物品来回床底

  • 客户端不仅可以向服务器发送请求,而且还可以吧一些内容传递给服务器
  • 服务器端也可以把内容返回给客户端
    • 客户端和服务端传输的内容总称:http报文,这些报文信息都是基于传输协议完成传输的,客户端传递给服务器叫做请求(Request),服务器返回给客户端叫做响应(Response) , request+response两个阶段统称为一个HTTP事务(事务:一个完整的事情)

HTTP事务

  • 当客户端想服务器端发送请求,此时客户端和服务器端会简历一个传输通道(链接通道),传输协议就是基于这个通道吧信息进行传输的
  • 当服务器端接受到请求信息,把内容返回给客户端后,传输通道会自动销毁关闭

传输协议分类

  • http:超文本传输协议(客户端和服务器端传输的内容除了文本以外),还可以传输图片,音视频等文件流[二进制编码/base64],以及传输xml格式的数据等,是目前市场上应用最广泛的传输协议
  • https:http ssl,它比http更加安全,要往数据内容的传输通道是经过ssl加密的(它需要在服务器端惊醒特殊的处理),所以涉及资金类的网站一般都是https协议的
  • ftp:资源文件传输协议,一般用客户端把资源文件(不是代码)上传到服务端,或者从服务器端下载一些资源文件(ftp传输的内容会http这类传输协议传输的内容多)

http报文

1、起始行

  • 请求起始行
  • 响应起始行

2、首部(头)

  • 请求头:内置请求头、自定义请求头
  • 响应式:内置响应头、自定义响应头
  • 通用头:请求和响应都有的

3、主体

  • 请求主体
  • 响应主体

请求xxx都是客户端设置的信息,服务器获取这些信息
响应xxx都是服务器端设置的信息,客户端用来接受这些信息

域名

设置域名其实就给不好记忆的服务器外网ip设置了一个好记忆的名字
顶级域名(一级域名):qq.com
二级域名:www.qq.com、v.qq.com、sports.qq.com
三级域名:kbs.sports.qq.com

端口号

在服务器发布项目的时候,我们可以通过端口号区分当前服务器上不同的项目
一台服务器的端口号取值范围:0~65535之间,如果电脑上安装了很多程序,有一些端口号是被占用了

HTTP:默认端口号80
HTTP:默认端口号443
FTP:默认端口号21

对于上述三个端口号其实是很重要的,如果被其它程序占用的,我们则不能使用了,所以服务器上一般是禁止安装其它程序的

第四部分 请求资源文件的路径名称

/stu/index.html
在服务器中发布项目的时候,我们一般都会配置一些默认文档:用户即使不输入请求文件的名称,服务器也会找到默认文档(一般默认文档都是index/default…)
我们通常为了做seo优化,会把一些动态页面的地址(xxx.php、xxx.aspx、xxx.asp、xxx.jsp…)进行伪URL重写(需要服务器处理的)
https://item.jd.com/432527.html
不可能是有一个商品,自己就单独写一个详情页面,肯定是同一个详情页做的不同处理

第一种方案

由后台语言很久详情页模板动态生成具体的详情页面

第二种方案

当前页面就是一个页面,例如:detail.html/detail.php…,我们做详情页面的时候,开发是按照detail.html?id=432527 来开发的,但是这种页面不方便做seo优化,此时我们把真实的地址进行重写,重写为了让我们看到的是4325427.html

第五部分 问号传承

?name=zf&age=9
把一些通过xxx=xxx的方式,放在一个url的末尾,通过问号传递

【作用】
1.在ajax请求中,我们可以通过问号传递参数的方式,客户端吧一些信息传递给服务器,服务器更具传递信息的不一样,返回不同的数据

1
2
3
4
5
6
7
8
9
10
// $.ajax(url,{});
// $.get(url,function(){});
// 对于ajax请求的特殊写法,原理还是基于ajax方法实现 $.post $.script

$.ajax({
url:'getPersonInfo?id=12'
...
})

// 当前案例,我们传递给服务器的编号是多少,服务器端就会把对应编号人员信息给返回

2.消除ajax请求中get方式缓存

1
2
3
4
5
$.ajax({
url:'xxx?_=0.123456'
method:'get'
})
// 我们会在请求url的末尾最佳一个随机数_=随机数,保证每一次请求的url都是不一样的,以此来消除get请求一流的缓存问题

3.通过url传递传输的方式,可以实现页面之间信息的通讯,例如:我们有两个页面A/B,A是列表页面、B是详情页,点击A中的某一条信息,进入到唯一的详情页B,如果展示不同的信息,这种操作就可以基于URL问号传递参数来实现了

例如:
http://sports.qq.com/kbsweb/game.htm?mid=10000:1471087
http://sports.qq.com/kbsweb/game.htm?mid=10000:1471086
在进入game.htm页面的时候,我们可以获取URL传递的参数值,更具传递参数值的不一样从服务器端获取不同的数据展示

在列表页面进行页面跳转的时候,我们需要记住的是跳转的同事传递不同的参数值

第六部分 HASH值

#xxx
URL末尾传递的井号什么,就是HASH值(哈希值)

[作用]
1、页面中锚点定位
2、前端路由(SPA单页面开发) –>