对抗攻击的详细解析:原理、方法与挑战

news2025/1/10 23:57:45

对抗攻击的详细解析:原理、方法与挑战

对抗攻击(Adversarial Attack)是现代机器学习模型,尤其是深度学习模型中的一个关键安全问题。其本质在于,通过对输入数据添加精微的扰动,人类难以察觉这些扰动,但它们会导致模型产生完全错误的预测。对抗攻击揭示了深度学习模型对数据中某些脆弱特征的过度依赖,表明模型并非如预期般鲁棒。
在这里插入图片描述

图片来源:AI安全-对抗攻击与防御_哔哩哔哩_bilibili

对抗攻击中的核心问题

在传统的机器学习任务中,训练集和测试集往往来自 相同的数据分布 P P P 。然而,对抗攻击通过在输入数据上引入极其微小的扰动,使得输入数据的分布发生了细微的改变。这种变化对于人类而言几乎无法感知,但对于模型,可能引发极大差异,甚至导致分类结果的完全错误。模型的这种脆弱性源自它们在高维特征空间中对某些输入特征的过度敏感性。

假设一个模型 f f f 是在分布 P P P 上训练的,并且输入 x x x 表示一张图片, f ( x ) f(x) f(x) 是模型对 x x x 的分类输出。对抗攻击试图找到一个微小的扰动 δ \delta δ,使得模型在输入 x + δ x + \delta x+δ 时输出错误的结果,即:

f ( x + δ ) ≠ f ( x ) f(x + \delta) \neq f(x) f(x+δ)=f(x)

尽管从视觉上, x x x x + δ x + \delta x+δ 对人类而言几乎完全相同,然而微小的扰动 δ \delta δ 可以使得模型的预测发生显著的变化。这就是对抗攻击问题的核心所在。

为什么对抗攻击能够成功?

对抗攻击之所以能够成功,是由于深度学习模型对输入特征的敏感性,这些特征往往在人类难以察觉的维度中发挥作用。神经网络通过非线性变换从输入数据中提取特征,每层网络的输出是前一层的非线性组合。当一个小的扰动 δ \delta δ 被添加到输入数据时,网络的激活值可能发生极大的变化,导致最终的分类结果出现显著的错误。这一现象可以用非线性特征空间中的放大效应来解释,即小的输入扰动在深度模型的高维空间中经过层层叠加和变换后,导致最终结果产生巨大差异。

对抗攻击的数学原理与常见方法

对抗攻击方法有多种实现,它们的核心都基于优化扰动 δ \delta δ 使模型输出错误结果。

对抗攻击发生在模型训练之后,主要在模型 推理阶段 进行。攻击者不调整模型的参数,而是针对一个已经训练好的模型,固定模型参数,通过修改输入来欺骗模型。此时,目标是 找到输入数据的敏感方向,沿着这个方向微调输入,让模型做出错误预测 。此时,使用的是梯度上升来增大输入数据的损失,而不是训练模型的参数。

以下是几种常见的对抗攻击方法及其数学原理:

1. Fast Gradient Sign Method (FGSM)

FGSM 是最早的对抗攻击方法之一,其目标是通过一次性施加扰动,沿着损失函数梯度上升的方向,使模型错误分类。其本质是找到损失函数最大变化的方向,并沿该方向施加固定大小的扰动。

在深度学习模型中,梯度 代表的是损失函数相对于输入的变化率。具体来说,梯度的方向是使损失增加最快的方向,而不是减少的方向。下面详细解释“敏感方向”这一概念,以及为什么梯度可以指示出这个方向。

梯度的作用

当我们提到梯度下降时,通常指的是在训练过程中更新模型参数(如权重和偏置)的算法,其目的是找到使损失函数下降最快的方向,以优化模型的预测性能。

然而,在对抗攻击中,我们并不是要降低损失,而是要增大损失,即让模型预测出错。因此,我们不再关心梯度下降的方向,而是关心梯度上升的方向,即使损失函数增加最快的方向。这个方向可以帮助我们找到输入空间中的一个“敏感方向”,即通过沿着这个方向添加微小的扰动,就可以导致模型的预测错误。

敏感方向的定义

对于某个输入图像 x x x,深度学习模型通过计算损失函数 L ( f ( x ) , y ) L(f(x), y) L(f(x),y) 来衡量模型的预测 f ( x ) f(x) f(x) 与真实标签 y y y 之间的差异。通过计算损失函数对输入 x x x 的梯度 ∇ x L ( f ( x ) , y ) \nabla_x L(f(x), y) xL(f(x),y),我们得到损失随着输入变化最快的方向。这个梯度可以理解为敏感方向,因为沿着这个方向加扰动会导致模型的输出发生最大变化。

简单来说:

  • 如果我们沿着梯度方向对输入图像施加扰动,即加上微小的噪声,这种微调将会放大模型的误差,使模型对输入的预测发生显著变化。
  • 因此,梯度方向表明了输入空间中模型最容易出错的方向,这就是我们所谓的“敏感方向”。
为什么梯度是“敏感方向”?

在 FGSM 这种攻击中,关键是通过梯度来找到对模型的预测影响最大的输入扰动:

  • 梯度 ∇ x L ( f ( x ) , y ) \nabla_x L(f(x), y) xL(f(x),y) 表示,当输入 x x x 沿着该方向变化时,损失函数增加得最快。
  • 由于深度学习模型通过复杂的非线性变换来提取输入的特征,因此对模型最敏感的特征往往对应于损失函数变化最大的方向。
  • 当我们沿着这个梯度方向施加扰动时,模型会更加倾向于犯错误,从而导致分类结果发生改变。

因此,梯度在这里指示了模型对输入的“敏感性”,并且告诉我们扰动在哪个方向上会最有效地干扰模型的预测。

具体步骤

给定一个深度学习模型 f ( x ) f(x) f(x),它可以预测输入图像 x x x 的类别。模型的损失函数 L ( f ( x ) , y ) L(f(x), y) L(f(x),y) 衡量了模型预测结果 f ( x ) f(x) f(x) 和真实标签 y y y 之间的差异。FGSM 利用损失函数对输入 x x x 的梯度来确定该图像的 敏感方向 ,即哪个方向最容易使模型犯错。

  1. 计算梯度:
    首先,我们计算损失函数 L ( f ( x ) , y ) L(f(x), y) L(f(x),y) 对输入图像 x x x 的梯度:
    ∇ x L ( f ( x ) , y ) \nabla_x L(f(x), y) xL(f(x),y)
    这个梯度代表损失函数在输入空间中增加最快的方向。

  2. 扰动生成:
    FGSM 沿着梯度方向加上符号(即正负方向),并且根据常数 ϵ \epsilon ϵ 来调整扰动的大小:
    x ′ = x + ϵ ⋅ sign ( ∇ x L ( f ( x ) , y ) ) x' = x + \epsilon \cdot \text{sign}(\nabla_x L(f(x), y)) x=x+ϵsign(xL(f(x),y))
    这里, ϵ \epsilon ϵ 是一个很小的正数,控制扰动的幅度。符号函数 sign ( ∇ x L ( f ( x ) , y ) ) \text{sign}(\nabla_x L(f(x), y)) sign(xL(f(x),y)) 仅保留梯度的方向,而忽略其幅度。

  3. 结果分析:
    对于人类来说,扰动后的图像 x ′ x' x 和原始图像 x x x 几乎没有可见差别。但由于模型高度依赖输入特征中的微小变化, x ′ x' x 很可能会被模型误分类。

关键特点
  • 效率: FGSM 只需一次梯度计算,因此它非常高效。
  • 局限性: FGSM 由于只进行一次扰动,不总是能够找到最强的对抗样本。

2. Projected Gradient Descent (PGD)

PGD 是 FGSM 的扩展版,其通过多次小步的梯度更新来逐步逼近对抗样本,是一种迭代攻击方法。PGD 的攻击效果比 FGSM 更强,因为它使用多次梯度更新来找到更具攻击性的扰动。

具体步骤

PGD 攻击基于多次迭代,每次计算损失函数的梯度并沿着该方向施加小幅度扰动,直到找到对模型最具攻击性的输入。

  1. 初始扰动:
    初始输入为原始图像 x 0 = x x^0 = x x0=x,并在后续步骤中不断更新。

  2. 迭代扰动更新:
    每次迭代计算当前输入 x t x^t xt 的梯度,并加上符号方向的扰动,更新规则为:
    x t + 1 = x t + α ⋅ sign ( ∇ x L ( f ( x t ) , y ) ) x^{t+1} = x^t + \alpha \cdot \text{sign}(\nabla_x L(f(x^t), y)) xt+1=xt+αsign(xL(f(xt),y))
    其中, α \alpha α 是步长大小,控制每次迭代中加入的扰动大小。

  3. 投影操作:
    为了确保最终生成的对抗样本 x ′ x' x 的扰动不超过预设范围(即 ϵ \epsilon ϵ),每次更新后的输入会被投影回原始输入 x x x ϵ \epsilon ϵ 范围内,即:
    x t + 1 = Proj B ( x , ϵ ) ( x t + 1 ) x^{t+1} = \text{Proj}_{B(x, \epsilon)}\left(x^{t+1}\right) xt+1=ProjB(x,ϵ)(xt+1)
    这个投影操作将当前的对抗样本约束在以 x x x 为中心、半径为 ϵ \epsilon ϵ 的球体内,保证最终的对抗样本不会偏离原始图像太远。

  4. 迭代停止:
    在经过多次迭代后(通常几十步),最终的对抗样本 x T x^{T} xT 通常会比一次性生成的 FGSM 对抗样本更具攻击性。

关键特点
  • 更强的攻击性: PGD 通过多次小步扰动逐渐逼近局部最优解,能够生成比 FGSM 更有效的对抗样本。
  • 灵活性: 通过调整步长 α \alpha α 和最大扰动 ϵ \epsilon ϵ,可以灵活控制攻击的强度和扰动的范围。

3. Carlini & Wagner (CW) 攻击

CW 攻击是基于优化的对抗攻击方法。与 FGSM 和 PGD 基于梯度符号生成扰动不同,CW 攻击通过解决一个优化问题来生成对抗样本,力求在最小的扰动下让模型分类出错。

具体步骤

CW 攻击将对抗样本生成视为一个优化问题,目标是在最小化扰动的同时最大化模型的分类错误。它常用 L 2 L_2 L2 范数作为约束条件,即希望生成的扰动 δ \delta δ 尽可能小。

  1. 优化目标:
    CW 攻击的优化目标是:
    min ⁡ δ ∥ δ ∥ p + c ⋅ L ( f ( x + δ ) , y ) \min_{\delta} \|\delta\|_p + c \cdot L(f(x + \delta), y) δminδp+cL(f(x+δ),y)
    其中, ∥ δ ∥ p \|\delta\|_p δp 是扰动的 p p p-范数,通常采用 L 2 L_2 L2 范数 ∥ δ ∥ 2 \|\delta\|_2 δ2,即最小化扰动的整体幅度。 c c c 是权衡因子,用于平衡扰动的大小和损失函数 L ( f ( x + δ ) , y ) L(f(x + \delta), y) L(f(x+δ),y) 的重要性。 L ( f ( x + δ ) , y ) L(f(x + \delta), y) L(f(x+δ),y) 是对抗样本的损失函数。

  2. 目标函数分解:
    CW 攻击将优化问题转化为两个部分:

    • 最小化扰动 δ \delta δ 的大小。
    • 最大化模型的损失函数,使得对抗样本 x + δ x + \delta x+δ 导致错误分类。
  3. 迭代优化:
    通过优化算法(如 Adam 优化器),CW 攻击会反复调整扰动 δ \delta δ,在每一步中平衡损失函数和扰动的大小,直到找到一个既能让模型出错、又保持扰动极小的对抗样本。

  4. 约束扰动:
    优化过程中,CW 攻击通过对 p p p-范数的约束来确保扰动不会过大,避免对抗样本与原始输入的视觉差异过于明显。

关键特点
  • 最小化扰动: CW 攻击通过优化算法生成最小扰动,同时保持高攻击成功率,往往能够生成极难察觉的对抗样本。
  • 灵活性: 可以选择不同的 p p p-范数(如 L 2 L_2 L2 L ∞ L_\infty L)来控制扰动的形式,并且权衡参数 c c c 可以调节攻击的强度。
  • 计算代价高: CW 攻击的优化过程复杂,计算开销较大,相较于 FGSM 和 PGD,它的攻击速度较慢。

总结

  • FGSM 是一种简单、高效的攻击方法,适合于快速生成对抗样本,但攻击强度有限。
  • PGD 通过迭代的方式逐步逼近最优的对抗样本,能够生成比 FGSM 更强的攻击,且灵活性更强。
  • CW 攻击 是基于优化问题的高级攻击方法,通过最小化扰动和最大化损失来精确生成对抗样本,虽然计算开销较大,但攻击效果显著。

通过这些方法,我们能够更加深入地理解深度学习模型对输入的敏感性,以及微小扰动如何在高维特征空间中被放大,最终导致分类错误。

深度神经网络如何做出决策?

要理解对抗攻击,首先需要了解深度神经网络是如何从输入中提取特征并做出决策的。一个典型的深度神经网络由多层非线性变换组成,输入数据经过每层处理后提取到不同层次的特征。最后,网络通过一个分类器(如 softmax)将提取到的特征映射为类别标签的概率分布。

h ( x ) h(x) h(x) 表示网络前几层的特征提取部分,分类器部分 g ( h ( x ) ) g(h(x)) g(h(x)) 则将特征映射到最终的类别概率:

f ( x ) = g ( h ( x ) ) f(x) = g(h(x)) f(x)=g(h(x))

当输入数据 x x x 中加入微小的扰动 δ \delta δ 时,网络中某些关键特征可能发生巨大变化。这种特征的变化往往集中在高维空间中的敏感方向上,这就是为什么微小的扰动能导致分类结果的重大偏差。

示例

通过一些具体的实例来更直观地理解对抗攻击。以下是几个与对抗攻击相关的实际应用案例,以及这些攻击如何影响模型的输出。

1. 对抗攻击在图像分类中的实例

在图像分类任务中,对抗攻击能够让看似无害的微小扰动对图像产生重大影响,从而导致深度学习模型错误分类。

实例 1:误导 MNIST 手写数字分类

MNIST 数据集是一个经典的手写数字分类任务,训练模型用于识别 0 到 9 之间的数字。假设模型能够准确分类原始的手写数字图像 x x x,将其正确分类为某个标签 y y y(例如“7”)。

然而,通过对图像添加微小的对抗性扰动 δ \delta δ,我们可以使原始的手写数字“7”被模型错误分类为“1”。例如,利用 FGSM 攻击方法,我们可以计算输入图像的梯度方向,并施加小量扰动来生成对抗样本。对于人类来说,生成的对抗样本看起来与原始图像几乎没有差别,图像仍然是清晰的“7”,但模型却会误将其分类为“1”或其他错误的类别。

如下所示:

  • 原始图像 x x x:是数字“7”。
  • 对抗性扰动后的图像 x + δ x + \delta x+δ:人眼看起来仍是“7”,但模型可能预测为“1”或“2”。

这种情况下,虽然图像看起来没有太大变化,但微小的像素差异已足以误导深度学习模型。

实例 2:误导 ImageNet 高级图像分类

ImageNet 是另一个广泛使用的图像分类数据集,它包含数百万张高分辨率图像,涉及 1000 个类别。在实际应用中,深度学习模型可以在这个数据集上实现高准确度。然而,通过对抗攻击,这些先进的模型也可以被轻易误导。

例如,假设我们有一张猫的图片,模型可以准确分类为“猫”。但通过施加微小的对抗性扰动 δ \delta δ,我们可以让模型将同一张猫的图片误分类为“汽车”或“金鱼”等完全不相关的类别。

  • 原始图像 x x x:猫。
  • 扰动后的对抗样本 x + δ x + \delta x+δ:人类眼中依然是猫,但模型预测为“金鱼”。

这个例子展示了深度学习模型对小扰动的极度敏感性,尽管扰动可能对人类几乎不可察觉。

2. 对抗攻击在自动驾驶中的实例

在自动驾驶领域,深度学习模型广泛用于物体检测和场景理解,例如识别道路标志和行人。对抗攻击在这一领域的应用可能会对安全性造成严重威胁。

实例 1:道路标志识别的对抗攻击

假设自动驾驶系统中使用的深度学习模型可以准确识别“停止”标志。然而,通过在道路标志上添加一些微小的对抗性扰动(例如,添加一些噪声或者在标志上贴上几块贴纸),系统可能无法识别该标志,甚至将其错误地分类为“限速 50”标志。

具体场景:

  • 原始图像 x x x:自动驾驶系统准确识别为“停止”标志。
  • 扰动后的标志 x + δ x + \delta x+δ:由于对抗性扰动的存在,系统将其错误地识别为“限速 50”标志。

对于人类驾驶员来说,这个“停止”标志看起来完全正常,但对抗性扰动使得自动驾驶系统的感知模型错误地将其识别为“限速 50”。这可能导致严重的安全事故,尤其是在城市交通场景中。

3. 对抗攻击在人脸识别中的实例

人脸识别技术已经广泛应用于安全认证、监控和身份识别系统。然而,对抗攻击也可以在这些应用中产生重大影响。

实例 1:误导人脸识别系统

假设一个深度学习人脸识别系统能够准确地识别人脸并进行身份认证。通过对抗性攻击者可以生成一个对抗性样本,使得人脸识别系统无法正确识别某个人,甚至将攻击者的人脸识别为另一名用户。

场景描述:

  • 原始图像 x x x:模型可以准确地将某人的脸识别为用户 A。
  • 扰动后的图像 x + δ x + \delta x+δ:经过对抗性扰动后,攻击者的人脸被系统错误识别为用户 B。

这种对抗攻击不仅会影响身份验证,还可能被用于逃避监控系统的检测,攻击者通过对抗样本可能轻松地躲过自动化监控系统的识别。

4. 对抗攻击在语音识别中的实例

除了图像分类和人脸识别,语音识别系统也可以被对抗攻击破坏。语音识别被广泛应用于语音助手、语音控制系统以及实时翻译中。对抗攻击同样可以通过微小的语音扰动来误导这些系统。

实例 1:误导语音助手(如 Siri、Alexa)

假设一个语音识别模型能够准确识别用户的命令,如“播放音乐”。通过添加对抗性扰动,攻击者可以生成一种微小的噪声,这种噪声对人类几乎听不到,但可以让语音助手错误地执行命令。

场景描述:

  • 原始音频 x x x:用户说“播放音乐”,语音助手正确执行命令。
  • 扰动后的音频 x + δ x + \delta x+δ:经过对抗性攻击后,语音助手错误地识别命令为“拨打紧急电话”。

在这一攻击场景中,攻击者通过对抗性扰动,可以让语音助手误解原始命令并执行潜在危险的操作,这对智能设备的安全性提出了极大的挑战。

对抗攻击对深度学习的挑战

对抗攻击揭示了深度学习模型在高维空间中提取脆弱特征的局限性。虽然这些特征在训练集和测试集分布相同的情况下表现良好,但在面对扰动或异常输入时,模型的表现会急剧恶化。这对实际应用中机器学习系统的安全性和鲁棒性提出了严峻的挑战,尤其是在自动驾驶、医疗诊断等高风险领域。

对抗攻击的防御成为了当前研究的热点领域,包括对抗训练、输入预处理以及模型架构的改进等手段,均试图增强模型对这些精微扰动的鲁棒性。然而,这些防御手段尚未能彻底解决对抗攻击的威胁,攻防对抗仍在持续演变。

总结

对抗攻击通过对输入数据施加人类不可察觉的微小扰动,使深度学习模型的预测结果发生显著变化。常见的对抗攻击方法如 FGSM、PGD 和 CW,均通过不同的数学手段生成对抗样本,揭示了深度学习模型对输入数据中的脆弱特征的依赖性。要提升模型的鲁棒性,需要从模型设计、训练过程以及输入数据预处理中采取综合措施。

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

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

相关文章

教你一招:在微信小程序中为用户上传的图片添加时间水印

在微信小程序开发过程中,我们常常需要在图片上添加水印,以保护版权或增加个性化元素。本文将为大家介绍如何在微信小程序中为图片添加时间水印,让你的小程序更具特色。 实现步骤: 1. 创建页面结构 在pages目录下创建一个名为upl…

使用思科搭建企业网规划训练,让网络全部互通,使用规则提高工作效率。

1. 企业背景: 某企业分为销售部、行政部、人力资源部、财务部、业务部、接待中心等主要六个部门;配置网管中心,允许网络管理员登录企业交换机和路由器对企业网络进行管理;配置服务器集群,设置FTP、DNS、WEB服务器&am…

一个基于 Tauri、Vite 5、Vue 3 和 TypeScript 构建的即时通讯系统,牛啊牛啊!(附源码)

这段时间正在学习桌面端开发,目前了解了Electron和Tauri,在搜索教程的时候发现了一位大佬用Tauri开发了个即时通讯的软件,并且技术栈用的也是VUE3和TypeScript,所以今天就给大家分享一下这个项目——HuLa HuLa HuLa 是一个基于 Tauri、Vite …

Skyeye 云智能制造 v3.14.6 发布,ERP 商城

Skyeye 云智能制造,采用 Springboot winUI 的低代码平台、移动端采用 UNI-APP。包含 30 多个应用模块、50 多种电子流程,CRM、PM、ERP、MES、ADM、EHR、笔记、知识库、项目、门店、商城、财务、多班次考勤、薪资、招聘、云售后、论坛、公告、问卷、报表…

【Elasticsearch系列廿一】ES7 SQL 新特性

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

嵌入式设备网口down后再up时不能link?

🏆本文收录于《CSDN问答解惑-专业版》专栏,主要记录项目实战过程中的Bug之前因后果及提供真实有效的解决方案,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收…

[ComfyUI]又降了,只需10G显存玩转CogVideoX5B图生视频,效果太惊艳!

在数字艺术和创意领域,[ComfyUI]一直致力于为用户提供最优质的技术和工具。今天,我们激动地宣布,[ComfyUI]再次取得重大突破——只需10G显存,用户就能轻松玩转CogVideoX5B图生视频,创造出令人惊艳的效果! …

【人工智能】在大型活动中的应用案例

人工智能在娱乐大型活动中的应用 ## 作者主页: 知孤云出岫 目录 **人工智能在娱乐大型活动中的应用****1. 引言****2. 智能票务与入场管理****2.1 动态定价与票务预测****2.2 生物识别技术快速入场****2.3 区块链技术防伪票务管理** **3. 智能观众互动与个性化体验****3.1 个性…

Java语言程序设计基础篇_编程练习题**18.35(H 树分形)

目录 题目:**18.35(H 树分形) 代码示例 代码解释 输出结果 题目:**18.35(H 树分形) 一个H 树分形(本章开始部分介绍过,如图18-1)如下定义: 1)从字母H开始。H的三条线长度一样,如图 18-1a 所示。 2)字母H(以它的 sans-serif …

归并算法实现

1.归并算法图解 2.归并算法代码 package com.suanfa.sort;import java.util.Arrays;/*** 归并算法*/ public class MergeSort {/*** 拆的时间复杂度logn * 并的时间复杂度n nlogn** param arr* param left* param right*/public static void sortMerge(int[] arr, int left, …

第十一章 从0-1搭建一个简单的JavaWeb系统(三)

目录 一、工程代码结构 二、代码实现 三、运行效果 四、未完待续 本章节的每一段代码,建议全部自己敲一遍,加深印象,切勿直接复制黏贴。 一、工程代码结构 本章节实现注销(退出)功能,以下图片中标红的…

19个邮件群发小技巧,最大水平充分利用邮件营销

邮件群发在现代通信中占据着非常重要的位置。无论是在商业环境还是个人生活中,它都有着广泛的应用。无论您是公司的市场推广专家,还是社交团体的筹办者,掌握有效的邮件群发技巧会帮助您更好地传递信息、节约时间和提升工作效率。 确定目标受众…

【Ubuntu】Ubuntu安装编译C/C++环境简易版教程

环境 操作系统:ubuntu-22.04.4-desktop-amd64.iso 安装 第一步:更新软件包列表,检查可用的软件包更新 sudo apt update在这一步,我们可以确保系统中的软件包列表是最新的,以便后续的软件包管理操作。 第二步:安装…

craco-less使用问题

craco-less使用问题 问题背景 前端是用React搭建,使用craco配置,相关库或插件版本如下 "craco/craco": "^7.1.0","react-scripts": "^5.0.1","craco-less": "^3.0.1"在生产环境&#xff…

JAVA开源项目 甘肃非物质文化网站 计算机毕业设计

本文项目编号 T 043 ,文末自助获取源码 \color{red}{T043,文末自助获取源码} T043,文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析 六、核心代码6.1 查…

【无人机设计与控制】基于蜣螂优化算法求解多无人机集群路径规划问题

摘要 本文基于蜣螂优化算法(Dung Beetle Optimization, DBO)研究了多无人机路径规划问题。目标是优化多无人机的飞行轨迹,在避免障碍物的同时,尽量减少能量消耗并保持集群内的通信。为提高搜索效率和准确性,对DBO进行…

AJAX 入门 day3 XMLHttpRequest、Promise对象、自己封装简单版的axios

目录 1.XMLHttpRequest 1.1 XMLHttpRequest认识 1.2 用ajax发送请求 1.3 案例 1.4 XMLHttpRequest - 查询参数 1.5 XMLHttpRequest - 数据提交 2.Promise 2.1 Promise认识 2.2 Promise - 三种状态 2.3 案例 3.封装简易版 axios 3.1 封装_简易axios_获取省份列表 3…

Spring Boot 中实现任务后台处理的几种常见方式

​ 博客主页: 南来_北往 系列专栏:Spring Boot实战 前言 在现代应用程序中,后台处理对于处理发送电子邮件、处理文件、生成报告等任务至关重要。 Spring Boot 提供了多种机制来高效地实现后台任务。本文探讨了在 Spring Boot 中处理后台处理的各…

STM32调试TIC12400笔记

工作中需要用到,但是有关这个芯片的参考资料好少,自己写一下调试过程,持续更新中,还没调完。 用的是正点原子的mini板,芯片是stm32f103RCT,需要知道spi的相关知识,先配置spi,用cube…

Ubuntu初期配置常见问题汇总

ubuntu配置vim 代码配色 终端配置 ubuntu配置vim 代码配色 终端配置_ubuntu的vim配置-CSDN博客https://blog.csdn.net/GM2418/article/details/134195020小缺点是无法自动补齐 ubuntu中vim实现代码补全等功能_ubuntu vim 自动补全-CSDN博客https://blog.csdn.net/weixin_4580…