通过混合机器学习和 TOPSIS 实现智能手机身份验证的稳健行为生物识别框架
1. 简介
随着日常工作、个人生活和金融操作对智能手机的依赖性不断增强,对弹性安全身份验证系统的需求也日益增长。尽管 PIN 码、密码和静态生物识别等传统身份验证方法仍可为系统提供一定的安全级别,但事实证明,它们容易受到多种威胁,包括敏感数据泄露、网络钓鱼、盗窃和暴力攻击 [ 1 ]。面部识别和指纹识别等其他静态生物识别方法虽然增强并提高了系统的安全性,但事实证明,它们容易受到静态数据限制、环境条件和基于欺骗的攻击 [ 2 ]。为了解决上述缺点并提高可用性和安全性,应采用动态有前景的解决方案 [ 3 ]。
行为生物识别技术被认为是系统身份验证问题最突出的解决方案之一,因为它们能够深入分析个人特定的交互模式,包括滑动手势、触摸压力和空间运动的 (X, Y) 坐标。与传统方法(例如静态技术)相比,这些方法可以重复提供身份验证,并且能够适应动态用户行为。许多先前的研究已经对运动数据和触摸动态进行了研究,以精确识别独特的用户特征;然而,它们不足以抵御现实世界的变化和条件,例如伪造尝试以及环境和气候变化 [ 4 , 5 ]。这些问题表明,我们确实需要更具弹性的技术。
有趣的是,为了进一步完善身份验证系统,三维 (3D) 触摸传感器已广泛应用于许多不同的应用领域。例如,为了获得每个人独特的交互模式,现代技术已经利用 3D 触摸位置和压力灵敏度来实现,这显著提高了系统的安全级别和稳健性 [ 6 ]。其他方法,例如音频和声音传感器,已经通过 3D 触摸传感器进行了增强,以用于移动医疗保健,从而保护患者数据的私密性和安全性 [ 7 ]。为了显著提高设计的安全级别,可以将生物特征数据(例如脑电图 (EEG) 信号处理)与传感器数据相结合 [ 8 ]。虽然这些进步有助于提高安全性,但仍然需要将触摸压力和位置数据集成到统一的框架中,以实现更稳健的身份验证。
先前的研究并未专注于将3D触摸压力数据与屏幕手指位置数据相结合,从而使用TOPSIS等决策技术构建统一的框架。在本研究中,我们致力于通过提出一种新颖的智能手机身份验证框架来解决这些局限性。基于TOPSIS的决策方法已通过机器学习技术得到增强,可以识别并排序用户行为中关键且有价值的特征。通过仅利用TOPSIS方法筛选出的有价值的特征,并使用机器学习算法增强模型弹性,该技术提供了一个安全、可扩展且用户友好的身份验证系统,可以抵御包括网络安全威胁在内的多种攻击。为了改进该技术的弹性和鲁棒性,我们结合了时间缩放、噪声插入和空间扰动方法来模拟现实世界的用户响应。本研究提出了一种安全轻量级的技术,可以抵御严重威胁,并通过将TOPSIS方法与机器学习算法和动态模式识别相结合来解决当前的身份验证难题。
本文的主要贡献是:
- 在 Android 平台上开发了一款智能手机身份验证应用程序,以收集 30 名参与者的数据,每位参与者进行 10 次尝试。
- 开发了一种基于机器学习的方法用于系统认证,其中评估了各种机器学习算法以确定最有效的模型。
- 采用TOPSIS法选择关键行为特征,通过关注最具影响力的数据来提高身份验证系统的性能。
- 通过应用数据扰动技术(包括噪声注入和时间缩放)来模拟现实世界的变化,系统的弹性得到了增强。
- 该系统针对四种类型的网络安全攻击(欺骗、光照变化、方向变化和噪声注入)进行了测试,以评估其稳健性和安全性。
本研究的核心创新之处在于其集成框架,该框架将行为生物识别、多准则决策(TOPSIS)和集成机器学习模型(RF、GBM 和 KNN)相结合,用于移动身份验证。与以往仅使用传统分类技术或单一生物特征的研究不同,本研究引入了一种迭代特征排序机制,该机制使用 TOPSIS 优化输入空间,并仅将最具影响力的特征输入到多个机器学习模型中。所提出的系统还通过借鉴现实世界的扰动技术(例如噪声注入、时间缩放)来增强鲁棒性,而这些技术在以往的研究中往往被忽视。这种组合有助于开发一个实时、轻量级且具有弹性的身份验证系统,该系统的性能优于现有模型,准确率达到 95.2%,并增强了抗欺骗能力和环境适应性。本文的其余部分安排如下:第2节简要概述了前期研究成果,包括身份验证系统的行为生物识别技术、身份验证系统中的机器学习技术以及决策方法,以及当前安全性和可用性方面的挑战。第3节详细介绍了我们提出的技术。第4节给出了实验结果(包括决策和分析)。第5节阐述了我们的结论和未来的工作。
2.文献综述
由于当今智能设备的进步和现代化的复杂性,许多研究人员已经实现了生物特征认证,以显著提高系统安全性和可用性 [ 9 ]。遗憾的是,超时和失败是传统身份验证技术的两个主要缺点,例如图案锁、PIN 码、基本生物特征识别系统和密码。虽然传统身份验证简单、轻量且易于实现,但事实证明,它们容易受到暴力破解、密码盗窃和网络钓鱼攻击 3、7、10、11 []。一旦静态凭证被泄露,攻击者就可以获得无限制访问权限,从而破坏系统的安全 [ 12 ]。为了解决这些漏洞,最近的研究将机器学习算法和传感器数据与传统身份验证结合起来,以提供更安全、更有弹性的系统,抵御许多严重的攻击[ 4、13 []](https://www.mdpi.com/2624-800X/5/2/20#B4-jcp-05-00020)。
2.1. 用于身份验证系统的行为生物识别技术
生物特征认证系统(包括指纹和面部识别)已被引入作为解决传统方法局限性的替代方案。与密码相比,这些系统提供了更高的安全性和用户便利性 [ 14,15 ]。然而,面部识别系统可能会被高质量图像或面具欺骗,指纹传感器易受雨水、灰尘和物理退化等环境因素的影响 [ 16,17 ],并且容易受到高级欺骗技术的攻击 [ 18,19 ]。上述挑战强调了对能够同时解决安全性和可用性问题的弹性、动态和自适应身份验证方法的需求。在 [ 20 ] 中,作者将指纹、面部识别和虹膜扫描结合起来作为传统方法的替代方案。虽然该提案利用生理特征进行用户验证并提供了增强的安全性,但它容易受到湿度、光照条件和设备方向等环境因素的影响 [ 21 ]。此外,生物特征数据容易受到欺骗,攻击者可以模仿用户凭据 [ 19,22 ]。这提高了基于行为的身份验证方法的需求。
行为生物识别技术依赖于用户交互模式(例如滑动动态、打字速度和触摸压力)来实现持续身份验证。与静态生理生物识别技术不同,行为方法是动态的,能够随着时间推移适应用户行为的变化,从而能够抵御欺骗尝试和对抗性攻击 [ 6 ]。许多研究表明行为生物识别技术对智能手机身份验证性能的影响。Smith 等人采用滑动轨迹和压力水平来区分冒名顶替者与真人 [ 23 ]。在 [ 24 ] 中
相关文章:
通过混合机器学习和 TOPSIS 实现智能手机身份验证的稳健行为生物识别框架
1. 简介 随着日常工作、个人生活和金融操作对智能手机的依赖性不断增强,对弹性安全身份验证系统的需求也日益增长。尽管 PIN 码、密码和静态生物识别等传统身份验证方法仍可为系统提供一定的安全级别,但事实证明,它们容易受到多种威胁,包括敏感数据泄露、网络钓鱼、盗窃和…...
day010
文章目录 1. 在Ubuntu中使用visudo2. 别名 alias2.1 查看已配置的别名2.2 配置grep别名2.3 配置rm别名2.4 临时使用配置别名的命令 3. 系统校验检查3.1 md5校验3.2 aide 高级入侵检测环境3.2.1 安装aide3.2.2 修改aide配置文件3.2.3 根据配置文件生成初始的指纹信息库3.2.4 使用…...
Coco AI 开源应用程序 - 搜索、连接、协作、您的个人 AI 搜索和助手,都在一个空间中。
一、软件介绍 文末提供程序和源码下载 Coco AI 是一个统一的搜索平台,可将您的所有企业应用程序和数据(Google Workspace、Dropbox、Confluent Wiki、GitHub 等)连接到一个功能强大的搜索界面中。此存储库包含为桌面和移动设备构建的 Coco 应…...
MySQL 8.0 OCP(1Z0-908)英文题库(11-20)
目录 第11题题目分析正确答案 第12题题目分析正确答案 第13题题目分析正确答案 第14题题目分析正确答案 第15题题目分析正确答案 第16题题目分析正确答案 第17题题目分析正确答案: 第18题题目分析正确答案 第19题题目分析正确答案 第20题题目分析正确答案 第11题 W…...
国标GB28181软件EasyGBS雪亮工程打造智能高效的视频监控新体系
一、背景 雪亮工程是构建公共安全视频监控联网应用的系统工程,旨在通过整合各类视频监控资源,实现城乡视频监控一体化,提升社会治安防控能力。随着城市化进程的加快和社会治理需求的不断提高,雪亮工程的建设规模不断扩大…...
视频添加字幕脚本分享
脚本简介 这是一个给视频添加字幕的脚本,可以方便的在指定的位置给视频添加不同大小、字体、颜色的文本字幕,添加方式可以直接修改脚本中的文本信息,或者可以提前编辑好.srt字幕文件。脚本执行环境:windowsmingwffmpeg。本方法仅…...
springCloud/Alibaba常用中间件之GateWay网关
文章目录 SpringCloud:依赖版本补充GateWay:网关三大核心之Router:路由1、导入基础依赖2、进行服务注册3、路由映射4、测试访问GateWay的端口是否可以访问 三大核心之Predicate:断言配置文件自定义Predicate(断言) 三大核心之Filter:过滤配置文件自定义全…...
ABP vNext + Dapr 实现云原生微服务治理
ABP vNext Dapr 实现云原生微服务治理 🚀 前言 📝 随着云原生与微服务架构的快速发展,相关工具和框架也在不断演进。ABP vNext 是一套成熟而现代的 .NET 应用开发框架,在模块化、领域驱动设计等方面提供强大支持。而 Dapr 作为…...
【报错】view size is not compatible with input tensor‘s size and stride
完整报错 Traceback (most recent call last): File "D:\360MoveData\Users\HONOR\whu\TwoStageTraining.py", line 590, in <module> criterionseg_criterion, save_dir./models, writerwriter_first_stage) File "D:\360MoveData\Users\HONOR\whu\TwoS…...
maven如何搭建自己的私服(windows版)?
环境准备 安装 JDK :确保系统已安装 JDK 8 或更高版本。可以通过以下步骤安装 JDK: 下载 JDK 安装包,可以从Oracle 官方网站下载适用于 Windows 的 JDK 安装程序。 运行安装程序,按照提示完成安装。安装过程中可以指定安装路径&a…...
CDGP|数据全生命周期的“收数、治数、用数、保数”体系详解
在数据成为重要资产的今天,如何高效地管理和利用数据已成为企业和组织的核心竞争力之一。数据全生命周期管理涵盖了从数据收集、治理、应用到保护的各个环节,形成了一个闭环体系。本文将重点介绍数据全生命周期中的“收数、治数、用数、保数”四个关键环…...
在UI原型设计中,低、高保真原型图有什么区别?
在数字产品开发中,原型(Prototype) 是连接创意与落地的桥梁。它通过可视化的方式验证功能、交互与用户体验,避免开发资源浪费。而低保真(Lo-Fi)与高保真(Hi-Fi)原型,则是…...
万物互联时代:ONVIF协议如何重构安防监控系统架构
前言 一、ONVIF协议是什么 ONVIF(Open Network Video Interface Forum,开放式网络视频接口论坛)是一种全球性的开放行业标准,由安讯士(AXIS)、博世(BOSCH)和索尼(SONY&…...
初识Linux · 传输层协议TCP · 上
目录 前言: TCP结构体 首部长度 确认应答机制 捎带应答机制 超时重传机制 连接管理机制 三次握手 SYN_SENT SYN_RCVD ESTABLISHED TCP为什么是三次握手 四次挥手 什么是四次挥手 状态理解 CLOSE_WAIT LAST_ACK TIME_WAIT 前言: 前文有…...
基于SpringBoot的校园周边美食探索及分享平台的设计与实现
资源详情: 私信我或点击链接获取: 基于SpringBoot的校园周边美食探索及分享平台的设计与实现资源-CSDN文库 摘要 美食一直是与人们日常生活息息相关的产业。传统的电话订餐或者到店消费已经不能适应市场发展的需求。随着网络的迅速崛起,互联…...
系统架构设计-真题2024下半年总结
系统架构设计-真题2024下半年总结 综合知识(选择题)考点分布选择题详细解释ABSD方法简介 选项分析生活化例子概念讲解系统的质量目标系统的商业目标系统开发人员的商业目标 简单记法总结基于内容推荐的优点选项分析正确答案总结 综合知识(选择…...
《React Native性能优化:从卡顿到丝滑的蜕变之旅》
《React Native性能优化:从卡顿到丝滑的蜕变之旅》 前言:当你的React Native应用开始"便秘"… “这破应用怎么又卡了?!”——如果你也曾在测试自己的React Native应用时发出这样的呐喊,那么你不是一个人在怒吼。想象一下这样的场景:你精心打造的APP在低端安卓…...
flutter build apk出现的一些奇怪的编译错误
我换了新电脑后重新编译基于livekit 的 flutter livekit工程,然后编译的时候一直报flutter_webrtc的 0.11.7 版本的dart代码有一个接口未实现,我比较了所以环境和版本实现找不到问题,根本不正常哪里导致的问题 ,以前的电脑的环境一…...
枚举 · 例8扩展-校门外的树:hard
登录—专业IT笔试面试备考平台_牛客网 代码区: #include<algorithm> #include<iostream> #include<vector>using namespace std; struct TREE{int left,right; }; bool compare(const TREE&a,const TREE& b ){if(a.left!b.left){return…...
监控系统进阶方案:OpenObserve的Docker部署与远程访问配置指南
文章目录 前言1. 安装Docker2. 创建并启动OpenObserve容器3. 本地访问测试4. 公网访问本地部署的OpenObserve4.1 内网穿透工具安装4.2 创建公网地址 5. 配置固定公网地址 前言 今天,我想分享一个在云原生可观测性领域备受关注的开源项目——OpenObserve。在复杂的云…...
如何通过grep 排除“INTEGER: 1”
在 Linux/Unix 系统中,使用 grep 过滤数据并 取反(排除匹配内容) 的核心选项是 -v(反向匹配)。以下是具体用法和场景示例: 1. 基础用法:排除包含指定关键词的行 # 语法 grep -v "pattern&…...
基于Qt开发的http/https客户端
成果展示: 使用Qt开发HTTP客户端主要依赖QNetworkAccessManager、QNetworkRequest和QNetworkReply三大核心类。以下是具体实现要点及最佳实践: 一、核心类与基础流程 1.QNetworkAccessManager 作为HTTP请求的管理者,负责异步处理…...
微程序控制器的详细工作过程
1. 基本组成结构 微程序控制器主要由以下部件构成: 控制存储器(Control Store, CS):存储微程序(微指令集合),通常使用ROM或EPROM。 微地址寄存器(μAR):存放…...
PostgreSQL 的 pg_current_logfile 函数
PostgreSQL 的 pg_current_logfile 函数 pg_current_logfile() 是 PostgreSQL 9.6 版本引入的一个系统管理函数,用于获取当前正在使用的日志文件路径。 一 基本用法 1 函数定义 pg_current_logfile([text]) → text2 简单查询 -- 获取当前日志文件路径 SELECT …...
实时云渲染——比像素流送节省80%精力的UE程序推流技术
UE5引擎除了适合开发3A游戏,同样适用于开发大场景高精度的数字孪生可视化场景,自带的Nanite 虚拟微多边形几何体技术、Lumen 全动态全局光照技术、高度可扩展的架构、强大的地形和植被系统以及高效的流媒体技术,使UE5在数字孪生领域的技术占有…...
如何解决 Linux 系统文件描述符耗尽的问题
在Linux系统中,文件描述符(File Descriptor, FD)是操作系统管理打开文件、套接字、管道等资源的抽象标识。当进程或系统耗尽文件描述符时,会导致服务崩溃、连接失败等严重问题。以下是详细的排查和解决方案: --- ###…...
存储器:DDR和HBM的区别
本文简要介绍DDR(Double Data Rate SDRAM)和HBM(High Bandwidth Memory)的主要区别: 1. 架构与设计 DDR:传统的主流动态随机存取存储器(DRAM),采用并行总线架构&#x…...
【计算机网络】Cookie、Session、Token之间有什么区别?
大家在日常使用浏览器时可能会遇到:是否清理Cookie?这个问题。 那么什么是Cookie呢?与此相关的还有Session、Token这些。这两个又是什么呢? 本文将对这三个进行讲解区分,如果对小伙伴有帮助的话,也请点赞、…...
每日学习:DAY24
日常开发与学习记录 前言 怎么感觉自己越来越懒了。 日程 忘记写了,大概是早上做了 SQL 表单,晚上写了 DispatcherController。 学习记录 操作系统 页面分配置换策略 学习内容 省流 SQL 表单构建关于嵌套注解的生效机制DispatcherController 统…...
grpo原理
图解deepseek的grpo原理、以debug形式阅读grpo的源码 练习两天半,从零实现DeepSeek-R1(基于Qwen2.5-0.5B和规则奖励模型,GRPO),从原理讲解到代码实现,解开DeepSeek-R1的神秘面纱 第一个视频 GRPO讲解 mod…...
RabbitMQ--基础篇
RabbitMQ 简介:RabbitMQ 是一种开源的消息队列中间件,你可以把它想象成一个高效的“邮局”。它专门负责在不同应用程序之间传递消息,让系统各部分能松耦合地协作 优势: 异步处理:比如用户注册后,主程序将发…...
ResNet残差神经网络的模型结构定义(pytorch实现)
ResNet残差神经网络的模型结构定义(pytorch实现) ResNet‑34 ResNet‑34的实现思路。核心在于: 定义残差块(BasicBlock)用 _make_layer 方法堆叠多个残差块按照 ResNet‑34 的通道和层数配置来搭建网络 import torch…...
如何使用极狐GitLab 软件包仓库功能托管 ruby?
极狐GitLab 是 GitLab 在中国的发行版,关于中文参考文档和资料有: 极狐GitLab 中文文档极狐GitLab 中文论坛极狐GitLab 官网 软件包库中的 Ruby gems (BASIC ALL) WARNING:Ruby gems 软件包库正在开发中,由于功能有限,尚未准备好…...
AI日报 · 2025年5月08日|Stripe发布全球首个支付AI基础模型
1、Stripe 发布支付领域专用 AI 基础模型及稳定币账户功能 Stripe 于5月7日在其年度 Sessions 大会上发布了全球首个专为支付领域打造的 AI 基础模型——“Payments Foundation Model”,该模型基于数百亿笔交易数据训练,能够捕捉每个支付中数百个传统模…...
React 笔记[1] hello world
React 笔记[1] hello world 明白了!既然你已经安装了 Node.js,我们可以 从零开始搭建一个 React Tailwind CSS 的 Hello World 项目。我将一步步列出操作指令,你只需要在终端里依次执行。 ✅ 第一步:初始化项目 mkdir my-hello…...
好消息!PyCharm 社区版现已支持直接选择 WSL 终端为默认终端
在过去,PyCharm 社区版虽然提供了链接 Windows 子系统 Linux(WSL)终端的能力,但用户无法在设置中直接指定 WSL 为默认终端,这一功能仅限于专业版使用者。 而现在,在 PyCharm 2025.1.1 版本中,Je…...
基于redis的定时状态更新
基于redis的定时状态更新 下面是一个简单的示例,展示如何使用redis实现状态更新,从而满足在某些场景下,既需要频繁更新状态, 又需要保证状态的实时性。以及定时更新状态的需求。 示例说明 假设有一个剧目演出计划,确…...
[原创](现代Delphi 12指南):[macOS 64bit App开发]: 如何获取自身程序的所在的目录?
[作者] 常用网名: 猪头三 出生日期: 1981.XX.XX 企鹅交流: 643439947 个人网站: 80x86汇编小站 编程生涯: 2001年~至今[共24年] 职业生涯: 22年 开发语言: C/C++、80x86ASM、Object Pascal、Objective-C、C#、R、Python、PHP、Perl、 开发工具: Visual Studio、Delphi、XCode、…...
服务器托管的常见问题
一、何谓IDC服务器托管服务? IDC服务器托管是指为了提高网站的访问速度,将您的服务器及相关设备托管到具有完善机房设施、高品质网络环境、丰富带宽资源和运营经验以及可对用户的网络和设备进行实时监控的网络数据中心内,以此使系统达到安全、可靠、稳定…...
使用Scrapeless Scraping Browser的自动化和网页抓取最佳实践
引言:人工智能时代浏览器自动化和数据收集的新范式 随着生成性人工智能、人工智能代理和数据密集型应用程序的快速崛起,浏览器正在从传统的“用户互动工具”演变为智能系统的“数据执行引擎”。在这一新范式中,许多任务不再依赖单一的API端点…...
电子电气架构 --- 如何有助于提安全性并减少事故
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 钝感力的“钝”,不是木讷、迟钝,而是直面困境的韧劲和耐力,是面对外界噪音的通透淡然。 生活中有两种人,一种人格外在意别人的眼光;另一种人无论…...
【训练】Qwen2.5VL 多机多卡 Grounding Box定位
之前的相关文章: 【深度学习】LLaMA-Factory微调sft Qwen2-VL进行印章识别 https://www.dong-blog.fun/post/1661 使用LLaMA-Factory微调sft Qwen2-VL-7B-Instruct https://www.dong-blog.fun/post/1762 构建最新的LLaMA-Factory镜像 https://www.dong-blog.f…...
MYSQL的行级锁到底锁的是什么东西
MySQL 的行级锁是一种锁机制,它允许数据库在执行并发操作时,锁定表中的某一行数据而不是整张表。行级锁通过限制对特定行的访问,允许其他线程并发地访问表中的其他行,从而提高并发性和性能。 行级锁的锁定对象 行级锁锁定的是 行…...
图神经网络中的虚拟节点
1.虚拟节点 当我们使用节点来构成图结构时, regular node: 常规的节点即代表了某一个局部特征, 即局部节点特征。 virtual node: 普通的节点不同,有时会需要这样的一种特征, 该特征代表了该样本的全局信息࿰…...
关于多版本CUDA共存的研究,是否能一台机子装两个CUDA 版本并正常切换使用
我发现了一个很有意思的事 我装了11.8cuda再装12.3cuda结果我的11.8cuda还在,没被替换掉或者删掉 然后我打开我的环境发现它的环境除了cuda_path都没改 这样我就有个大胆的想法,如果我把cuda path换成11.8路径那是不是就能切换了 而且cuda_path 和 cuda_…...
el-table与echarts图形实现滚动联动
el-table与echarts图形滚动联动 效果图 实现思路 设计图滚动条位于表格下方,且echarts滚动不易获取当前展示数据到左侧的距离 故:通过监听表格的滚动实现联动 为了保持echarts的横坐标和表格的列基本保持对齐,用tdWidth标识单列表格的宽度…...
【Git】【commit】查看未推送的提交查看指定commit的修改内容合并不连续的commit
文章目录 1. 查看未推送的提交方法一 :git status方法二:git log方法三:git cherry方法四:git rev-list 2. 查看指定commit的修改方法一:git show方法二:git log方法三:git diff 3. 合并不连续的…...
C++GO语言微服务基础技术①
目录 01-项目简介 02-单体式架构 03-微服务优缺点 04-单体式和微服务区别 05-RPC简介 06-RPC使用步骤 07-注册RPC服务函数接口 08-绑定服务和调用方法函数接口 09-rpc服务端和客户端编码实现 10-json的rpc 11-rpc的封装 12-rpc封装小结 01-项目简介 # 单体式和微服…...
AI CUBE 使用指南 目标检测格式范例 AI cube 报错数据集不合规范,请清洗数据集
血的教训:labels.txt里面放1 2 3 4 ..也可以英文,不能有中文 教程:K230 借助 AICube部署AI 视觉模型 YOLO等教程_嘉楠 ai cube多标签分类-CSDN博客 | 目标检测范例: 不清楚不是数字行不行 这个id可以英文,你…...
vue中scss使用js的变量
一、前言 在项目开发中,很多时候会涉及到scss样式变量,正常定义方式 $primary-color: rgb(188, 0, 194);;使用时直接使用即可:color: $primary-color。但是,如果,这些变量是在js中定义的怎么办 二、实现 …...