HTML Input 文件上传功能全解析:从基础到优化
🤍 前端开发工程师、技术日更博主、已过CET6
🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1
🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》
🍚 蓝桥云课签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》
💬 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。
文章目录
- 一、引言
- 二、基本语法与属性设置
- (一)基本语法
- (二)重要属性
- 三、文件选择对话框与用户交互
- (一)文件选择对话框的触发
- (二)文件选择后的显示与信息获取
- 四、与服务器的交互
- (一)表单提交
- (二)服务器端处理
- 五、安全性考量
- (一)文件类型验证
- (二)文件大小限制
- (三)防止恶意文件上传
- 六、在不同场景下的应用优化
- (一)大文件上传优化
- (二)多文件批量上传优化
- 七、总结
一、引言
在现代网页应用中,文件上传功能是一项极为常见且重要的交互特性。无论是用户上传个人资料图片、分享文档,还是企业应用中的批量数据导入,都离不开文件上传功能的支持。而 HTML 中的<input>
元素搭配特定的属性设置,为实现文件上传提供了基础且强大的工具。本文将深入剖析 HTML <input>
文件上传功能的各个方面,包括其基本原理、属性设置、与服务器的交互、安全性考量以及在不同场景下的应用优化。
二、基本语法与属性设置
(一)基本语法
实现文件上传功能的<input>
元素基本语法如下:
<input type="file" name="fileUpload">
其中,type="file"
明确指定了该<input>
元素用于文件上传操作。name
属性则在表单提交时作为键,与上传文件的相关信息(如文件名、文件内容等)作为值一起发送给服务器。
(二)重要属性
- accept 属性
- 作用:用于限制可接受的文件类型。通过指定特定的 MIME 类型或文件扩展名,可以确保用户只能选择符合要求的文件进行上传。
- 示例:
accept="image/*"
表示只接受各种图像类型的文件;accept="application/pdf"
则仅允许上传 PDF 文件;还可以设置多个可接受的类型,如accept="image/png,image/jpeg,application/pdf"
。
- multiple 属性
- 作用:当设置了
multiple
属性时,用户可以在文件选择对话框中选择多个文件进行上传。这在需要批量上传文件的场景中非常有用,如批量上传图片库或多个文档。 - 示例:
<input type="file" name="filesUpload" multiple>
,用户在选择文件时,可以通过按住键盘上的特定键(如 Ctrl 键在 Windows 系统或 Command 键在 Mac 系统)来选择多个文件。
- 作用:当设置了
三、文件选择对话框与用户交互
(一)文件选择对话框的触发
当用户点击type="file"
的<input>
元素时,浏览器会弹出文件选择对话框。这个对话框的外观和操作方式在不同的浏览器和操作系统下可能会略有差异,但基本功能都是让用户浏览本地文件系统并选择要上传的文件。
(二)文件选择后的显示与信息获取
- 在用户选择文件后,通常在
<input>
元素旁边会显示所选文件的文件名(部分浏览器可能还会显示文件大小等简要信息)。在一些现代浏览器中,还可以通过 JavaScript 来获取更详细的文件信息,如文件类型、文件大小、最后修改日期等。例如:
const fileInput = document.getElementById('fileUpload');
fileInput.addEventListener('change', function() {const selectedFiles = this.files;for (let i = 0; i < selectedFiles.length; i++) {const file = selectedFiles[i];console.log('文件名:', file.name);console.log('文件大小:', file.size);console.log('文件类型:', file.type);}
});
- 如果设置了
accept
属性,文件选择对话框中会自动过滤掉不符合要求的文件,只显示可接受的文件类型,方便用户快速定位到合适的文件进行选择。
四、与服务器的交互
(一)表单提交
当文件上传<input>
元素位于一个<form>
表单内时,点击表单的提交按钮(通常是<button type="submit">
),表单会将文件上传相关的数据发送到服务器。在表单的method
属性设置为POST
(一般用于文件上传的常用方法)的情况下,文件数据会以特定的格式(如多部分表单数据格式,multipart/form-data
)被包含在 HTTP 请求中发送给服务器。
例如:
<form action="/upload" method="POST" enctype="multipart/form-data"><input type="file" name="fileUpload"><button type="submit">上传文件</button>
</form>
在这个例子中,当用户点击提交按钮后,浏览器会将所选文件以multipart/form-data
格式发送到/upload
这个服务器端的 URL 地址。
(二)服务器端处理
- 服务器端接收到文件上传请求后,需要使用相应的服务器端编程语言和框架来处理上传的文件。例如,在 Node.js 中,可以使用
express
框架结合multer
中间件来处理文件上传:
const express = require('express');
const multer = require('multer');
const app = express();const storage = multer.diskStorage({destination: function(req, file, cb) {// 设置文件存储的目录cb(null, 'uploads/');},filename: function(req, file, cb) {// 设置上传文件的文件名cb(null, file.fieldname + '-' + Date.now() + '.' + file.originalname.split('.').pop());}
});const upload = multer({ storage: storage });app.post('/upload', upload.single('fileUpload'), function(req, res) {// 文件上传成功后的处理逻辑res.send('文件上传成功');
});app.listen(3000, function() {console.log('服务器运行在 3000 端口');
});
在上述代码中,multer
中间件负责解析上传的文件数据,将文件存储到指定的目录,并在文件上传成功后执行相应的回调函数。
2. 对于其他服务器端语言,如 Python 的Flask
框架,可以使用flask_uploads
扩展来处理文件上传;在 PHP 中,可以通过$_FILES
超全局变量来获取上传文件的信息并进行处理。
五、安全性考量
(一)文件类型验证
虽然可以通过accept
属性在前端对文件类型进行初步限制,但这种限制是可以被绕过的。因此,在服务器端必须再次对上传文件的类型进行严格验证。可以通过检查文件的 MIME 类型、文件头信息或文件扩展名等多种方式来确保上传文件的类型符合预期。例如,在 Node.js 中,可以使用file-type
库来检查文件的类型:
const fileType = require('file-type');// 假设已经获取到上传文件的 buffer 数据
const buffer = //... 获取文件 buffer 数据的过程
const type = fileType(buffer);
if (type && (type.mime === 'image/png' || type.mime === 'image/jpeg')) {// 文件类型符合要求,继续处理
} else {// 文件类型不符合,拒绝上传
}
(二)文件大小限制
为了防止用户上传过大的文件导致服务器资源耗尽或应用程序出现异常,需要在前端和服务器端都设置文件大小限制。在前端,可以使用 JavaScript 来检查用户选择文件的大小,在超过一定限制时给予用户提示并阻止表单提交。例如:
const fileInput = document.getElementById('fileUpload');
fileInput.addEventListener('change', function() {const selectedFiles = this.files;const maxSize = 10 * 1024 * 1024; // 10MB 的限制for (let i = 0; i < selectedFiles.length; i++) {const file = selectedFiles[i];if (file.size > maxSize) {alert('文件过大,请选择小于 10MB 的文件');fileInput.value = ''; // 清空文件选择return;}}
});
在服务器端,也需要设置相应的文件大小限制配置。例如,在 Node.js 的multer
中间件中,可以设置limits
选项来限制文件大小:
const upload = multer({storage: storage,limits: {fileSize: 10 * 1024 * 1024 // 10MB 的限制}
});
(三)防止恶意文件上传
上传的文件可能包含恶意代码,如病毒、木马或恶意脚本。为了防止恶意文件上传,除了上述的文件类型和大小验证外,还可以对上传文件进行病毒扫描。一些服务器端安全软件或云服务提供了文件病毒扫描功能,可以集成到文件上传处理流程中。此外,对于可执行文件类型(如.exe
、.sh
等),一般应禁止上传,除非有特殊的、严格安全控制的应用场景。
六、在不同场景下的应用优化
(一)大文件上传优化
当上传大文件(如几 GB 的视频文件或大型数据库备份文件)时,传统的文件上传方式可能会出现问题,如上传过程中网络中断导致上传失败且需重新开始、长时间占用服务器资源等。为了优化大文件上传,可以采用以下技术:
- 分块上传:将大文件分割成多个小块,分别上传每个小块,在服务器端再将这些小块合并成完整的文件。这样即使在上传过程中出现网络中断,也可以只重新上传中断的小块,而不是整个文件。例如,可以使用
resumable.js
库在前端实现分块上传功能,在服务器端使用相应的逻辑来处理分块文件的接收和合并。 - 断点续传:结合分块上传,记录已上传的块信息,当上传中断后重新开始上传时,可以从上次中断的位置继续上传。这需要在前端和服务器端都建立相应的状态记录和恢复机制。
(二)多文件批量上传优化
在多文件批量上传场景中,除了前面提到的使用multiple
属性方便用户选择多个文件外,还可以在上传过程中提供进度条显示,让用户了解每个文件以及整个批量上传的进度。在服务器端,可以优化文件处理逻辑,采用异步处理或多线程处理等方式,提高批量上传的效率,减少用户等待时间。例如,在 Node.js 中,可以使用async
库来处理多个文件上传的异步操作,确保每个文件的上传和处理都不会阻塞其他文件的上传流程。
七、总结
HTML <input>
文件上传功能是构建现代网页应用中文件交互功能的重要基石。通过深入理解其基本语法、属性设置、与服务器的交互机制、安全性考量以及在不同场景下的应用优化方法,开发人员可以构建出安全、高效、用户体验良好的文件上传功能模块。在未来的网页开发中,随着网络技术的不断发展和用户需求的日益复杂,文件上传功能也将不断演进和完善,为用户提供更加便捷、强大的文件交互体验。
相关文章:
HTML Input 文件上传功能全解析:从基础到优化
🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…...
深入理解Spring事务
目录 什么是Spring事务为什么需要Spring事务Spring事务的实现 Spring事务的传播机制Spring事务的底层原理 EnableTransactionManagement --开启Spring管理事务Import(TransactionManagementConfigurationSelector.class) --提供两个beanAutoProxyRegistrar --启用AOP的功能&am…...
React学习笔记2-初识React
这篇七个点:1 环境搭建, 2 JSX, 3 组件,4 数据流,5 生命周期,6 React与DOM,7 实例 1 环境搭建 1.1 引用React CDN <!DOCTYPE html> <html lang"en"> <head><met…...
【5G】Spectrum 频谱
频谱是移动运营商的关键资产,可用的频谱是定义移动网络容量和覆盖范围的重要因素。本章讨论了5G的不同频谱选项、它们的特性以及5G早期部署阶段的预期频谱。5G是首个旨在利用大约400 MHz到90 GHz之间所有频段的移动无线系统。5G还设计用于在许可、共享和非许可频谱带…...
解决流网络中不存在s~u~t路径的节点的最大流问题
解决流网络中不存在s~u~t路径的节点的最大流问题 问题分析伪代码C代码示例解释在流网络问题中,我们通常会假设对于所有的节点v ∈ V,都存在一条从源点s到汇点t经过v的路径。然而,当这一假设不成立时,即存在某些节点u,使得不存在路径sut,我们需要证明在这种情况下,网络中…...
springboot的 nacos 配置获取不到导致启动失败及日志不输出问题
前言 问题 1. 本地启动应用时,一切正常,但是部署 docker 后,会因为获取不到 nacos 中的配置导致服务启动失败。 2.当 docker 中的服务一直重启,可能会突然某一次启动成功,之后只要不重新构建 docker 镜像&am…...
word poi-tl 图表功能增强,插入图表折线图、柱状图、饼状图
目录 问题解决问题poi-tl介绍 功能实现引入依赖功能介绍 功能实例饼图模版代码效果图 雷达图(模版同饼图)代码效果图 柱状图(模版同饼图)代码效果图 附加CustomCharts 工具类CustomChartSingleSeriesRenderData 数据对象CustomCha…...
SpringBoot 项目如何集成 JWT
SpringBoot 项目如何集成 JWT JWT JSON Web Token (JWT) 是一个开放标准(RFC 7519),它定义了一种紧凑的、自包含的方式,用于作为 JSON 对象在各方之间安全地传输信息。 在 Oauth2 中,其实就是返回访问令牌 (access_token&#…...
如何查看电脑刷新率
Windows 系统 通过显示设置查看: 右键点击桌面空白处,选择 “显示设置”。在打开的窗口中,找到 “高级显示设置”。点击 “显示适配器属性”。在弹出的窗口中,选择 “监视器” 选项卡,即可看到当前的屏幕刷新率。使用 …...
MVC基础——市场管理系统(一)
文章目录 项目地址一、创建项目结构1.1 创建程序以及Controller1.2 创建View1.3 创建Models层,并且在Edit页面显示1.4 创建Layou模板页面1.5 创建静态文件css中间件二、Categories的CRUD2.1 使用静态仓库存储数据2.2 将Categorie的列表显示在页面中(List)2.3 创建_ViewImport.…...
面向对象中多态的含义
多态性的定义 多态(Polymorphism)是面向对象编程中的一个重要概念。它是指同一个函数名或操作符在不同的对象或情境下具有不同的行为。简单来说,就是 “多种形态”。例如,在一个图形处理程序中,有 “计算面积” 这个操…...
L2G3000-LMDeploy 量化部署实践
文章目录 LMDeploy 量化部署实践闯关任务环境配置W4A16 量化 KV cacheKV cache 量化Function call LMDeploy 量化部署实践闯关任务 环境配置 conda create -n lmdeploy python3.10 -y conda activate lmdeploy conda install pytorch2.1.2 torchvision0.16.2 torchaudio2.1.…...
ubuntu下的chattts 学习5:Example: self introduction
代码 import ChatTTS import torch import torchaudiochat ChatTTS.Chat() chat.load(compileFalse) # Set to True for better performance ################################### inputs_en """ chat T T S is a text to speech model designed for dialogu…...
IDEA的service窗口中启动类是灰色且容易消失
大家在学习Spring Cloud的过程中,随着项目的深入,会分出很多个微服务,当我们的服务数量大于等于三个的时候,IDEA会给我们的服务整理起来,类似于这样 但是当我们的微服务数量达到5个以上的时候,再启动服务的时候,服务的启动类就会变成灰色,而且还容易丢失 解决方法 我们按住…...
vue中pdf.js的使用,包括pdf显示,跳转指定页面,高亮关键词
目录 一、下载pdf.js 二、引入到本地的项目中 三、实现预览pdf 四、跳转到指定页面 五、利用pdf里面的find查找关键词 六、修改页面大小为实际大小 一、下载pdf.js https://github.com/mozilla/pdf.js 里面有很多的版本, 高版本的可能浏览器不兼容或者还要考…...
Cherno C++学习笔记 P32 字符串
这篇文章我们来讲字符串。字符串可以说是最重要的变量类型了,因为对字符串的读写极大地影响到我们的程序和用户之间的交互。甚至很多很庞大的程序就只是在处理字符串。 对于字符串,我们同时需要有关于数组和指针的关系,字符串的实现与数组是…...
【C++初阶】第7课—标准模版库STL(string_1)
文章目录 1. 什么是STL2. STL六大组件3. 标准库中string类3.1 auto关键字3.2 范围for3.3 string类的类型3.4 string类的常用接口(string类对象的常见构造)3.5 string的析构和赋值运算符重载3.6 string类对象的容量操作 1. 什么是STL STL(standard template library—标准模板库…...
GESP202306 一级【时间规划】题解(AC)
》》》点我查看「视频」详解》》》 AC_Code #include <bits/stdc.h> using namespace std;int main() {int h1, m1, h2, m2;cin >> h1 >> m1;cin >> h2 >> m2;h1 h1 * 60 m1;h2 h2 * 60 m2;cout << h2 - h1;return 0; }》》》点我查…...
React基础知识四 Hooks
什么是hooks? (coderwhy) hooks是react 16.8(2019年)出的新特性。 react有两种形式来创建组件——类式和函数式。在hooks之前类式组件就是react最主流的编程方式。 这个时候,函数式组件是非常鸡肋的,几乎没什么用。因…...
Linux服务器通用安全加固指南
1、保护引导过程(以Grub引导为例) 在 /etc/inittab 中添加 sp:S:respawn:/sbin/sulogin,以确保当切换到单用户模式时 运行级的配置要求输入 root 密码: cp /etc/inittab / etc/initab .bak vim /etc/inittab 退出:es…...
vsphere vcenter web 界面的介绍
这是主页的页面...
分类算法中的样本不平衡问题及其解决方案
一、样本不平衡问题概述 在机器学习的分类任务中,样本不平衡是指不同类别训练样本数量存在显著差异的现象。这一差异会给模型训练和性能评估带来挑战,尤其在处理少数类样本时,模型可能难以有效学习其特征。 以二分类为例,理想情况…...
[LitCTF 2023]破损的图片(初级)
[LitCTF 2023]破损的图片(初级) 我们下载附件得到一个没有后缀的文件,拖去010看一看,发现本来应该是文件头的那部分不大对劲,结合后面四个点以及IHDR,大致也应该知道是啥了 修改第一行为png 89 50 4E 47 0D 0A 1A 0A 00 00 00 …...
最新道客巴巴怎么免费下载文档方法
一、利用浏览器插件 插件自动识别下载:对于经常需要下载道客巴巴文档的人来说,安装浏览器插件是不错的选择。如Chrome浏览器上的一些插件(如PDF在线转换器等),安装后,在浏览器中打开道客巴巴文档ÿ…...
Bert的Transformer原理
多义词如何应对: 答:通过Self attention,不同的上下文,对同一个"苹果",得到截然不同的embedding激活值; Multi-head的作用: 有些类似CNN里用的多个卷积核得到多个Channel的特征图&…...
多人聊天室 NIO模型实现
NIO编程模型 Selector监听客户端不同的zhuangtai不同客户端触发不同的状态后,交由相应的handles处理Selector和对应的处理handles都是在同一线程上实现的 I/O多路复用 在Java中,I/O多路复用是一种技术,它允许单个线程处理多个输入/输出&…...
vue.js学习(day 20)
综合案例:购物车 数据渲染 构建cart购物车模块 准备后端接口服务环境 请求数据存入vuex cart.js // 新建购物车模块 import axios from axios export default {namespaced: true,state () {return {// 购物车数据 [{},{}]list: []}},mutations: {updateList (…...
蓝桥杯二分题
P1083 [NOIP2012 提高组] 借教室 题目描述 在大学期间,经常需要租借教室。大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室。教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样。 面对海量租…...
通过 CC-Link IEFB 转 Modbus RTU 网关达成三菱 FX5U PLC 与 RS485 温湿度传感器通信的配置实例展示
一. 案例背景 在某一化工厂现场,现场的设备是三菱FX5UPLC为了避免因为工作环境存在潮湿度较高性、较高温度等对员工造成不健康或危险的现象,现决定在现场装数多台温湿度传感器。通过捷米特JM-CCLKIE-RTU网关将三菱PLC及温湿度传感器连接起来并连接上位机…...
视频质量评价算法 DOVER 使用教程
DOVER 介绍 DOVER是为ICCV2023会议论文“Exploring Video Quality Assessment on User Generated Contents from Aesthetic and Technical Perspectives”提供的官方代码、演示和权重的项目。DOVER(Disentangled Objective Video Quality Evaluator)是一个用于评估用户生成内…...
视频编辑技术:一键生成混剪视频的AI技术应用
随着视频内容的爆炸式增长,视频编辑技术也在不断进步。本文将探讨如何利用AI技术,实现一键生成混剪视频,并自动添加配音和字幕,以提高视频编辑的效率和质量。 AI技术在视频编辑中的应用 AI技术在视频编辑领域的应用越来越广泛&am…...
精确的单向延迟测量:使用普通硬件和软件
论文标题:Precise One-way Delay Measurement with Common Hardware and Software(精确的单向延迟测量:使用普通硬件和软件) 作者信息:Maciej Muehleisen 和 Mazen Abdel Latif,来自Ericsson Research Eri…...
【博士每天一篇文献-COIL算法】Co-transport for class-incremental learning
1 介绍 年份:2021 会议:2021ACM Zhou D W, Ye H J, Zhan D C. Co-transport for class-incremental learning[C]//Proceedings of the 29th ACM International Conference on Multimedia. 2021: 1645-1654. 本文提出的算法是CO-transport for clas…...
AI与BI的火花:大语言模型如何重塑商业智能的未来
大家好,我是独孤风。 在当今这个数据驱动的时代,企业对于信息的需求如同对于氧气的需求一般至关重要。商业智能(BI)作为企业获取、分析和呈现数据的关键工具,正在经历一场深刻的变革,而这一变革的催化剂正是…...
C++设计模式(建造者、中介者、备忘录)
一、建造者模式 将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。 示例: //房子(产品类) class House { private:int rooms;int windows;string decoration; public:void setRooms(int r) {rooms …...
【数据结构】遍历二叉树
遍历二叉树的算法描述(递归定义) 先序遍历 若二叉树为空,则空操作; 否则 (1)访问根节点 (2)先序遍历左子树 (3)先序遍历右子树 中序遍历 若二叉树为空…...
鸿蒙获取 APP 信息及手机信息
前言:获取 APP 版本信息可以通过 bundleManager.getBundleInfoForSelfSync(bundleFlags) 去获取,获取手机信息可以通过 kit.BasicServicesKit 库去获取,以下是封装好的工具类。 import bundleManager from ohos.bundle.bundleManager; impo…...
OpenWRT下深入了解IPv6——SLAAC
一、SLAAC(无状态地址自动配置) 1.基本原理 SLAAC 是 IPv6 中的一种地址自动配置机制,它允许设备根据网络中的路由器通告信息和自身的 MAC 地址自动生成 IPv6 地址。在 IPv6 网络中,MAC 地址长度为 48 位,而 IPv6 地…...
UE5水文章 UI按钮样式快捷复制黏贴
shift右键拷贝 shift右键黏贴...
迭代器模式的理解和实践
引言 在软件开发中,我们经常需要遍历容器对象(如数组、列表、集合等)中的元素。如果每个容器对象都实现自己的遍历算法,那么代码将会变得冗余且难以维护。为了解决这个问题,迭代器模式应运而生。迭代器模式是一种行为型…...
Python __func 与 _func 的区别引起的思考
文章目录 __function_function深入名称修饰机制名称修饰的目的实现原理 属性访问控制的高级模式基本模式扩展复杂的转换和验证逻辑带有日志和审计的访问控制 如果突然让我说一说 Python中的__function和_function有哪些不同的约定和用途,我好像一下子没法说出很多东…...
python学opencv|读取视频(二)制作gif
【1】引言 前述已经完成了图像和视频的读取学习,本次课学习制作gif格式动图。 【2】教程 实际上想制作gif格式动图是一个顺理成章的操作,完成了图像和视频的处理,那就自然而然会对gif的处理也产生兴趣。 不过在opencv官网、matplotlib官网…...
Redmi AX3000 (RA81) 路由器恢复原厂固件
最近给Redmi AX3000 (RA81) 刷了OpenWrt固件,但是存在各种小问题,因此决定刷回原厂固件。刷机之前保证能够访问路由器ssh,否则请百度救砖教程。 准备工具 Redmi AX3000 (RA81) 原厂分区文件 [github下载地址 / csdn下载地址]小米路由器修复…...
【调试工具】USB 转 UART 适配器(USB 转 TTL)
「USB 转 TTL 转换器」是错误的叫法,正确的叫法应该为 「USB 转 UART 适配器」。 Device connection 注意端口的交叉连接,Device1_TX<---->Device2_RX USB-to-UART adapter GND 记得接地。 使用: 当 TX,RX 需要电平为 0-3.3V 时&am…...
【YOLO部署Android安卓手机APP】YOLOv11部署到安卓实时目标检测识别——以火焰烟雾目标检测识别举例(可自定义更换其他目标)
前言:本项目基于YOLOv11部署到手机APP实现对火焰烟雾的检测识别,当然,以此你可以按照本项目开发步骤扩展更换为其他目标进行检测,例如更换为车牌、手势、人脸面部活动、人脸表情、火焰烟雾、行人、口罩、行为、水果、植物、农作物等等部署手机APP进行检测。本文为详细设计/…...
Python 中的 __slots__ 属性有什么作用?
__slots__ 是Python类中的一种特殊属性,它允许你显式地声明一个类的实例可以拥有的属性。 这不仅有助于节省内存,还能提高属性访问的速度,并且防止动态添加不属于设计的属性。 在大型项目或者对性能敏感的应用程序中,正确使用 _…...
【H2O2|全栈】Node.js与MySQL连接
目录 前言 开篇语 准备工作 初始配置 创建连接池 操作数据库 封装方法 结束语 前言 开篇语 本节讲解如何使用Node.js实现与MySQL数据库的连接,并将该过程进行函数封装。 与基础部分的语法相比,ES6的语法进行了一些更加严谨的约束和优化&#…...
【大数据技术基础】 课程 第3章 Hadoop的安装和使用 大数据基础编程、实验和案例教程(第2版)
第3章 Hadoop的安装和使用 3.1 Hadoop简介 Hadoop是Apache软件基金会旗下的一个开源分布式计算平台,为用户提供了系统底层细节透明的分布式基础架构。Hadoop是基于Java语言开发的,具有很好的跨平台特性,并且可以部署在廉价的计算机集群中。H…...
DDR4与DDR3服务器内存的关键区别有哪些?
内存作为服务器性能的关键组件之一,已经经历了从DDR3到DDR4的过渡。DDR4内存相较于DDR3在多个方面有所提升,包括速度、带宽、功耗以及数据传输效率等。然而,尽管DDR4内存在性能上占有优势,DDR3内存依然在一些特定场景中得到了广泛…...
OceanBase 的探索与实践
作者:来自 vivo 互联网数据库团队- Xu Shaohui 本文总结了目前我们遇到的痛点问题并通过 OceanBase 的技术方案解决了这些痛点问题,完整的描述了 OceanBase 的实施落地,通过迁移到 OceanBase 实践案例中遇到的问题与解决方案让大家能更好的了…...