8月1日上课内容 第一章web基础与http协议

dns与域名

网络是基于tcp/ip协议进行通信和连接的
应用层--传输层---网络层----数据链路层-----物理层
ip地址,我们每一台主机都有一个唯一的地址标识(固定的ip地址),区分用户和计算机通信。
ip地址:32位二进制数组成的,不方便记忆
192.168.233.61
域名:
www,baidu.com
dns解析: 就是把域名解析成IP地址,方便通信。
dns解析的方式:
1、/etc/hosts

负责快速解析的文件,包含了ip与主机名之间的映射关系,如果没有dns服务器的情况下,可以使用/etc/hosts文件来完成解析和映射。

2、/etc/resolv.conf

dns客户端的配置文件,设置dns服务器的ip和域名。还包含了主机域名的搜索顺序。主要是域名解析服务器使用的配置文件。

它的源头在这

3、修改网卡配置文件

ifcfg-ens33

 生效顺序:1、hosts 2、网卡配置文件 3、resolv.conf

dns域名解析服务器,现在都由运营商来做。

域名解析服务器作用:

1、保持和维护域名空间。

2、响应解析请求

解析端:(客户端)

根域------顶级域------二级域------子域------主机名

注册域名(了解):

1、准备材料------域名注册网站------注册,申请------>正式使用。

html:文本标记语言,是一种规范的,标准的语言格式。网页文件本身就是一个文本文件,html通过标记的方式,告诉浏览器如何显示文本当中的内容。html文件是一个文本文件,所有能够生成txt文件的工具,都可以进行编辑。修改之后的文件的后缀名只能是 .html或者.htm

网页都是基于html来写的(F12查看)

可以修改

通过左边的图标可以进行定位,指定内容修改

为什么是.htm?

这是网站服务的默认配置,只能识别.html或者.htm后缀名格式的文件

如果文件改了格式,配置文件也要和它保持一致,否则就会找不到

网页:就是一个纯文本格式的文件,用html语言来进行编写的。是用浏览器翻译成页面的形式显示出来的。

网站:是由多个页面组成的,网页的结合体。主页:打开网站之后出现的第一个页面,就是网站的主页(也可以理解为首页)。

域名:浏览网页时输入的网址。

http/https

用来传输页面的通信协议,https就是加密的,他们都是一种通信协议,基于tcp协议,端口号,http默认是80,https默认:443

netstat -antp | grep nginx 查看

URL:万维网寻址系统,唯一标识。

合起来完整的格式,包含域名和URI,是URL

https://www.bilibili.com/

URI

https://www.bilibili.com/v/dance/?spm id from=333.1007.0.0

从/v/开始后面就是URI

 

超链接:超链接将网站中的不同页面连接起来。

发布

将制作好的网页上传到服务器,供用户访问

html的语法(了解即可):

<html>

<head> 网页的内容描述</head>

                <body>网页的内容</body>

</html>

 

头标签中常用的标签:

<title>                定义了文档的标题
<base>                定义了页面链接标签的默认链接地址
<link>                定义了一个文档和外部资源之间的关系
<meta>                定义了 HTML 文档中的元数据
<script>            定义了客户端的脚本文件
<style>                定义了 HTML 文档的样式文件

内容当中常用的标签(都是了解即可):

<table>  定义表格
    
<tr>    定义表格中的一行
    
<td>  定义表格当中某一行的一列
    
<img> 定义图片
    
<a>  超链接
    
<font> 定义字体

web概述

 打开的页面也可以理解为web页面

现在主流的是web2.0

可以实现双向的交互

例如:发弹幕

视频是静态页面

点赞、投币等都是动态请求

因为web2.0用户交互

产生了静态页面和动态页面

静态页面就是标准的html文件

扩展名都是.htm .html

里面可以包含图片,文本,声音,动画视频等。

是网站建设的基础。

没有后台数据,不包含可交互的内容。

更新起来比较麻烦,一般用于展示型网站。

静态页面的特点:

1、静态页面的URL是固定的。一般不包含?

2、页面一经发布,都是保存在网站的服务器上的。

3、静态页面相对稳定,内容很少发生变化,容易被搜索引擎解锁。

4、没有数据库的支持,制作和维护的工作量都比较大。网站的信息量如果太大,单纯使用静态页面比较困难。

5、没有交互性,只能看,功能上受限很大。

6、浏览的速度较快,因为不需要连接后端数据库。

动态页面:

1、网页URL是不固定的,用户可以和后台数据进行交互

2、动态页面的网址一般都会包含一个特殊标记------------?

3.动态页面的语音:PHP ISP PYTHON RUBY TOMCAT (JAVA)

动态页面的特点:

1、交互性

2、自动跟新

3、特效,每个人进入页面的时候,会有不同的效果。

总结:

静态页面就是 看

动态页面 可以交互

web1.0 wbe2.0核心的区别就是交互

web3.0 交互,场景融合(类似于头号玩家中的场景,元宇宙)

http协议:

httpd程序名,apache服务名

http协议,超文本传输协议。是互联网上引用最广泛的网络协议之一。

基于tcp协议的应用层的传输协议。面向用户

客户端和服务端之间进行数据传输的一种规则。

工作流程(重点,面试题)

1、客户端和服务端进行tcp连接

三次握手------建立连接。

2、客户端发送http请求,服务端接收到http请求之后,响应客户端的请求。

3、通过socket接口,通过端口进行通信。

4、响应到达客户端,解析的过程(浏览器解析),用户查看,使用,访问。

5、访问、使用、查看,结束之后,断开连接,四次挥手。

http的一种无状态的协议,它本身不会对发送过的请求和响应的通信进行持久化处理。链接保持

为了http能够快速的大量的进行处理事务,提高效率

连接保持的需要的

cookie:记录用户的登陆状态,跟踪统计用户访问网站的习惯,识别用户身份,保存用户信息。

这个是服务器保留在用户计算机上的小文件。

http协议本身自带的连接保持功能

http0.9

http1.0

http1.1 自带连接保持功能,长连接。

长连接:一次性获取页面文件的所有信息,不再需要分开处理请求。所以速度大大加快。并行。

        连接保持:keep-alive,在一个tcp连接上,可以传送多个http的请求和响应。减少了建立和关闭连接的消耗以及延迟。

                        连接保持的有时间的,不是无限的。默认开启的。65秒

 

连接资源占用:长时间保持,会降低服务器的负载,如果是高并发,会使服务器耗尽资源

连接状态管理:长连接需要维护连接状态。服务器就需要跟踪每个连接的状态,增加服务器的负担(集群就诞生了)。

主流的就是http1.1

https:加密通信协议,加密数据传输。加密过程涉及客户端和服务器之间进行秘钥交换,确保只有合法的接收方,才能够解密数据。

证书:https使用数字证书验证身份。

https:电子商务,银行网站。

加密解密会对访问速度有一定的影响,但是为了安全可以忽略不计

http的请求方式:

1、请求头

请求头当中包含请求体。

 

请求体当中的内容:

Accept:客户端可以接受的数据类型
Accept-Encoding: 客户端可以接受的编码格式

Accept-Language:客户端可以支持的语言类型。

Cache-Control: 缓存时间,图片或者音频文件的缓存时间缓存指的是保留在本地的时间,下一次再访问图片,不需要再去服务端发起请求了,提高访问速度
Connection: 告诉服务器处理请求连接。一般默认都是keep-alive,连接保持,默认65秒

keep-alive: 告诉服务器,别急着关闭连接,保持一下段时间

请求方式:get 就是用来向服务器发起请求。http协议中的get,就是请求。

post也是请求的一种,post是向后台发数据。向服务器会添加数据,也可以改变服务器上的数据。

 

get方法:

1、从指定服务器获取数据

2、get请求可以被缓存

3、get请求会保存在浏览器的记录中,cookie

4、get请求的长度,是有限制的

就是获取数据

 

post:

也是请求的一种,提交数据给服务器处理

1、post请求不能缓存

2、post请求也不会记录在浏览器的记录当中

3、请求体的长度也没有限制。

post就是发数据,主要用于接口测试

状态码,响应码,服务器来进行提供的(面试会问,工作中用得到)

请求之后,服务器收到请求会有一个回应,响应,同时会反馈一个响应码

请求状态的响应码:

1xx

2xx

3xx

4xx

5xx

100-101 信息显示

200-206 成功 只要状态码的200,统统都是成功。

300-305 重定向

400-415 客户端错误 请求失败,获取资源失败

500-505 服务端错误 响应失败

200:成功 ok

301:请求的页面跳转

304:重定向到缓存。

403:禁止访问

404:请求页面找不到

500:服务器内部错误

502:网关失效

503:服务不可用

504:网关请求超时

通信套接字(也很重要)

socket:

实现不同主机进行通信和数据交换

进程间传输的标志:ip   端口

http协议当中socket的作用:

1、客户端套接字:定义唯一的客户进程
2、服务端套接字:定义了一个唯一的服务器进程。
套接字调用的相关接口

socket()创建端口
bind () 绑定ip和端口
listen() 监听,等待连接
accept0 接受请求
connect () 请求连接建立
write () 发送
read () 接受
ESTABLISHED 连接已经建立,正在传输数据

close()关闭连接

使用nc工具的模拟实验

nc -l 8888建立通信链接

等待连接:

nc 192.168.233.10 8888

建立连接之后的连接状态就变为了estab

 发送消息:

 

 

 

 

附: 

http协议请求流程分析详细版

用户输入URL(地址链接)(http://www.baidu.com:80/tools.html)客户端获取到端口及主机名后,
客户端利用DNS解析域名,首先客户端的浏览器会先找自身的缓存,
如果有解析结束,如果没有客户端会去找host文件,
如果host文件没有的话,客户端会去找本地的DNS缓存服务器,
本地的DNS缓存服务器没有的话,缓存服务器会去找根域,根域没有,
会返回一个.com.然后本地缓存服务器会去找顶级域,顶级域没有的话会返回baidu.com.,
然后本地缓存服务器会去找二级域,二级域解析完后会返回客户端。    

客户端解析到IP地址后会通过TCP的三次握手与服务器建立连接,
首先客户端向服务器发送请求连接报文,SYN=1初始序号seq为x,
这时客户端进入SYN-SENT状态,服务器确认请求报文ACK=1,SYN=1,确认序号ACK=X+1,
服务器产生的初始序号seq=y,回复客户端确认连接,此时服务器进入SYN-RCVD状态,
客户端接受后确认报文ACK=1,ACK=y+1,客户端又重组序号为x+1。
TCP连接已经建立,客户端进入ESTABLISHED 状态,当服务器收到客户端的确认后,
也会进入 ESTABLISHED 状态。客户端连接到IP地址,发送httpGET的请求,从服务器读取http响应。

之后断开连接时,需要通过TCP的四次挥手完成,
客户端向服务器发送断开连接请求报文,FIN=1,ACK=1,序号为u,
客户端处于FIN—WAIT-1(终止等待1)状态,服务器确认报文ACK=1,
确认序号为ACK=u+1,服务器的序号为v,回复客户端,
服务器服务端处于CLOSE—WAIT(关闭等待)状态,
客户端接受确认报文ACK=1,确认序号ACK=v+1,客户端重组序号为seq=u+1,
客户端处于FIN—WAIT-2(终止等待2)状态,然后服务器也想让客户端断开连接,
就发送了断开连接请求,FIN=1,ACK=1,服务器重组序号为w,
服务器服务端处于LAST—ACK(最后确认)状态,
客户端接受后确认报文ACK=1.确认序号为ACK=w+1,客户端序号为u+1,
客户端进入CLOSED(时间等待)状态,等待最长报文段寿命2*MSL,服务器确认后,
立即进入关闭状态。然后进行关闭连接。


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/63778.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SpringMVC -- REST风格开发,RESTful快速开发、RESTful注解开发

&#x1f40c;个人主页&#xff1a; &#x1f40c; 叶落闲庭 &#x1f4a8;我的专栏&#xff1a;&#x1f4a8; c语言 数据结构 javaweb 石可破也&#xff0c;而不可夺坚&#xff1b;丹可磨也&#xff0c;而不可夺赤。 REST 一、REST简介1.1REST风格简介 二、RESTful入门案例2.…

绘制曲线python

文章目录 import matplotlib.pyplot as plt# 提供的数据 x= [1,1.1,1.2,1.3,1.4,1.5,1.6,1.7,1.8,1.9,2,2.1,2.2,2.3,2.4,2.5,2.6,2.7,2.8,2.9,3,3.1,3.2,3.3,3.4,3.5,3.6,3.7,3.8,3.9,4,4.1,4.2,4.3,4.4,4.5,4.6,4.7,4.8,4.9,5,5.1,5.2,5.3,5.4,5.5,5.6,5.7,5.8,5.9,6,6.1,6.2…

门面模式(C++)

定义 为子系统中的一组接口提供一个一致(稳定) 的界面&#xff0c;Facade模式定义了一个高层接口&#xff0c;这个接口使得这一子系统更加容易使用(复用)。 应用场景 上述A方案的问题在于组件的客户和组件中各种复杂的子系统有了过多的耦合&#xff0c;随着外部客户程序和各子…

代码随想录算法训练营day55

文章目录 Day55 判断子序列题目思路代码 不同的子序列题目思路代码 Day55 判断子序列 392. 判断子序列 - 力扣&#xff08;LeetCode&#xff09; 题目 给定字符串 s 和 t &#xff0c;判断 s 是否为 t 的子序列。 字符串的一个子序列是原始字符串删除一些&#xff08;也可以…

java文件

一.File类 二.扫描指定目录&#xff0c;并找到名称中包含指定字符的所有普通文件&#xff08;不包含目录&#xff09;&#xff0c;并且后续询问用户是否要删除该文件 我的代码: import java.io.File; import java.io.IOException; import java.util.Scanner;public class Tes…

Excel功能总结

1&#xff09;每一张表格上都打印表头 “页面布局”-->“打印标题”-->页面设置“工作表”页-->打印标题“顶端标题行” 如&#xff1a;固定第1~2行&#xff0c;设置成“$1:$2” 2&#xff09;将页面内容打印在一页【缩印】 1.选好需要打印的区域&#xff0c;“页面布…

数据结构 | 利用二叉堆实现优先级队列

目录 一、二叉堆的操作 二、二叉堆的实现 2.1 结构属性 2.2 堆的有序性 2.3 堆操作 队列有一个重要的变体&#xff0c;叫作优先级队列。和队列一样&#xff0c;优先级队列从头部移除元素&#xff0c;不过元素的逻辑顺序是由优先级决定的。优先级最高的元素在最前&#xff…

全志D1-H (MQ-Pro)驱动 OV5640 摄像头

内核配置 运行 m kernel_menuconfig 勾选下列驱动 Device Drivers ---><*> Multimedia support --->[*] V4L platform devices ---><*> Video Multiplexer[*] SUNXI platform devices ---><*> sunxi video input (camera csi/mipi…

C++11 新特性 ---- 模板的优化

C11 模板机制:① 函数模板② 类模板模板的使用&#xff1a;① 范围&#xff1a;模板的声明或定义只能在全局或类范围进行&#xff0c;不可以在局部范围&#xff08;如函数&#xff09;② 目的&#xff1a;为了能够编写与类型无关的代码函数模板&#xff1a;- 格式&#xff1a;t…

软件工程:帕金森定律

在软件开发中&#xff0c;你是否遇到过这种情况&#xff1a; 团队要开发一个简单的购物车应用&#xff0c;项目预期时间是2周工期。负责开发的工程师默认利用完整的2周时间来完成任务。在第一周&#xff0c;工程师会认为任务很轻松&#xff0c;有充足的时间来完成任务&#xff…

SPM(Swift Package Manager)开发及常见事项

SPM怎么使用的不再赘述&#xff0c;其优点是Cocoapods这样的远古产物难以望其项背的&#xff0c;而且最重要的是可二进制化、对xcproj项目无侵入&#xff0c;除了网络之外简直就是为团队开发的项目库依赖最好的管理工具&#xff0c;是时候抛弃繁杂低下的cocoapods了。 一&…

Camunda 7.x 系列【2】开源工作流引擎框架

有道无术&#xff0c;术尚可求&#xff0c;有术无道&#xff0c;止于术。 本系列Spring Boot 版本 2.7.9 本系列Camunda 版本 7.19.0 源码地址&#xff1a;https://gitee.com/pearl-organization/camunda-study-demo 文章目录 1. 前言2. 开源工作流引擎框架2.1 jBPM2.2 Activ…

Python识别抖音Tiktok、巨量引擎滑块验证码识别

由于最近比较忙&#xff0c;所以本周搞了一个相对简单的验证码&#xff0c;就是抖音Tiktok的滑块验证码&#xff0c;这也是接到客户的一个需求。这种验证码通常在电脑端登录抖音、巨量引擎的的时候出现。 首先看一下最终的效果&#xff1a; 验证码识别过程 1、利用爬虫采集图…

jenkins的cicd操作

cicd概念 持续集成&#xff08; Continuous Integration&#xff09; 持续频繁的&#xff08;每天多次&#xff09;将本地代码“集成”到主干分支&#xff0c;并保证主干分支可用 持续交付&#xff08;Continuous Delivery&#xff09; 是持续集成的下一步&#xff0c;持续…

【ArcGIS Pro二次开发】(57):地图系列

在ArcGIS Pro中&#xff0c;有一个地图系列&#xff0c;可以在一个布局中导出多个地图。 在SDK中为ArcGIS.Desktop.layout.MapSeries类和映射系列导出选项&#xff0c;可以以支持多页导出。 MapSeries类提供了一个静态CreateSpatialMapSeries方法&#xff0c;该方法使用指定的…

【0807作业】使用消息队列实现AB进程对话+使用共享内存实现A进程打印字符串,B进程逆置字符串,打印结果为【正序 逆序 正序 逆序】

作业一&#xff1a;使用消息队列实现AB进程对话 ① 打开两个终端&#xff0c;要求实现AB进程对话 A进程先发送一句话给B进程&#xff0c;B进程接收后打印B进程再回复一句话给A进程&#xff0c;A进程接收后打印重复1.2步骤&#xff0c;当收到quit后&#xff0c;要结束AB进程 ② …

K8s中的PV和PVC和监控

1.PV和PVC PV&#xff1a;持久化存储&#xff0c;对存储资源进行抽象&#xff0c;对外提供可以调用的地方&#xff08;类似&#xff1a;生产者&#xff09; PVC&#xff1a;用于调用&#xff0c;不需要关心内部实现细节&#xff08;类似&#xff1a;消费者&#xff09; 2.实…

ChatGPT 作为 Python 编程助手

推荐&#xff1a;使用 NSDT场景编辑器 助你快速搭建可编辑的3D应用场景 简单的数据处理脚本 我认为一个好的起点是某种数据处理脚本。由于我打算让 ChatGPT 之后使用各种 Python 库编写一些机器学习脚本&#xff0c;这似乎是一个合理的起点。 目标 首先&#xff0c;我想尝试…

8.7一日总结

后台管理项目(使用vue3) 1.创建项目 npm init vuelatest 2.进入项目,下载依赖 3.下载需要的项目依赖 下载重置样式表 npm install reset-css 在main.js中阴入 import reset-css 4.清理目录 将项目中不需要的内容删除 5.运行项目 npm run dev 6.将仓库推送…