前端入门到入土?

文章目录

  • 前言
  • http和https的区别,https加密的原理是?
    • 区别
    • https的加密原理
  • TCP为什么要三次握手?
  • proxy代理的原理?
  • 内存泄漏?
    • 什么是内存泄漏?
    • 为什么会有内存泄漏?
    • 内存泄漏的情况?
    • 如何防止内存泄漏的问题?
  • 后言

前言

后序我会更新一系列的前端面试题,感兴趣的可以关注一手

http和https的区别,https加密的原理是?

区别

http

HTTP 是一种无状态协议。每个请求都是独立的,服务器不会保留任何与先前请求相关的信息。
数据传输是明文的,不进行加密。这意味着攻击者可以截获、查看和修改传输的数据。
默认使用端口80进行通信。

https

HTTPS 是在 HTTP 基础上加入了安全性的扩展版本。
HTTPS 使用 SSL(安全套接字层)或 TLS(传输层安全)协议对数据进行加密。这样,通过加密传输,使得数据更难以被窃取、篡改或伪造。
HTTPS 需要使用数字证书来验证服务器的身份。这样客户端可以确保它们正在与预期的服务器进行通信,而不是中间人攻击者。
默认使用端口443进行通信。

https的加密原理

HTTPS 的加密原理主要基于公钥加密和对称密钥加密两种方式的结合。
公钥加密(非对称加密):

服务器生成一对密钥:公钥和私钥。公钥用于加密数据,私钥用于解密数据。
服务器将公钥发送给客户端。
客户端使用服务器的公钥对要发送的数据进行加密,并将加密后的数据发送给服务器。
由于只有服务器拥有与之配对的私钥,所以只有服务器能够解密客户端发送的数据。

对称密钥加密:

在建立安全连接后,服务器和客户端协商生成一个临时的对称密钥(会话密钥)。
服务器使用自己的私钥对对称密钥进行加密,然后将加密后的对称密钥发送给客户端。
客户端使用服务器的公钥解密收到的加密对称密钥。
服务器和客户端之间的后续通信将使用对称密钥进行加密和解密。

混合加密解决的问题
通过公钥加密,HTTPS 实现了数据传输阶段的安全性,保护了数据在传输过程中的机密性;通过对称密钥加密,实现了数据传输阶段的高效性,提高了数据传输的速度。这样,HTTPS 综合了公钥加密和对称密钥加密的优点,确保了数据的安全性和完整性。

TCP为什么要三次握手?

  • 双方同步初始序列号:双方在建立连接之前,发送方和接收方都需要确定初始的序列号,以便用于后续的数据传输和确认。通过三次握手,发送方和接收方可以同时交换并确认彼此的初始序列号。

  • 确认双方的接收能力:三次握手过程中,发送方首先发送一个带有 SYN(同步)标志的包给接收方,表示请求建立连接,并将自己的初始序列号发送给接收方。接收方收到后,会发送一个带有 SYN/ACK(同步/确认)标志的包给发送方,表示接收方已收到请求并同意建立连接,同时确认发送方的初始序列号。最后,发送方再发送一个带有 ACK(确认)标志的包给接收方,表示发送方收到了接收方的确认。

  • 防止已失效的连接请求被误认为有效:由于网络延迟或其他原因,可能会出现发送方发送的连接请求在传输过程中被丢失,而接收方无法正确确认该连接是否建立。如果没有三次握手,接收方会认为发送方发送的请求是有效的,从而可能导致建立了不必要的无效连接。通过三次握手,可以确保发送方和接收方都确认了彼此的连接请求,避免了误认为失效连接请求的情况。

proxy代理的原理?

创建代理对象:通过使用 Proxy 构造函数,我们可以创建一个代理对象。该构造函数接受两个参数:目标对象(target)和处理程序(handler)。

定义处理程序:处理程序是一个对象,其中定义了一些特殊的方法,用于拦截对目标对象的操作。常见的拦截方法包括 get、set、apply 等。当我们对代理对象进行操作时,这些拦截方法会被触发。

操作拦截:当我们对代理对象进行操作时,比如获取属性、设置属性、调用函数等,处理程序中相应的拦截方法会被调用。我们可以在这些拦截方法中自定义行为逻辑。

转发操作:在处理程序中,我们可以选择将操作转发给目标对象,也可以选择忽略操作或返回自定义的结果。通过将操作转发给目标对象,我们可以保持对目标对象的访问,并且可以在转发前后执行自定义逻辑。

内存泄漏?

什么是内存泄漏?

内存泄漏指的是程序在使用内存时,由于某些原因导致程序无法释放已经分配的内存。这会导致系统中的可用内存逐渐减少,最终可能会导致程序崩溃或系统资源不足。

为什么会有内存泄漏?

  • 资源未释放:最常见的内存泄漏是忘记释放已经动态分配的内存。例如,在使用malloc、new等分配内存的函数后,如果没有使用相应的free、delete函数释放内存,就会导致内存泄漏。

  • 引用计数错误:某些语言或框架可能使用引用计数来管理内存,即对象被引用时计数加一,不再被引用时计数减一。如果引用计数错误,计数值无法归零,就会导致内存泄漏。

  • 循环引用:当两个或多个对象相互引用时,如果没有正确处理,它们之间会形成循环引用。在这种情况下,即使对象已经不再被使用,由于引用关系仍存在,对象无法被垃圾回收,从而导致内存泄漏。

  • 缓存问题:缓存是提高性能的常用技术,但如果没有合理管理缓存,就容易导致内存泄漏。比如过期的缓存没有及时清理,或者缓存中存储了大量不再使用的数据。

  • 句柄泄漏:句柄是一种用于访问资源或对象的引用,如文件句柄、网络连接句柄等。如果在使用完毕后没有关闭或释放句柄,就可能导致内存泄漏。

  • 异常处理不当:在异常处理时,如果没有正确释放分配的内存和资源,就会导致内存泄漏。

内存泄漏的情况?

  • 内存使用量逐渐增加:在长时间运行的程序中,如果存在内存泄漏,内存使用量会逐渐增加而不会释放,导致系统可用内存不断减少。

  • 程序运行变慢或卡顿:由于内存泄漏导致系统内存不足,程序可能会变得运行缓慢或出现卡顿现象。这是因为系统不得不频繁进行内存交换,从而影响了程序的执行效率。

  • 频繁的垃圾回收操作:某些编程语言或框架中使用垃圾回收机制来自动管理内存,在发生内存泄漏的情况下,垃圾回收器需要不断运行来释放未被引用的内存,这会导致频繁的垃圾回收操作,降低了程序的性能。

  • 程序异常终止或崩溃:当内存泄漏达到一定程度时,可用内存耗尽,可能会导致程序异常终止或崩溃。这是因为操作系统无法为程序提供所需的内存资源。

  • 资源无法释放:在代码中未释放已分配的内存或其他资源,这些资源将一直占用系统资源,直到程序结束或系统重新启动。

  • 内存泄漏警告:一些开发工具或调试器可能会检测到内存泄漏,并给出相应的警告信息。这些警告通常指示程序中存在未释放的内存或资源。

如何防止内存泄漏的问题?

  • 仔细审查代码:检查代码,找出可能导致内存泄漏的地方。查看是否有未释放的内存分配、资源未关闭或清理的情况。

  • 使用合适的内存管理机制:在使用动态内存分配的语言中,例如C++中的new和delete,需要确保每次分配内存后都要正确释放。可以使用智能指针等自动内存管理的工具来避免手动释放内存的问题。

  • 注意循环引用:如果出现了对象之间的循环引用,应该采取一些手段打破这种引用关系。例如,使用弱引用代替强引用,或者重新设计对象之间的关系,以避免产生循环引用。

  • 合理使用缓存:对于使用缓存的情况,需要注意合理管理缓存的生命周期。及时清理过期的缓存或不再使用的缓存项,避免长时间保留不必要的数据。

  • 引入垃圾回收机制:对于支持垃圾回收的语言或框架,可以使用垃圾回收机制来自动管理内存,减少手动内存释放的风险。但仍需要注意编写代码时的一些规范,避免产生无法回收的对象。

  • 使用性能分析工具:使用专业的性能分析工具来检测和识别内存泄漏问题。这些工具可以帮助定位内存泄漏的源头,并提供相应的修复建议。

  • 进行测试和代码审查:进行全面的测试,包括单元测试、集成测试和回归测试,以确保程序在各种情况下都没有内存泄漏。同时进行代码审查,借助团队合作的力量来发现和纠正潜在的内存泄漏问题。

后言

创作不易,要是本文章对广大读者有那么一点点帮助 不妨三连支持一下,您的鼓励就是博主创作的动力

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PAT 1163 Dijkstra Sequence

个人学习记录,代码难免不尽人意。 Dijkstra’s algorithm is one of the very famous greedy algorithms. It is used for solving the single source shortest path problem which gives the shortest paths from one particular source vertex to all the other v…

关于MySQL数据库版本不同导致表进行比较的时候报错illegal mix of collations...的问题

问题发生的原委 之前在项目开发的时候,我本地也建立了数据库用作开发库,我本地的数据库版本是5.7的,但是测试和生产库都是8.0的版本,我们定义的数据库字符集是utf8mb4,排序规则是utf8mb4_general_ci,前段时…

数据库连接报错CannotGetJdbcConnectionException: Failed to obtain JDBC Connection

数据库连接报错CannotGetJdbcConnectionException: Failed to obtain JDBC Connection 报错信息 [Namecom.primeton.esb.online.restaurant.ms.online.mediaService.mediaService.biz][activity nameJDBC调用][activity idinvokePojo9] throw an exception:java.lang.Excepti…

TCP/IP协议簇的主要协议以及主要用途

目录 SLIP协议--(Serial line IP) PPP协议--(点对点协议) IP协议 ICMP协议 ARP协议 TCP协议 UDP协议 FTP协议 DNS协议 SMTP协议 TCP/IP协议簇是Internet的基础,TCP/IP是一组协议得代名词,包括许多…

springboot封装查询快递物流

目录 一、ApiClient代码解读二、ApiService代码解读三、HomeController代码解读四、整体代码五、结果展示 一、ApiClient代码解读 这是一个简单的Spring Boot的RestTemplate客户端,用于执行HTTP请求。 首先,这个类被Component注解标记,这意味…

【微服务部署】04-ForwardedHeaders

文章目录 1. ForwardedHeaders1.1 场景1.2 关键的HTTP头1.3 核心处理要点 1. ForwardedHeaders 1.1 场景 获取用户IP获取用户请求的原始URL 1.2 关键的HTTP头 X-Forwarded-ForX-Forwarded-ProtoX-Forwarded-Host 1.3 核心处理要点 设置PathBase设置ForwardedHeaders中间件…

2024毕业设计选题指南【附选题大全】

title: 毕业设计选题指南 - 如何选择合适的毕业设计题目 date: 2023-08-29 categories: 毕业设计 tags: 选题指南, 毕业设计, 毕业论文, 毕业项目 - 如何选择合适的毕业设计题目 当我们站在大学生活的十字路口,毕业设计便成了我们面临的一项重要使命。这不仅是对我们…

vue训练场练习props和$emit,实现大写输入,小写输出。

场景: 在vue官网训练场,使用训练场中的组件。 仅作为练习笔记,仅供产考。 App.vue 组件代码 方式一:Watch监听 方式二:input绑定

【hadoop运维】running beyond physical memory limits:正确配置yarn中的mapreduce内存

文章目录 一. 问题描述二. 问题分析与解决1. container内存监控1.1. 虚拟内存判断1.2. 物理内存判断 2. 正确配置mapReduce内存2.1. 配置map和reduce进程的物理内存:2.2. Map 和Reduce 进程的JVM 堆大小 3. 小结 一. 问题描述 在hadoop3.0.3集群上执行hive3.1.2的任…

多线程的五种“打开”方式

1 概念 1.1 线程是什么?? 线程(Thread)是计算机科学中的一个基本概念,它是进程(Process)中的一个执行单元,负责执行程序的指令序列。线程是操作系统能够进行调度和执行的最小单位。…

GB28181学习(二)——注册与注销

概念 使用REGISTER方法进行注册和注销;注册和注销应进行认证,认证方式应支持数字摘要认证方式,高安全级别的宜支持数字证书认证;注册成后,SIP代理在注册过期时间到来之前,应向注册服务器进行刷新注册&…

Spring——Spring Boot基础

文章目录 第一个helloword项目新建 Spring Boot 项目Spring Boot 项目结构分析SpringBootApplication 注解分析新建一个 Controller大功告成,运行项目 简而言之,从本质上来说,Spring Boot 就是 Spring,它做了那些没有它你自己也会去做的 Spri…

java-参数传递机制

java参数传递机制都是值传递。 基本类型参数传输都是数据值。 传递到方法中的值是拷贝后的值。 引用类型参数传输的都是地址值。 如果是数组的参数传递,那么是引用传递(本质上还是值传递,但是由于数组的值传递是传递数组的内存地址&#xf…

探索OLED透明屏的优缺点:引领科技未来的革命性突破

OLED透明屏作为一项革命性的创新技术,其令人惊叹的透明度和柔性性能引起了全球范围内的关注。 然而,了解OLED透明屏的优缺点对于我们全面认识其在科技未来中的地位至关重要。 今天,尼伽将深入探讨OLED透明屏的优势和限制,并借助…

spring boot项目生成容器并运行

一个安静的周末,shigen又睡懒觉了,上次说的拖延症的惩罚来了:早晚各100个健腹轮练习,早上的已经完成了。今天的文章来的有点晚,但是依旧保持质量。 springboot项目生成容器并运行 背景 将springboot项目打包成jar包&…

chatgpt谈论日本排放污水事件

W...Y的主页 😊 代码仓库分享 💕 近日,世界发生了让人义愤填膺的时间——日本排放核污水。这件事情是那么的突然且不计后果,海洋是我们全人类共同的财产,而日本却想用自己一己私欲将全人类的安全置之度外&#xff0c…

Mysql 性能分析 explain、Describe

通常 多表查询 比 子查询效率更高一些, 数据搜索引擎 如果子查询能转换城成多表查询,会自动转换。 explain 、describe 语法结构 explain select_options | update_options | insert_options | replace_options 或 describe select_options | update…

java反编译工具jd-gui使用

文章目录 一、JD-GUI介绍二、下载三、安装四、使用教程五、免责声明摘抄 一、JD-GUI介绍 JD-GUI是一个独立的图形实用程序,显示“.class”文件的Java源代码。 使用JD-GUI浏览重构的源代码,以便即时访问方法和字段。 二、下载 MAC安装包:ht…

安防视频监控/视频集中存储/云存储平台EasyCVR无法播放HLS协议该如何解决?

视频云存储/安防监控EasyCVR视频汇聚平台基于云边端智能协同,支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。音视频流媒体视频平台EasyCVR拓展性强,视频能力丰富,具体可实现视频监控直播、视频轮播、视频录像、…

学习周报9.3

文章目录 前言文献阅读一摘要挑战基于时间序列的 GAN 分类 文献阅读二摘要介绍提出的模型:时间序列GAN (TimeGAN) 代码学习总结 前言 本周阅读两篇文献,文献一是一篇时序生成方面的综述,主要了解基于时间序列 的GAN主要分类以及时间序列GAN方面面临的一…