http、https笔记
目录
- HTTP 基本概念
- 状态码:
- get和post的区别:
- http 常⻅字段:
- http的缺点:
- HTTP/1.1
- HTTP/3
- HTTPS
- HTTPS和HTTP区别
- 对称加密和⾮对称加密
- ⾮对称加密
HTTP 基本概念
状态码:
1xx 中间状态,比如post的continue
200 OK是最常⻅的成功状态码
3xx 重定向
4xx 客户端发送的报⽂有误
5xx 服务器处理时内部发⽣了错误
get和post的区别:
1、get获取数据,post改教据
2、get把请求在url上,不安全,post在http包内,安全
3、get数据最大2k,post无限制
4、get产生一个TCP包(header+data ),返回200
post产生两个TCP包(1、header返回100continue,2、data返回200 )
5.get会被缓存,post不会
6、get是幂等,post不是幂等的(get不能对数据进行修改,网络不好会多次重试)
http 常⻅字段:
Host 字段:指定服务器的域名
Content-Length 字段:本次服务器回应的数据⻓度是 1000 个字节
Connection 字段:要求服务器使⽤ TCP 持久连接,以便其他请求复⽤
Content-Type 字段:数据是什么格式
Content-Encoding 字段:数据的压缩⽅法 gzip
http的缺点:
⽆状态:Cookie 技术
明⽂传输:引⼊ SSL/TLS 层
HTTP/1.1
⻓连接:只要任意⼀端没有明确提出断开连接,则保持 TCP 连接状态
管道⽹络传输:可在同⼀个 TCP 连接⾥⾯,客户端可以发起多个请求,只要第⼀个请求发出去了,不必等其回来,就可以发第⼆个请求出去,可以减少整体的响应时间。(按照顺序)

HTTP/3
把 HTTP 下层的 TCP 协议改成了 UDP!
QUIC 有⾃⼰的⼀套机制可以保证传输的可靠性的。当某个流发⽣丢包时,只会阻塞这个流,其他流不会受到
影响。
QUIC 是⼀个在 UDP 之上的伪 TCP + TLS + HTTP/2 的多路复⽤的协议。

HTTPS
窃听⻛险:混合加密的⽅式实现信息的机密性
篡改⻛险:摘要算法的⽅式来实现完整性,它能够为数据⽣成独⼀⽆⼆的「指纹」,指纹⽤于校验数据的完整性
冒充⻛险:将服务器公钥放⼊到数字证书中,解决了冒充的⻛险
HTTPS和HTTP区别
http 明文 80端口
https
密文 443端口
过程:
1、tcp三次握手
2、ca数字证书放入非对称密钥获取会话密钥,对称密钥进行加密会话
3、http只有tcp三次握手的三个包(快),https是12个包(3+9个的ssl包)(慢)
对称加密和⾮对称加密
对称加密只使⽤⼀个密钥,运算速度快,密钥必须保密,⽆法做到安全的密钥交换。
⾮对称加密使⽤两个密钥:公钥和私钥,公钥可以任意分发⽽私钥保密,解决了密钥交换问题但速度慢
⾮对称加密
1、client、sever交换随机数
2、sever发送证书
3、client 取CA的公钥,验证数字证书,取出服务器的公钥,用服务器公钥加密随机数( pre-master key ),随后根据client、sever随机数+随机数( pre-master key )来生成会话密钥
4、sever私钥解密随机数( pre-master key ),随后根据client、sever随机数+随机数( pre-master key )来生成会话密钥
相关文章:
http、https笔记
目录 HTTP 基本概念状态码:get和post的区别:http 常⻅字段:http的缺点: HTTP/1.1HTTP/3HTTPSHTTPS和HTTP区别对称加密和⾮对称加密⾮对称加密 HTTP 基本概念 状态码: 1xx 中间状态,比如post的continue 20…...
飞凌嵌入式「国产」嵌入式核心板大盘点(三)——龙芯中科、赛昉科技
为了帮助各位工程师朋友详细了解飞凌嵌入式推出的“国产化”产品,小编专门开设了「国产平台大盘点专题」。上周,已经带大家盘点了飞凌嵌入式联合瑞芯微电子和全志科技两个国产处理器品牌打造的平台,今天,将继续为大家介绍龙芯和赛…...
以vue2为例,用npm开发环境在后端部署vue2项目(更推荐使用nginx部署)
因为之前一致出现的跨域问题,从而想到了这个办法,属于偏方。推荐使用nginx部署,再去解决跨域问题。 接下来聊一聊本文所使用的方法。 首先将你的前端vue项目拷贝一份到服务器,准备一个dockerfile文件,用这个进行部署首…...
docker容器监控:Cadvisor +Prometheus+Grafana的安装部署
目录 Cadvisor PrometheusGrafana的安装部署 一、安装docker: 1、安装docker-ce 2、阿里云镜像加速器 3、下载组件镜像 4、创建自定义网络 二、部署Cadvisor 1、被监控主机上部署Cadvisor容器 2、访问cAdvisor页面 三、安装prometheus 1、部署Prometheus…...
前端食堂技术周刊第 93 期:7 月登陆 Web 平台的新功能、Node.js 工具箱、Nuxt3 开发技巧、MF 重构方案
美味值:🌟🌟🌟🌟🌟 口味:橙橙冰萃美式 食堂技术周刊仓库地址:https://github.com/Geekhyt/weekly 大家好,我是童欧巴。欢迎来到前端食堂技术周刊,我们先来…...
获取 Android 的 SHA1 值
1、调试版,可以直接在 Android studio 中的 gradle 中查看。也可以用下面方法进行 前提要先确定签名文件所在的路径:调试版默认使用的签名文件是debug.keystore,文件处于 C 盘用户目录下的.android文件夹下。打开命令行工具, 1、…...
! [remote rejected] develop -> develop (pre-receive hook declined)
问题 git push 远程提交dao develop 分支失败,出现下面错误信息 remote: GitLab: You are not allowed to push code to protected branches on this project. To https://xxx.com.cn/xxx/xxx/xxx/xxx.git/! [remote rejected] develop -> develop (pre-receiv…...
最强的表格组件—AG Grid使用以及License Key Crack
PS: 想要官方 License Key翻到最后面 Ag Grid简介 Ag-Grid 是一个高级数据网格,适用于JavaScript/TypeScript应用程序,可以使用React、Angular和Vue等流行框架进行集成。它是一种功能强大、灵活且具有高度可定制性的表格解决方案,提供了丰富…...
【算法】逆波兰表达式
文章目录 定义求法代码思想: 定义 逆波兰表达式也称为“后缀表达式”,是将运算符写在操作数之后的运算式。 求法 *如:(ab)c-(ab)/e的转换过程: 先加上所有的括号。 (((ab)*c)-((ab)/e))将所有的运算符移到括号外面 (((ab) c)* …...
添加SQLCipher 到项目中
文章目录 一、克隆下载SQLCipher二、手动导入1. 生成sqlite3.c2. 在项目中添加命令3. 添加 Security.framework 三、CocoaPods导入 SQLCipher官方地址 一、克隆下载SQLCipher $ cd ~/Documents/code $ git clone https://github.com/sqlcipher/sqlcipher.git二、手动导入 1.…...
轻松预约,尽享美食,详解餐厅预约小程序的设计与实现
随着智能手机的普及和人们生活水平的提高,餐厅预约已经成为人们日常生活中的一部分。为了更好地满足人们的需求,许多餐厅开始使用小程序来提供更方便快捷的预约服务。本文将介绍如何制作一款餐厅预约小程序的详细步骤。 1. 进入乔拓云网后台,…...
数据结构--栈和队列3.1(栈-顺序结构)
目录 栈(Stack)栈顶(top)栈底(bottom)空栈(不含任何元素) 创建栈 入栈操作 出栈操作 销毁一个栈 计算栈的当前容量 实例分析 栈的插入操作叫做进栈(Push…...
pdf怎么压缩到1m?这样做压缩率高!
PDF是目前使用率比较高的一种文档格式,因为它具有很高的安全性,还易于传输等,但有时候当文件体积过大时,会给我们带来不便,这时候简单的解决方法就是将其压缩变小。 想要将PDF文件压缩到1M,也要根据具体的情…...
AttentionFreeTransformer 源码解析(一):AFTFull、AFTSimple、AFTLocal
我觉得源码写的很好懂,我就不加注释了,直接上计算流程图。 AFTFull class AFTFull(nn.Module):def __init__(self, max_seqlen, dim, hidden_dim64):super().__init__()max_seqlen: the maximum number of timesteps (sequence length) to be fed indim…...
C++ 计算 拟合优度R^2
解决的问题: 拟合优度(Goodness of Fit)是指回归直线对观测值的拟合程度,度量拟合优度的统计量是可决系数(亦称确定系数) R?。R最大值为 1。R%的值越接近1,说明回归直线对观测值的拟合程度越好,反之,R%值越小&#x…...
Springboot-Retrofit HTTP工具框架快速使用
在SpringBoot项目直接使用okhttp、httpClient或者RestTemplate发起HTTP请求,既繁琐又不方便统一管理。 因此,在这里推荐一个适用于SpringBoot项目的轻量级HTTP客户端框架retrofit-spring-boot-starter,使用非常简单方便,同时又提供…...
微信小程序实现人脸识别(从一个没有开通人脸核身的小程序跳转到要给开通人脸核身的小程序,进行人脸识别后再跳转回来)
A小程序没有开通人脸识别功能,B小程序开通了人脸识别。 总体思路是:从A小程序需要进行人脸识别的地方携带参数跳转到B小程序进行人脸识别,识别后把参数传递回来。 A小程序的参考代码如下: //人脸识别相关 start powerDrawerFace(e){var that = thisthat.setData({faceO…...
CSS-grid布局
网格布局也叫grid布局,平常写样式的时候基本上都是用的flex布局。 像以下布局,用flex布局就可能会有有点麻烦,这时候用grid布局就方便的多了。 或者是照片墙 grid布局就是将容器划分为行和列,产生单元格,然后在指定的…...
【JavaEE进阶】Bean 作用域和生命周期
文章目录 一. 关于Bean作用域的实例1. lombok2. 实例代码 二. 作用域定义1. Bean的六种作用域2. 设置作用域 三. Spring 执行流程和 Bean 的生命周期1. Spring 执行流程2. Bean生命周期 一. 关于Bean作用域的实例 注意在此例子中需要用到lombok 1. lombok lombok是什么? Lo…...
3分钟自建查分系统?现在每个人都可以实现了
学生成绩查询系统在现代教育管理中扮演着重要的角色,它不仅可以方便学生和家长查询成绩,也能帮助老师更好地管理和分析学生的学业表现。作为一名教师,了解如何制作学生成绩查询系统是提高教学效率和管理学生成绩便利性的关键。 在制作学生成…...
云音乐歌词提取:一站式歌词获取与管理解决方案
云音乐歌词提取:一站式歌词获取与管理解决方案 【免费下载链接】163MusicLyrics 云音乐歌词获取处理工具【网易云、QQ音乐】 项目地址: https://gitcode.com/GitHub_Trending/16/163MusicLyrics 还在为音乐播放器找不到歌词而烦恼吗?163MusicLyri…...
Git打Tag避坑指南:从创建、推送到删除,一次讲清新手常犯的5个错误
Git打Tag避坑指南:从创建、推送到删除,一次讲清新手常犯的5个错误 在团队协作开发中,Git Tag的使用看似简单,却隐藏着不少"坑"。很多开发者都遇到过这样的场景:本地打了Tag以为万事大吉,结果同事…...
别再傻傻分不清了!ARM Cortex-M开发中SVC和PendSV中断到底该怎么用?(附FreeRTOS/RT-Thread实战对比)
ARM Cortex-M开发中SVC与PendSV中断的深度解析与实战应用 在嵌入式系统开发领域,特别是使用ARM Cortex-M系列处理器时,SVC和PendSV这两个中断机制常常让开发者感到困惑。它们看似功能相似,却在实时操作系统(RTOS)中扮演着截然不同的角色。本文…...
大模型安全防护:典型攻击方法与防御策略
1. 大模型安全防护面临的挑战大型语言模型在各类应用场景中展现出强大能力的同时,其安全性问题也日益凸显。作为从业者,我们在实际部署和使用过程中发现,即使是最先进的防护措施,也可能存在被特定攻击手段绕过的风险。这些攻击手法…...
WeiClaw:基于配置的Web自动化与数据采集框架实战指南
1. 项目概述与核心价值最近在折腾一个挺有意思的开源项目,叫“kellyvv/WeiClaw”。乍一看这个名字,可能有点摸不着头脑,但如果你对自动化、数据采集或者RPA(机器人流程自动化)感兴趣,那这个项目绝对值得你花…...
Python代码质量提升:从规范到优化的实践指南
1. 为什么需要提升Python代码质量 刚入行时我写过不少能跑就行的Python脚本,直到有次在线上环境因为一个缩进错误导致服务崩溃,才意识到代码质量的重要性。Python作为动态类型语言,在提供灵活性的同时也带来了更多潜在风险。良好的编码习惯不…...
云服务器部署Hermes Agent(爱马仕龙虾)的详细教程
云服务器部署Hermes Agent(爱马仕龙虾)的详细教程 关键词:Hermes Agent部署、AI Agent部署教程、腾讯云Lighthouse、微信接入AI助手、Hermes Agent安装、AI助手云端运行 最近一直在研究「AI Agent长期运行」的方案。 本地跑 Agent 最大的问…...
LFM2-2.6B-GGUF在运维自动化中的应用:智能解析日志并执行故障修复脚本
LFM2-2.6B-GGUF在运维自动化中的应用:智能解析日志并执行故障修复脚本 1. 运维自动化的新机遇 凌晨三点,服务器突然告警。运维工程师小王从睡梦中惊醒,手忙脚乱地登录系统查看日志,发现是数据库连接池耗尽导致的服务不可用。这种…...
免费解锁Windows虚拟显示器:Parsec VDD完整指南,游戏直播与远程办公的终极解决方案
免费解锁Windows虚拟显示器:Parsec VDD完整指南,游戏直播与远程办公的终极解决方案 【免费下载链接】parsec-vdd ✨ Perfect virtual display for game streaming 项目地址: https://gitcode.com/gh_mirrors/pa/parsec-vdd 你是否曾为远程服务器缺…...
Python爬虫遇到‘utf-8‘解码失败?手把手教你用chardet库自动检测编码(附requests实战)
Python爬虫编码困境终结者:用chardet智能攻克乱码难题 当爬虫遇上乱码:一个开发者的日常噩梦 上周三凌晨两点,我盯着屏幕上那行熟悉的报错信息——UnicodeDecodeError: utf-8 codec cant decode byte 0xb2 in position 135——第17次尝试抓取…...
