突破网络壁垒:实现 Mac SSH 访问 Windows WSL Ubuntu 的最佳实践20250301
突破网络壁垒:实现 Mac SSH 访问 Windows WSL Ubuntu 的最佳实践
背景与痛点
在现代开发环境中,开发者通常会面临不同操作系统之间的协同工作。例如:
- 主要开发环境位于 Windows 的 WSL Ubuntu 子系统
- 需要从局域网内的 Mac 设备进行远程访问和管理
- 由于 WSL 默认采用 NAT 网络隔离(172.x.x.x 网段),导致:
- 无法直接从局域网设备(如 192.168.x.x)访问 WSL 环境
- 每次 WSL 重启时可能导致 IP 地址变化,影响网络连接(WSL2 特性)
因此,我们需要配置端口转发解决方案,确保从 Mac 等设备可以无缝访问 WSL 上的服务,包括 SSH 和 HTTP 服务。
网络架构解析
设备 | IP 地址 | 网络类型 | 访问关系 |
---|---|---|---|
Windows 宿主机 | 192.168.1.6 | 局域网 | 可直连 |
WSL Ubuntu | 172.22.192.1 | NAT 虚拟网络 | 仅宿主机可访问 |
Mac | 192.168.1.44 | 局域网 | 可直连宿主机 |
系统级解决方案:Windows 端口转发配置
步骤 1:配置持久化端口转发
我们将使用 Windows 的 netsh 工具 来配置端口转发,确保可以从外部设备(如 Mac)访问 WSL 中的 SSH 服务和 HTTP 服务(如 8080 端口)。
1.1 配置 SSH 端口转发
首先,配置 WSL 的 SSH 服务访问,使 Mac 可以通过 SSH 连接到 WSL 环境。
# 以管理员身份运行 PowerShell
$wsl_ip = (wsl hostname -I).Trim()# 配置 SSH 服务端口转发
netsh interface portproxy add v4tov4 `listenaddress=192.168.1.6 `listenport=5522 `connectaddress=$wsl_ip `connectport=22
这里的配置将 Windows 宿主机的 5522 端口转发到 WSL 上的 22 端口(SSH 服务)。你可以通过 Mac 使用 SSH 连接 Windows 的 5522 端口。
1.2 配置 HTTP(8080)端口转发
接下来,如果你希望 WSL 上的 8080 端口(通常是 Web 服务的端口)能够从 Mac 访问,则需要在 Windows 宿主机上配置另一个端口转发规则。
# 配置 HTTP 服务端口转发
netsh interface portproxy add v4tov4 `listenaddress=192.168.1.6 `listenport=8080 `connectaddress=$wsl_ip `connectport=8080
这样,Mac 就能够通过 192.168.1.6:8080 访问 WSL 上运行的 HTTP 服务(如一个 Web 应用)。
1.3 防火墙配置
为了限制访问权限,我们将防火墙规则配置为只允许来自 Mac 的请求。
# 配置防火墙规则,限制 Mac IP 地址
New-NetFirewallRule -DisplayName "WSL SSH Proxy" `-Direction Inbound `-Action Allow `-Protocol TCP `-LocalPort 5522 `-RemoteAddress 192.168.1.44 # 限制只允许 Mac 访问New-NetFirewallRule -DisplayName "WSL HTTP Proxy" `-Direction Inbound `-Action Allow `-Protocol TCP `-LocalPort 8080 `-RemoteAddress 192.168.1.44 # 限制只允许 Mac 访问
总结:通过以上配置,Windows 宿主机将 5522 端口转发到 WSL 的 SSH 服务(22 端口),同时将 8080 端口转发到 WSL 上的 HTTP 服务(8080 端口)。Mac 设备可以直接通过这两个端口访问 WSL 中的相应服务。
步骤 2:配置自动启动脚本
为了保证每次启动 Windows 时都能自动设置端口转发规则,可以将这些配置写入 PowerShell 脚本并添加到启动任务中。
2.1 保存 PowerShell 脚本
将以下 PowerShell 脚本保存为 wsl_ssh_http_proxy.ps1
,路径可以设置为 C:\Scripts\wsl_ssh_http_proxy.ps1
:
$port_ssh = 5522
$port_http = 8080
$wsl_ip = (wsl hostname -I).Trim()# 清除旧规则
netsh interface portproxy reset# 配置 SSH 服务端口转发
netsh interface portproxy add v4tov4 `listenaddress=0.0.0.0 `listenport=$port_ssh `connectaddress=$wsl_ip `connectport=22# 配置 HTTP 服务端口转发
netsh interface portproxy add v4tov4 `listenaddress=0.0.0.0 `listenport=$port_http `connectaddress=$wsl_ip `connectport=8080# 设置防火墙规则
New-NetFirewallRule -DisplayName "WSL SSH Proxy" `-Direction Inbound `-Action Allow `-Protocol TCP `-LocalPort $port_ssh `-RemoteAddress 192.168.1.44 # 限制只允许 Mac 访问New-NetFirewallRule -DisplayName "WSL HTTP Proxy" `-Direction Inbound `-Action Allow `-Protocol TCP `-LocalPort $port_http `-RemoteAddress 192.168.1.44 # 限制只允许 Mac 访问
2.2 创建计划任务
- 打开 任务计划程序
- 创建一个新任务,设置触发器为 计算机启动时
- 在操作中设置为
powershell.exe -ExecutionPolicy Bypass -File C:\Scripts\wsl_ssh_http_proxy.ps1
步骤 3:SSH 和 HTTP 服务的安全加固配置
3.1 SSH 安全加固
在 WSL 内禁用密码认证,以增强 SSH 服务的安全性。
# 禁用密码认证
sudo sed -i 's/#PasswordAuthentication yes/PasswordAuthentication no/' /etc/ssh/sshd_config
sudo systemctl restart ssh
3.2 HTTP 服务安全配置
如果你运行的是 Web 服务,确保只允许信任的 IP 地址访问,或者在 WSL 内进行防火墙配置,限制访问权限。
Mac 端专业级连接方案
方法 1:SSH 配置文件优化
为了更好地连接 WSL 环境,建议在 Mac 上配置 SSH 客户端,并指定对应的端口和身份验证文件。
# ~/.ssh/config
Host wsl-sshHostName 192.168.1.6Port 5522User ubuntu_userIdentityFile ~/.ssh/wsl_keyServerAliveInterval 60TCPKeepAlive yesCompression yes
方法 2:建立 SSH 隧道代理
如果你希望通过 SSH 隧道同时访问 SSH 服务和 HTTP 服务,使用以下命令:
# 创建持久化隧道,转发 SSH 和 HTTP 服务
autossh -M 0 -N -L 2222:localhost:5522 -L 8080:localhost:8080 user@192.168.1.6# 连接时直接使用
ssh -p 2222 localhost
高级运维策略
网络诊断工具包
# 连通性测试
mtr -rwzc 10 192.168.1.6# 端口扫描
nmap -sT -p 5522,8080 192.168.1.6# 流量监控
tcpdump -i eth0 port 22 -w ssh_traffic.pcap
tcpdump -i eth0 port 8080 -w http_traffic.pcap
自动化监控脚本
#!/bin/bash
ALERT_THRESHOLD=3
FAIL_COUNT=0while true; do# 检查 SSH 服务if ! nc -z -w 3 192.168.1.6 5522; then((FAIL_COUNT++))elseFAIL_COUNT=0fi# 检查 HTTP 服务if ! nc -z -w 3 192.168.1.6 8080; then((FAIL_COUNT++))elseFAIL_COUNT=0fiif [ $FAIL_COUNT -ge $ALERT_THRESHOLD ]; thenecho "Warning: Service failure detected!"fisleep 60
done
总结
通过这种配置,您可以实现以下目标:
- 从 Mac 通过 SSH 访问 Windows 上的 WSL 环境
- 外部设备访问 WSL 上运行的 HTTP 服务
- 在系统启动时自动配置端口转发,避免重复操作
- 通过适当的安全加固,提高 SSH 和 HTTP 服务的安全性
这些技术结合使得跨平台的开发环境更加流畅和安全,非常适用于在混合环境中开发与测试的需求。
相关文章:
突破网络壁垒:实现 Mac SSH 访问 Windows WSL Ubuntu 的最佳实践20250301
突破网络壁垒:实现 Mac SSH 访问 Windows WSL Ubuntu 的最佳实践 背景与痛点 在现代开发环境中,开发者通常会面临不同操作系统之间的协同工作。例如: 主要开发环境位于 Windows 的 WSL Ubuntu 子系统需要从局域网内的 Mac 设备进行远程访问…...
【开源-鸿蒙土拨鼠大理石系统】鸿蒙 HarmonyOS Next App+微信小程序+云平台
✨本人自己开发的开源项目:土拨鼠充电系统 ✨踩坑不易,还希望各位大佬支持一下,在GitHub给我点个 Start ⭐⭐👍👍 ✍GitHub开源项目地址👉:https://github.com/lusson-luo/HarmonyOS-groundhog-…...
RAG 阿里云
RAG-阿里云Spring AI Alibaba官网官网 RAG-阿里云Spring AI Alibaba官网官网 AI应用跑起来,取消一下航班的操作666...
python -ssh学习
def exe_sshcmd(ip,username,userpswd,port,cmd): """ 功能:SSH登录到指定设备,并执行对应的命令 入参:前四项为ssh登录shell的ip和port,具备管理员权限的用户名和密码, cmd可以…...
【Java学习】内部类
面向对象系列六 一、类级别 1.静态成员 2.非静态成员与方法 二、类的创建与成员管理 1.类的创建 2.类的成员管理 三、常见的内部类 1.非静态内部类 2.静态内部类 3.匿名内部类 4.局部内部类 一、类级别 1.1静态成员 静态成员是类级别的是能一路直属都是在类层面的&…...
养生,开启健康生活之门
在这个快节奏的时代,人们在忙碌奔波中,往往忽略了自身健康。养生保健,不再是老年人的专属,而是各个年龄段维持良好生活状态的关键,它是我们开启健康生活的一把钥匙。 规律作息是养生的基石。人体就像一台精密的仪器&am…...
1-3压缩命令
文章目录 1. tar1.1 压缩(.tar.gz .tgz .tar.bz2 )1.2 解压缩(.tar.gz .tgz .tar.bz2 ) 2.zip2.1 压缩(.zip)2.2 解压缩 3.xz3.1 压缩(.tar.xz)3.2 解压缩 1. tar 1.1 压缩(.tar.gz .tgz .tar.bz2 ) c…...
Dify使用和入门
第一步:了解 Dify 在开始之前,先简单了解一下 Dify 是什么: Dify 是一个开源的 LLM 应用开发平台,专注于帮助开发者快速构建生产级的生成式 AI 应用。它支持知识库集成、RAG(检索增强生成)技术、复杂工作…...
AcWing 5933:爬楼梯 ← 递归 / 递推 / 高精度
【题目来源】 https://www.acwing.com/problem/content/5936/ 【题目描述】 树老师爬楼梯,他可以每次走 1 级或者 2 级,输入楼梯的级数,求不同的走法数。 例如:楼梯一共有 3 级,他可以每次都走一级,或者第…...
WebGL 渲染器 WebGLRenderer
目录 Three.js封装的渲染器 .domElement属性 .setSize(width, height)方法 帧缓冲区的相关封装 渲染器方法.clear(color,depth,stencil) 渲染器方法.clearDepth() 渲染器属性.autoClear Three.js封装的渲染器 .domElement属性 如果想通过WebGL渲染一个三维场景&#…...
基于Three.js的3D赛车游戏开发实战详解
目录 一、项目效果预览二、核心技术架构2.1 三维场景构建2.2 赛道与车辆模型2.3 光照系统三、核心运动系统3.1 车辆运动控制3.2 物理模拟公式3.3 边界限制四、摄像机控制系统4.1 第三人称视角数学原理4.2 鼠标交互实现五、星空背景特效5.1 点云生成算法5.2 动态闪烁效果六、性能…...
⭐算法OJ⭐位操作实战【计数】(C++ 实现)
191. Number of 1 Bits Given a positive integer n, write a function that returns the number of set bits in its binary representation (also known as the Hamming weight). int hammingWeight(uint32_t n) {int count 0;while (n) {count n & 1; // 检查最低位…...
【通俗讲解电子电路】——从零开始理解生活中的科技(一)
导言:电子电路为什么重要? ——看不见的“魔法”,如何驱动你的生活? 清晨,当你的手机闹钟响起时,你可能不会想到,是电子电路在精准控制着时间的跳动;当你用微波炉加热早餐时&#…...
浏览器JS打不上断点,一点就跳到其他文件里。浏览器控制台 js打断点,指定的位置打不上断点,一打就跳到其他地方了。
关闭JavaScript 源代码映射,F12开发者模式 设置->偏好设置->源代码/来源->JavaScript 源代码映射。 肯定不是这个原因导致的,但这个办法可以暂时解决问题,点完这个东西就隐藏了webpack,有懂的来讲讲。 又浪费一个小时…...
浅谈人工智能之Windows安装llama factory
浅谈人工智能之Windows安装llama factory Llama Factory 是一个强大的工具,旨在帮助用户轻松管理和优化Llama模型的训练和部署。在某些情况下,您可能需要在部分互联网连接的环境中安装和使用Llama Factory。本文将详细介绍如何在Windows系统上这种情况下…...
mac电脑中使用无线诊断.app查看连接的Wi-Fi带宽
问题 需要检查连接到的Wi-Fi的AP硬件支持的带宽。 步骤 1.按住 Option 键,然后点击屏幕顶部的Wi-Fi图标;2.从下拉菜单中选择 “打开无线诊断”(Open Wireless Diagnostics);3.你可能会看到一个提示窗口,…...
Python--内置模块和开发规范(下)
2. 开发规范 2.1 单文件应用 文件结构示例 # 文件注释 import os import jsonDB_PATH "data.json" # 常量放顶部def load_data():"""函数注释:加载数据"""if os.path.exists(DB_PATH):with open(DB_PATH, "r"…...
vue3配置端口,比底部vue调试
import { fileURLToPath, URL } from ‘node:url’ import { defineConfig } from ‘vite’ import vue from ‘vitejs/plugin-vue’ import vueJsx from ‘vitejs/plugin-vue-jsx’ // 关闭vue底部调试模式 // import vueDevTools from ‘vite-plugin-vue-devtools’ // htt…...
代码随想录day51
647. /** lc appleetcode.cn id647 langcpp** [647] 回文子串*/// lc codestart #include<iostream> #include<vector> #include<string> using namespace std; class Solution { public:int countSubstrings(string s) {vector<vector<bool>> …...
B2B2C多语言电商系统代销逻辑设计和开发
随着全球电商市场的快速发展,B2B2C(Business-to-Business-to-Consumer)模式逐渐成为企业拓展业务的重要方式。特别是在多语言、多文化的国际市场环境中,B2B2C多语言电商系统的代销功能为企业提供了灵活的业务模式,帮助…...
示波器探头衰减值:简单来说就是“信号缩小器
一、什么是衰减值 衰减值就是探头把信号“缩小”多少倍再传给示波器。比如: 1X衰减:信号原样传输(不缩小),适合测小电压(比如手机电池3.7V)。 10X衰减:信号缩小10倍,适…...
Nginx系列06(Nginx 缓存配置、SSL/TLS 配置)
目录 Nginx 缓存配置 SSL/TLS 配置 Nginx 缓存配置 概念:Nginx 缓存配置允许服务器将频繁访问的资源(如网页、图片、脚本等)存储在内存或磁盘中,当再次接收到相同请求时,直接从缓存中读取并返回,减少对后…...
JavaScript——前端基础3
目录 JavaScript简介 优点 可做的事情 运行 第一个JavaScript程序 搭建开发环境 安装的软件 操作 在浏览器中使用JavaScript文件 分离JS 使用node运行JS文件 语法 变量与常量 原生数据类型 模板字符串 字符串的内置方法 数组 对象 对象数组和JSON if条件语…...
操作系统知识点12
1.在操作系统的结构设计中,采用层次结构的操作系统其最大优点是把整体问题局部化 2.非特权指令是指操作系统和用户均可以使用的指令 3.向处理器发出的中断信号称为中断请求 4.轮转法RR是单纯基于时间片考虑的 5.当进程处于就绪状态时,表示进程已获得…...
(七)趣学设计模式 之 适配器模式!
目录 一、 啥是适配器模式?二、 为什么要用适配器模式?三、 适配器模式的实现方式1. 类适配器模式(继承插座 👨👩👧👦)2. 对象适配器模式(插座转换器 🔌…...
RBF神经网络+NSGAII多目标优化算法,工艺参数优化、工程设计优化(Matlab)
目录 效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.RBF神经网络NSGAII多目标优化算法(Matlab完整源码和数据) 多目标优化是指在优化问题中同时考虑多个目标的优化过程。在多目标优化中,通常存在多个冲突的目标,即改善一…...
IP段转CIDR:原理Java实现
🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…...
工会考试知识点分享
工会考试涵盖工会基础知识、劳动法及相关法律法规、时政等内容,以下是一些常见的知识点分享: 工会基础知识 工会的性质与职能:工会是职工自愿结合的工人阶级的群众组织,基本职责是维护职工合法权益,同时还具有组织、…...
Java进阶——Stream流以及常用方法详解
本文详细介绍了 Java Stream 流的重要知识点。包括数据源与操作分离(不存储数据,不可复用)、惰性求值与短路优化;以及流的创建方式,如集合创建、数组 / 值创建、文件创建;然后介绍中间操作,像过…...
数据如何安全“过桥”?分类分级与风险评估,守护数据流通安全
信息化高速发展,数据已成为企业的核心资产,驱动着业务决策、创新与市场竞争力。随着数据开发利用不断深入,常态化的数据流通不仅促进了信息的快速传递与共享,还能帮助企业快速响应市场变化,把握商业机遇,实…...
Kubernetes LimitRange对于pod 的 update 事件会不会处理?
在 Kubernetes 中,LimitRange 是一个用于限制命名空间中 Pod 或容器资源使用的对象。它主要限制资源请求(requests)和资源限制(limits),如 CPU 和内存。LimitRange 影响的是 Pod 或容器的创建(c…...
服务器禁止操作汇总(Server Prohibits 0peration Summary)
服务器禁止操作汇总 一、禁忌操作TOP10 1. 直接断电关机 💥 血泪案例:某物流公司运维拔电源强制关机,导致数据库事务中断,20万订单状态丢失。 📌 技术解析: • 直接断电可能引发: ✅ 文件系统…...
Android Studio 新版本Gradle通过JitPack发布Maven仓库示例
发布本地仓库示例:https://blog.csdn.net/loutengyuan/article/details/145938967 以下是基于 Android Studio 24.2.2(Gradle 8.10.2 AGP 8.8.0 JDK17) 的通过JitPack发布Maven仓库示例,包含aar和jar的不同配置: 1.…...
Spring Boot 测试:单元、集成与契约测试全解析
一、Spring Boot 分层测试策略 Spring Boot 应用采用经典的分层架构,不同层级的功能模块对应不同的测试策略,以确保代码质量和系统稳定性。 Spring Boot 分层架构: Spring Boot分层架构 A[客户端] -->|HTTP 请求| B[Controller 层] …...
一个便捷的web截图库~
随着时间的发展,前端开发的范围越来越广,能够实现的功能也越来越多,要实现的功能也五花八门,今天就给大家介绍一个web截图库,让前端也能实现截图功能—— js-web-screen-shot js-web-screen-shot js-web-screen-shot 是一个基于 …...
【HTML— 快速入门】HTML 基础
准备工作 vscode下载 百度网盘 Subline Text 下载 Sublime Text下载 百度网盘 vscode 下载 Sublime Text 是一款轻量好用的文本编辑器,我们在写前端代码时,使用 Sublime Text 打开比使用记事本打开,得到的代码体验更好,比 vscode…...
github操作
在本地创建一个 Git 仓库并将其上传到 GitHub 的整个流程可以分为以下几个步骤。以下是详细的说明和对应的命令: 1. 安装 Git 确保你的系统已经安装了 Git。如果未安装,可以通过以下方式安装: Windows: 下载 Git for Windows 并安装。macOS…...
基于ArcGIS Pro、R、INVEST等多技术融合下生态系统服务权衡与协同动态分析实践应用
文章目录 前言第一章、生态系统服务第二章、平台基础一、ArcGIS Pro介绍二、R环境配置与基础操作 第三章、数据获取与预处理第四章、生态系统服务估算第五章、生态系统服务权衡与协同第六章、空间统计分析第七章、论文撰写与图表复现了解更多 ————————————————…...
Python Cookbook-2.18 从指定的搜索路径寻找文件
任务 给定一个搜索路径(一个描述目录信息的字符串),需要根据这个路径和请求的文件名找到第一个符合要求的文件。 解决方案 需要循环指定的搜索路径中的目录: import os def search_file(filename,search path,pathsepos.pathsep): """…...
遗传算法详解及在matlab中的使用
遗传算法分析 一 遗传算法概述1 算法概念2 基本特点3 启发式算法 二 原理与方法1 实现步骤1.1 个体编码1.2 种群初始化1.3 适应度计算1.4 选择运算1.5 交叉运算1.6 变异运算 2 总结 三 应用实例1 GA工具使用教程2 设置目标函数3 搜索最小值4 搜索最大值 一 遗传算法概述 本章简…...
智能AI替代专家系统(ES)、决策支持系统(DSS)?
文章目录 前言一、专家系统(ES)是什么?二、决策支持系统(DSS)是什么?1.决策支持系统定义2.决策系统的功能与特点3.决策支持系统的组成 三、专家系统(ES)与决策支持系统(D…...
活在AI原生时代的05后,开始用AI创业
大家好,我是Shelly,一个专注于输出AI工具和科技前沿内容的AI应用教练,体验过300款以上的AI应用工具。关注科技及大模型领域对社会的影响10年。关注我一起驾驭AI工具,拥抱AI时代的到来。 人工智能&AIGC术语100条 Shelly聊AI-重…...
【官方配图】win10/win11 安装cuda 和 cudnn
文章目录 参考资料1.安装cuda toolkit1. 下载安装包2.安装验证 2. 安装cudnn下载cudnn安装包安装cudnn安装后的配置 参考资料 官方nvidia安装cuda官方nvidia安装cudnn 1.安装cuda toolkit 1. 下载安装包 下载地址 https://developer.nvidia.com/cuda-downloads?target_osW…...
释放微软bing的力量:深度剖析其主要功能
在浩瀚无垠的互联网海洋中,搜索引擎就如同指南针,引领我们找到所需要的信息。微软必应凭借其一系列强大功能,在搜索引擎领域脱颖而出,成为极具竞争力的一员。在这篇博客文章中,我们将深入探讨微软必应的主要功能,这些功能使其独具特色,成为全球用户的得力工具。 1. 智能…...
【Nginx 】Nginx 部署前端 vue 项目
1. 项目打包 1.1 安装依赖 在项目部署之前,确保开发环境中已安装Node.js和npm,这是运行Vue项目的基础。通过执行npm install命令,可以安装项目所需的所有依赖。这一步是打包流程的前提,确保了后续编译的顺利进行。 根据npm的官…...
DO-254航空标准飞行器电机控制器设计注意事项
DO-254航空标准飞行器电机控制器设计注意事项 1.核心要求1.1 设计保证等级(DAL)划分1.2生命周期管理1.3验证与确认2.电机控制器硬件设计的关键注意事项2.1需求管理与可追溯性2.2冗余与容错设计2.3验证与确认策略2.4元器件选型与管理2.5环境适应性设计2.6文档与配置管理3.应用…...
C# Unity 唐老狮 No.3 模拟面试题
本文章不作任何商业用途 仅作学习与交流 安利唐老狮与其他老师合作的网站,内有大量免费资源和优质付费资源,我入门就是看唐老师的课程 打好坚实的基础非常非常重要: Unity课程 - 游习堂 - 唐老狮创立的游戏开发在线学习平台 - Powered By EduSoho 如果你发现了文章内特殊的字体…...
视频推拉流EasyDSS点播平台云端录像播放异常问题的排查与解决
EasyDSS视频直播点播平台是一个功能全面的系统,提供视频转码、点播、直播、视频推拉流以及H.265视频播放等一站式服务。该平台与RTMP高清摄像头配合使用,能够接收无人机设备的实时视频流,实现无人机视频推流直播和巡检等多种应用。 最近&…...
【分布式锁通关指南 05】通过redisson实现分布式锁
引言 在上个篇章中,我们通过redis手撸了一套分布式锁,但是最后也提到了它依然存在不完美的地方。那么有没有更简单和靠谱的实现方式。当然有,在本篇章中,我们将讲解如何使用redisson框架实现分布式锁以及理解它的源码。 什么是red…...
路劲家园大学:教育创新赋能社区人文生态建设
2025年2月10日至13日,路劲家园大学集训活动成功举办,众多教育领域学者与一线教师齐聚,通过专题研讨、教学展示、技术探索等多元形式,为家园大学注入全新活力,探索教育创新发展之路。 双院揭牌 构建社区美育新生态 集训…...