17_HTML5 Web 存储 --[HTML5 API 学习之旅]
HTML5 Web 存储(Web Storage)是 HTML5 引入的一种在用户浏览器中存储数据的机制。它提供了比传统的 cookies 更加方便和强大的功能,包括更大的存储空间、更好的性能以及更简单的 API。Web 存储主要分为两种类型:localStorage
和 sessionStorage
。
1. localStorage
- 持久性:数据不会过期,除非被明确删除或用户清空浏览器缓存。
- 适用场景:适合存储不需要立即发送到服务器的数据,例如用户的偏好设置、购物车内容等。
- API 方法:
setItem(key, value)
:存储数据项。getItem(key)
:获取指定键的数据项。removeItem(key)
:移除指定键的数据项。clear()
:清除所有数据项。key(index)
:返回指定索引位置的键名。
示例代码
// 设置一个名为 'username' 的键值对
localStorage.setItem('username', '张三');// 获取并打印 'username' 的值
console.log(localStorage.getItem('username')); // 输出: 张三// 更新 'username' 的值
localStorage.setItem('username', '李四');
console.log(localStorage.getItem('username')); // 输出: 李四// 删除 'username' 键值对
localStorage.removeItem('username');
console.log(localStorage.getItem('username')); // 输出: null// 清除所有数据项
localStorage.clear();
下面提供了五个使用 localStorage
的 HTML5 Web 存储示例。这些例子展示了如何在不同的场景中利用 localStorage
来存储和检索数据,从而提升用户体验或实现特定功能。
示例 1: 存储用户偏好设置
在这个例子中,我们将用户的主题颜色偏好存储在 localStorage
中,并在页面加载时应用这些设置。
<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><title>用户偏好设置</title><style id="themeStyle"></style><script>function setTheme(color) {localStorage.setItem('themeColor', color);document.getElementById('themeStyle').innerHTML = `body { background-color: ${color}; }`;}window.onload = function() {const savedTheme = localStorage.getItem('themeColor');if (savedTheme) {setTheme(savedTheme);}};</script>
</head>
<body><button onclick="setTheme('lightblue')">浅蓝色主题</button><button onclick="setTheme('lightgreen')">浅绿色主题</button><button onclick="setTheme('white')">白色主题</button>
</body>
</html>
示例 2: 记录用户访问次数
这里我们使用 localStorage
来记录用户访问网站的次数,并在每次访问时更新计数器。
<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><title>访问次数统计</title><script>window.onload = function() {let visits = localStorage.getItem('visits') || 0;visits++;localStorage.setItem('visits', visits);document.getElementById('visitCount').innerText = `您已经访问了 ${visits} 次本页面。`;};</script>
</head>
<body><p id="visitCount"></p>
</body>
</html>
示例 3: 购物车功能
在这个例子中,我们将购物车中的商品信息存储在 localStorage
中,以便用户可以在不同会话之间保持其选择的商品。
<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><title>购物车</title><script>/*** 将商品添加到购物车。* * @param {string} item - 要添加的商品名称。*/function addToCart(item) {// 从 localStorage 中获取名为 'cart' 的项,并尝试将其解析为 JSON 数组。// 如果该项不存在或为空,则初始化为一个空数组。let cart = JSON.parse(localStorage.getItem('cart')) || [];// 将新商品添加到购物车数组中。cart.push(item);// 将更新后的购物车数组转换回 JSON 字符串,并保存到 localStorage 中。localStorage.setItem('cart', JSON.stringify(cart));// 弹出提示框,告知用户商品已成功添加到购物车。alert(`${item} 已添加到购物车`);}/*** 查看当前购物车的内容。*/function viewCart() {// 从 localStorage 中获取名为 'cart' 的项,并尝试将其解析为 JSON 数组。// 如果该项不存在或为空,则初始化为一个空数组。let cart = JSON.parse(localStorage.getItem('cart')) || [];// 使用 Array.prototype.join 方法将购物车中的所有商品以逗号分隔连接成一个字符串,// 然后通过 alert 弹窗向用户展示这些商品。// 如果购物车为空,则只会显示“购物车内容: ”。alert(`购物车内容: ${cart.join(', ')}`);}</script>
</head>
<body><!-- 添加商品按钮 --><button onclick="addToCart('苹果')">添加苹果</button><button onclick="addToCart('香蕉')">添加香蕉</button><!-- 查看购物车按钮 --><button onclick="viewCart()">查看购物车</button>
</body>
</html>
示例 4: 表单自动填充
当用户填写表单后,我们可以将表单数据保存到 localStorage
,并在用户返回页面时自动填充这些数据。
<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><title>表单自动填充</title><script>// 当页面完全加载完毕后执行以下函数window.onload = function() {// 获取表单中的姓名和邮箱输入框元素const nameInput = document.getElementById('name');const emailInput = document.getElementById('email');// 从 localStorage 中恢复之前保存的姓名和邮箱值(如果存在)nameInput.value = localStorage.getItem('name') || ''; // 如果没有保存的值,则设置为空字符串emailInput.value = localStorage.getItem('email') || ''; // 如果没有保存的值,则设置为空字符串// 监听姓名输入框的变化事件,当用户输入时实时保存到 localStoragenameInput.oninput = function() {localStorage.setItem('name', this.value); // 将当前输入框的值保存到 'name' 键中};// 监听邮箱输入框的变化事件,当用户输入时实时保存到 localStorageemailInput.oninput = function() {localStorage.setItem('email', this.value); // 将当前输入框的值保存到 'email' 键中};};</script>
</head>
<body><!-- 表单元素 --><form><!-- 姓名输入框 --><label for="name">姓名:</label><input type="text" id="name" name="name"><br><br><!-- 邮箱输入框 --><label for="email">邮箱:</label><input type="email" id="email" name="email"><br><br><!-- 提交按钮 --><input type="submit" value="提交"></form>
</body>
</html>
示例 5: 简单的任务列表
这个例子展示了一个简单的任务列表应用程序,允许用户添加、删除任务,并且任务会在浏览器关闭后仍然存在。
<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><title>任务列表</title><script>/*** 加载任务列表* 从localStorage中获取任务列表数据,并添加到页面上的任务列表中*/function loadTasks() {const taskList = document.getElementById('taskList');const tasks = JSON.parse(localStorage.getItem('tasks')) || [];tasks.forEach(task => {const li = document.createElement('li');li.textContent = task;taskList.appendChild(li);});}/*** 添加任务* 获取输入框中的任务描述,将其添加到任务列表中,并保存到localStorage中*/function addTask() {const taskInput = document.getElementById('newTask');const taskText = taskInput.value.trim();if (taskText !== '') {const tasks = JSON.parse(localStorage.getItem('tasks')) || [];tasks.push(taskText);localStorage.setItem('tasks', JSON.stringify(tasks));// 创建一个新的li元素const li = document.createElement('li');// 设置li元素的文本内容为任务文本li.textContent = taskText;// 将新的li元素添加到任务列表中document.getElementById('taskList').appendChild(li);taskInput.value = '';}}/*** 清除所有任务* 从localStorage中移除任务列表数据,并清空页面上的任务列表*/function clearTasks() {localStorage.removeItem('tasks');document.getElementById('taskList').innerHTML = '';}// 页面加载时自动调用loadTasks函数window.onload = loadTasks;</script>
</head>
<body><h2>我的任务列表</h2><input type="text" id="newTask" placeholder="输入新任务..."><button onclick="addTask()">添加任务</button><button onclick="clearTasks()">清除所有任务</button><ul id="taskList"></ul>
</body>
</html>
这些示例展示了 localStorage
在各种实际应用场景中的使用方式,包括但不限于存储用户偏好、统计访问次数、实现购物车功能、自动填充表单以及创建持久化的任务列表。通过合理利用 localStorage
,可以显著提高 Web 应用的功能性和用户体验。
2. sessionStorage
- 会话性:数据仅在当前会话期间有效(即同一个浏览器标签页),关闭页面或标签后数据会被清除。
- 适用场景:适合临时存储与单个会话相关的数据,如表单数据、临时状态信息等。
- API 方法:与
localStorage
相同。
示例代码
// 设置一个名为 'sessionData' 的键值对
sessionStorage.setItem('sessionData', '会话数据');// 获取并打印 'sessionData' 的值
console.log(sessionStorage.getItem('sessionData')); // 输出: 会话数据// 关闭页面或标签后,再打开新的页面或标签,尝试获取 'sessionData'
console.log(sessionStorage.getItem('sessionData')); // 输出: null (因为会话已结束)
当然,下面是两个使用 sessionStorage
的 HTML5 Web 存储示例。这些例子展示了如何在不同的场景中利用 sessionStorage
来存储和检索数据,从而提升用户体验或实现特定功能。
示例 1: 表单数据保存
在这个例子中,我们将表单中的用户输入临时保存到 sessionStorage
中。如果用户刷新页面或在同一个浏览器标签页中导航离开再返回,表单数据将自动恢复。但是一旦关闭了该标签页,所有数据都会被清除。
<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><title>表单数据保存</title><script>window.onload = function() {// 恢复表单数据(如果存在)const nameInput = document.getElementById('name');const emailInput = document.getElementById('email');nameInput.value = sessionStorage.getItem('name') || '';emailInput.value = sessionStorage.getItem('email') || '';// 监听表单输入事件,实时保存数据到 sessionStoragenameInput.oninput = function() {sessionStorage.setItem('name', this.value);};emailInput.oninput = function() {sessionStorage.setItem('email', this.value);};};</script>
</head>
<body><form><label for="name">姓名:</label><input type="text" id="name" name="name"><br><br><label for="email">邮箱:</label><input type="email" id="email" name="email"><br><br><input type="submit" value="提交"></form>
</body>
</html>
解释:
window.onload
:当页面加载时,尝试从sessionStorage
恢复表单数据。oninput
事件监听器:每当用户在输入框中输入内容时,立即将最新的值保存到sessionStorage
。
示例 2: 记录会话中的浏览历史
在这个例子中,我们记录用户在同一会话期间访问过的页面,并通过一个简单的列表展示出来。一旦用户关闭当前浏览器标签页,所有记录的数据都将被清除。
<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><title>浏览历史记录</title><script>// 页面加载完成后执行的函数window.onload = function() {// 更新浏览历史updateHistory(window.location.href);// 显示浏览历史displayHistory();};/*** 更新浏览历史的函数* @param {string} url 当前页面的URL*/function updateHistory(url) {// 从sessionStorage获取历史记录,如果不存在则初始化为数组let history = JSON.parse(sessionStorage.getItem('history')) || [];// 如果历史记录中不包含当前URL,则添加到历史记录中if (!history.includes(url)) {history.push(url);// 将更新后的历史记录保存到sessionStoragesessionStorage.setItem('history', JSON.stringify(history));}}/*** 显示浏览历史的函数*/function displayHistory() {// 从sessionStorage获取历史记录,如果不存在则初始化为数组let history = JSON.parse(sessionStorage.getItem('history')) || [];// 获取页面上的历史记录列表元素const historyList = document.getElementById('historyList');// 清空现有列表historyList.innerHTML = '';// 遍历历史记录,创建并添加到列表中history.forEach(function(url, index) {const li = document.createElement('li');li.textContent = `第 ${index + 1} 次访问: ${url}`;historyList.appendChild(li);});}</script>
</head>
<body><h2>浏览历史记录</h2><ul id="historyList"></ul>
</body>
</html>
解释:
updateHistory(url)
:每次页面加载时调用此函数,将当前页面 URL 添加到sessionStorage
中的浏览历史数组里(避免重复添加)。displayHistory()
:从sessionStorage
中读取浏览历史,并将其显示在一个无序列表 (<ul>
) 中。window.onload
:当页面加载时,更新并显示浏览历史。
这两个示例展示了 sessionStorage
在不同应用场景中的使用方式,包括但不限于保存表单数据以防止意外丢失以及记录用户的浏览行为。由于 sessionStorage
数据仅在当前会话期间有效,因此非常适合处理与单个浏览会话相关联的信息。
Web 存储的特点
HTML5 Web 存储(Web Storage)提供了两种在用户浏览器中存储数据的方式:localStorage
和 sessionStorage
。它们具有以下特点,这些特点使得 Web 存储成为一种强大且灵活的客户端数据管理工具。
1. 持久性和会话性
-
localStorage
:- 数据是持久性的,除非被明确删除或用户清空浏览器缓存,否则数据不会过期。
- 适合存储不需要立即发送到服务器的数据,例如用户的偏好设置、购物车内容等。
-
sessionStorage
:- 数据仅在当前会话期间有效(即同一个浏览器标签页),关闭页面或标签后数据会被清除。
- 适合临时存储与单个会话相关的数据,如表单数据、临时状态信息等。
2. 容量较大
- 每个域名通常可以存储大约 5MB 的数据(具体取决于浏览器实现)。这比传统的 cookies 提供了更多的空间来存储数据。
3. 同步操作
- 所有的读写操作都是同步的,这意味着它们会阻塞 JavaScript 执行,直到操作完成。不过,对于大多数应用场景来说,这种延迟是可以接受的,因为 Web 存储的操作速度非常快。
4. 只支持字符串
- Web 存储只能保存字符串格式的数据。如果要存储复杂的数据结构(如对象或数组),需要先使用
JSON.stringify()
方法将其转换为字符串,读取时再用JSON.parse()
方法解析回来。
5. 简单的 API
- 提供了一组简单易用的方法来进行数据的存取和管理,包括:
setItem(key, value)
:存储数据项。getItem(key)
:获取指定键的数据项。removeItem(key)
:移除指定键的数据项。clear()
:清除所有数据项。key(index)
:返回指定索引位置的键名。
6. 事件驱动
- 支持
storage
事件,当同一域下的其他窗口或标签页中的 Web 存储发生改变时触发。这可以用来实现跨窗口或标签页之间的通信。
7. 安全性考虑
- 数据是明文存储在客户端的,因此不适合用于敏感信息的存储,除非采取额外的安全措施(如加密)。
- Web 存储的数据是基于同源策略的,即只有相同协议、主机名和端口的页面才能访问同一存储区域的数据。
8. 离线功能
- 可以用来存储应用程序状态或用户生成的内容,即使在网络连接不可用的情况下也能提供一定程度的功能和服务。
9. 性能优势
- 相较于 cookies,Web 存储不会随每个 HTTP 请求一起发送到服务器,从而减少了不必要的网络流量,提高了性能。
使用场景示例
- 用户偏好设置:可以将用户的界面偏好(如主题颜色、字体大小等)存储在
localStorage
中,以便下次访问时自动应用这些设置。 - 离线存储:允许用户在网络连接不可用的情况下浏览网站,并在网络恢复后再提交交互数据。
- 跨页面通信:通过监听
storage
事件,可以在同一域下的不同标签页之间共享和同步数据变化。
总之,HTML5 Web 存储提供了一种简单而有效的方式来管理和持久化客户端数据,增强了 Web 应用的功能性和用户体验。它不仅简化了开发流程,还为开发者提供了更多的灵活性来处理不同类型的数据需求。
测试代码下载
html5_api代码
相关文章:

17_HTML5 Web 存储 --[HTML5 API 学习之旅]
HTML5 Web 存储(Web Storage)是 HTML5 引入的一种在用户浏览器中存储数据的机制。它提供了比传统的 cookies 更加方便和强大的功能,包括更大的存储空间、更好的性能以及更简单的 API。Web 存储主要分为两种类型:localStorage 和 s…...

GCP Cloud Architect exam - PASS
备考指南 推荐视频课程 https://www.udemy.com/course/google-cloud-architect-certifications/?couponCodeKEEPLEARNING 推荐题库 https://www.udemy.com/course/gcp-professional-cloud-architect-exam-practice-tests-2024/?couponCodeKEEPLEARNING 错题集 http…...

【Sentinel】初识Sentinel
目录 1.1.雪崩问题及解决方案 1.1.1.雪崩问题 1.1.2.超时处理 1.1.3.仓壁模式 1.1.4.断路器 1.1.5.限流 1.1.6.总结 1.2.服务保护技术对比 1.3.Sentinel介绍和安装 1.3.1.初识Sentinel 1.3.2.安装Sentinel 1.4.微服务整合Sentinel 1.1.雪崩问题及解决方案 1.1.1.…...

java常见类库
StringBuffer类 String和StringBuffer的区别 String 不可变性:String 类是不可变的,这意味着一旦创建了一个 String 对象,其值就不能改变。每次对 String 进行修改(如连接、替换等操作)都会产生新的 String 对象&…...

Wordly Wise 3000 国际背单词01 介绍 + 测词汇量
📚 Wordly Wise 3000 国际背单词01 介绍 测词汇量 🌟 大家好!我们正式启动背Wordly Wise 3000单词,旨在利用国际资源和科学的学练方法,帮助大家更得效地坚持学练单词。我们将通过图文和Video等多种形式与大家分享经验…...
Unity Dots理论学习-2.ECS有关的模块(1)
Unity的实体组件系统(ECS)是支撑DOTS模块和技术的面向数据架构。ECS为Unity中的内存数据和runtime进程调度提供了高度的控制和确定性。 ECS for Unity 2022 LTS 配备了两个兼容的物理引擎,一个高级的Netcode package,以及一个用来…...

2021.12.28基于UDP同信的相关流程
作业 1、将TCP的CS模型再敲一遍 服务器 #include <myhead.h> #define PORT 8888 #define IP "192.168.124.123" int main(int argc, const char *argv[]) {//创建套接字//绑定本机IP和端口号//监听客户端请求//接收客户端连接请求//收发消息//创建套接字int…...

使用 Docker 搭建 Hadoop 集群
1.1. 启用 WSL 与虚拟机平台 1.1.1. 启用功能 启用 WSL并使用 Moba 连接-CSDN博客 1.2 安装 Docker Desktop 最新版本链接:Docker Desktop: The #1 Containerization Tool for Developers | Docker 指定版本链接:Docker Desktop release notes | Do…...

optuna和 lightgbm
文章目录 optuna使用1.导入相关包2.定义模型可选参数3.定义训练代码和评估代码4.定义目标函数5.运行程序6.可视化7.超参数的重要性8.查看相关信息9.可视化的一个完整示例10.lightgbm实验 optuna使用 1.导入相关包 import torch import torch.nn as nn import torch.nn.functi…...

Android 设置铃声和闹钟
Android设置铃声和闹钟使用的方法是一样的,但是要区别的去获取对应的权限。 统一权限,不管是设置闹钟还是铃声,他们都需要一个系统设置权限如下: //高版本需要WRITE_SETTINGS权限//此权限是敏感权限,无法动态申请,需要…...

自动化测试模型(一)
8.8.1 自动化测试模型概述 在自动化测试运用于测试工作的过程中,测试人员根据不同自动化测试工具、测试框架等所进行的测试活动进行了抽象,总结出线性测试、模块化驱动测试、数据驱动测试和关键字驱动测试这4种自动化测试模型。 线性测试 首先&#…...

解决nuxt3下载慢下载报错问题
在下载nuxt3时总是下不下来,最后还报错了。即使改成国内镜像源也不行。 解决方法: 直接去github上下载 https://github.com/nuxt/starter/tree/v3 解压后得到如下目录: 手动修改项目名和文件夹名 安装依赖 npm install可能会比较慢或下不…...
Ubuntu修改swap大小
查看swap位置和大小: swapon -s 方案一:修改原有文件大小方式 第一步:进入系统根目录cd /; 第二步:执行:sudo dd if/dev/zero of/swap bs1M count16384 //每段块1M 共16384块,即16G 第三步:执行…...

[C#] 复数乘法的跨平台SIMD硬件加速向量算法(不仅支持X86的Sse、Avx、Avx512,还支持Arm的AdvSimd)
文章目录 一、简单算法二、向量算法2.1 算法思路2.1.1 复数乘法的数学定义2.1.2 复数的数据布局2.1.3 第1步:计算 (a*c) (-b*d)i2.1.4 第2步:计算 (a*d) (b*c)i2.1.5 第3步:计算结果合并 2.2 算法实现(UseVectors)2.…...

C#WPF基础介绍/第一个WPF程序
什么是WPF WPF(Windows Presentation Foundation)是微软公司推出的一种用于创建窗口应用程序的界面框架。它是.NET Framework的一部分,提供了一套先进的用户界面设计工具和功能,可以实现丰富的图形、动画和多媒体效果。 WPF 使用…...

强大的接口测试可视化工具:Postman Flows
Postman Flows是一种接口测试可视化工具,可以使用流的形式在Postman工作台将请求接口、数据处理和创建实际流程整合到一起。如下图所示 Postman Flows是以API为中心的可视化应用程序开发界面。它提供了一个无限的画布用于编排和串连API,数据可视化来显示…...
系统设计及解决方案
发送验证码 1:根据手机号从Redis中获取value(验证码_时间戳) 2:如果value不为空,并且时间戳与当前时间戳的间隔小于60秒,则返回一个错误信息 3:生成随机验证码 4:调用阿里云短信服务API给用户发送短信验证码…...

从0入门自主空中机器人-2-2【无人机硬件选型-PX4篇】
1. 常用资料以及官方网站 无人机飞控PX4用户使用手册(无人机基本设置、地面站使用教程、软硬件搭建等):https://docs.px4.io/main/en/ PX4固件开源地址:https://github.com/PX4/PX4-Autopilot 飞控硬件、数传模块、GPS、分电板等…...

Linux之ARM(MX6U)裸机篇----2.汇编LED驱动实验
一,alpha的LED灯硬件原理分析 STM32 IO初始化流程 ①,使能GPIO时钟 ②,设置IO复用,复用为GPIO ③,配置GPIO的电气属性推挽,上拉下拉 ④,使用GPIO,输出高/低电平 MX6ULL IO初始化…...

e3 1220lv3 cpu-z分数
e3 1220lv3 双核四线程,1.1G频率,最低可在800MHZ运行,TDP 13W。 使用PE启动后测试cpu-z分数。 现在e3 1220lv3的价格落到69元。...
Android Wi-Fi 连接失败日志分析
1. Android wifi 关键日志总结 (1) Wi-Fi 断开 (CTRL-EVENT-DISCONNECTED reason3) 日志相关部分: 06-05 10:48:40.987 943 943 I wpa_supplicant: wlan0: CTRL-EVENT-DISCONNECTED bssid44:9b:c1:57:a8:90 reason3 locally_generated1解析: CTR…...

使用VSCode开发Django指南
使用VSCode开发Django指南 一、概述 Django 是一个高级 Python 框架,专为快速、安全和可扩展的 Web 开发而设计。Django 包含对 URL 路由、页面模板和数据处理的丰富支持。 本文将创建一个简单的 Django 应用,其中包含三个使用通用基本模板的页面。在此…...
反向工程与模型迁移:打造未来商品详情API的可持续创新体系
在电商行业蓬勃发展的当下,商品详情API作为连接电商平台与开发者、商家及用户的关键纽带,其重要性日益凸显。传统商品详情API主要聚焦于商品基本信息(如名称、价格、库存等)的获取与展示,已难以满足市场对个性化、智能…...

安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件
在选煤厂、化工厂、钢铁厂等过程生产型企业,其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进,需提前预防假检、错检、漏检,推动智慧生产运维系统数据的流动和现场赋能应用。同时,…...
【SpringBoot】100、SpringBoot中使用自定义注解+AOP实现参数自动解密
在实际项目中,用户注册、登录、修改密码等操作,都涉及到参数传输安全问题。所以我们需要在前端对账户、密码等敏感信息加密传输,在后端接收到数据后能自动解密。 1、引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId...

UDP(Echoserver)
网络命令 Ping 命令 检测网络是否连通 使用方法: ping -c 次数 网址ping -c 3 www.baidu.comnetstat 命令 netstat 是一个用来查看网络状态的重要工具. 语法:netstat [选项] 功能:查看网络状态 常用选项: n 拒绝显示别名&#…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...
Robots.txt 文件
什么是robots.txt? robots.txt 是一个位于网站根目录下的文本文件(如:https://example.com/robots.txt),它用于指导网络爬虫(如搜索引擎的蜘蛛程序)如何抓取该网站的内容。这个文件遵循 Robots…...
Linux离线(zip方式)安装docker
目录 基础信息操作系统信息docker信息 安装实例安装步骤示例 遇到的问题问题1:修改默认工作路径启动失败问题2 找不到对应组 基础信息 操作系统信息 OS版本:CentOS 7 64位 内核版本:3.10.0 相关命令: uname -rcat /etc/os-rele…...

云原生安全实战:API网关Kong的鉴权与限流详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关(API Gateway) API网关是微服务架构中的核心组件,负责统一管理所有API的流量入口。它像一座…...