当前位置: 首页 > article >正文

用Python的pywifi库写个WiFi密码测试工具,顺便聊聊网络安全那些事儿

Python实战用pywifi构建WiFi安全测试工具的技术解析在数字化生活高度普及的今天WiFi网络已成为我们日常工作和生活的基础设施。作为开发者理解WiFi连接原理并掌握相关安全知识不仅能提升技术能力也能更好地保护自身网络安全。本文将带领读者从零开始构建一个基于Python pywifi库的WiFi连接测试工具同时深入探讨网络安全的核心概念。1. 开发环境准备与pywifi基础要开始我们的WiFi安全测试工具开发首先需要搭建合适的开发环境。Python 3.6及以上版本是pywifi库的理想运行环境同时建议使用虚拟环境来管理项目依赖。核心依赖安装pip install pywifipywifi库是Python中操作无线网卡的核心工具它提供了跨平台的WiFi操作接口。在开始编码前我们需要理解几个关键概念SSIDWiFi网络的公开名称标识BSSID接入点的MAC地址认证算法包括OPEN、SHARED等不同类型加密类型如WPA、WPA2、WEP等网卡状态检查代码示例import pywifi from pywifi import const wifi pywifi.PyWiFi() iface wifi.interfaces()[0] print(f网卡状态: {已连接 if iface.status() const.IFACE_CONNECTED else 未连接}) print(f可用网卡: {iface.name()})注意不同操作系统下网卡操作可能需要管理员权限在Linux/macOS上运行脚本时可能需要sudo2. WiFi扫描功能实现构建测试工具的第一步是实现WiFi网络扫描功能这能帮助我们获取周围可用的无线网络信息。pywifi提供了简洁的接口来实现这一功能。增强型WiFi扫描实现def scan_wifi_networks(interface): 扫描周围WiFi网络并返回详细信息 interface.scan() time.sleep(5) # 等待扫描完成 scan_results interface.scan_results() networks [] for result in scan_results: network { ssid: result.ssid, bssid: result.bssid, signal: result.signal, auth: result.akm, cipher: result.cipher } networks.append(network) return sorted(networks, keylambda x: x[signal], reverseTrue)网络信息解析要点信号强度(signal)数值越大表示信号越好典型范围在-90dBm到-30dBm之间认证类型(auth)常见值包括const.AKM_TYPE_NONE开放网络const.AKM_TYPE_WPAPSKWPA-PSKconst.AKM_TYPE_WPA2PSKWPA2-PSK加密方式(cipher)常见值有const.CIPHER_TYPE_NONE无加密const.CIPHER_TYPE_WEPWEP加密const.CIPHER_TYPE_TKIPTKIP加密const.CIPHER_TYPE_CCMPAES加密(CCMP)WiFi信息展示表格字段说明典型值SSID网络名称HomeWiFiBSSID接入点MAC地址a4:56:02:1f:3b:cdSignal信号强度(dBm)-67Auth认证类型const.AKM_TYPE_WPA2PSKCipher加密方式const.CIPHER_TYPE_CCMP3. WiFi连接测试核心实现连接测试是工具的核心功能我们需要实现完整的连接流程包括配置文件创建、连接尝试和状态检查。安全连接测试函数def test_connection(interface, ssid, password, timeout5): 测试WiFi连接是否成功 # 创建配置文件 profile pywifi.Profile() profile.ssid ssid profile.auth const.AUTH_ALG_OPEN profile.akm.append(const.AKM_TYPE_WPA2PSK) profile.cipher const.CIPHER_TYPE_CCMP profile.key password # 移除所有已有配置 interface.remove_all_network_profiles() # 添加新配置 tmp_profile interface.add_network_profile(profile) # 尝试连接 interface.connect(tmp_profile) # 等待连接结果 start_time time.time() while time.time() - start_time timeout: if interface.status() const.IFACE_CONNECTED: return True time.sleep(0.1) return False连接测试最佳实践超时设置合理的超时时间(3-5秒)可以平衡测试准确性和效率错误处理应捕获并处理可能出现的异常如网卡不可用等状态检查连接后应验证实际网络连通性而不仅是接口状态资源清理测试完成后应断开连接并清理配置文件连接状态检查表状态常量值说明const.IFACE_DISCONNECTED0接口已断开const.IFACE_SCANNING1正在扫描const.IFACE_INACTIVE2接口未激活const.IFACE_CONNECTING3正在连接const.IFACE_CONNECTED4已连接4. 安全测试与防御机制在开发WiFi测试工具时我们必须充分考虑安全性和合法性。本节将探讨如何构建一个符合伦理的安全测试框架。合法测试原则明确授权只测试自己拥有或获得明确授权的网络有限测试避免对网络造成实质性影响数据保护不记录或泄露任何测试数据合规使用工具仅用于安全研究和学习目的安全测试防护机制实现class SafetyGuard: 安全测试防护机制 def __init__(self): self.max_attempts 3 # 最大尝试次数 self.delay 60 # 失败后延迟(秒) self.attempts 0 # 当前尝试次数 def check_authorization(self, ssid): 检查测试授权 if not self._is_owned_network(ssid): raise PermissionError(f未授权测试网络: {ssid}) def record_attempt(self, success): 记录尝试并实施防护 self.attempts 0 if success else 1 if self.attempts self.max_attempts: print(f达到最大尝试次数暂停{self.delay}秒) time.sleep(self.delay) self.attempts 0 def _is_owned_network(self, ssid): 验证网络所有权 # 这里应实现实际的验证逻辑 return True # 示例中默认返回True安全测试检查清单[ ] 获取网络所有者的书面测试授权[ ] 在非生产环境中进行测试[ ] 限制测试时间和频率[ ] 使用专用测试设备[ ] 测试后恢复网络原状5. 密码强度测试与安全建议密码安全性是WiFi网络安全的第一道防线。我们可以通过分析常见弱密码模式来提升自身网络安全意识。常见弱密码模式连续数字如12345678、00000000等简单重复如aaaaaaa、abcdabcd等字典单词直接使用英文单词或常见组合个人信息使用生日、电话号码等个人信息短密码长度不足8位的密码密码强度评估函数def evaluate_password_strength(password): 评估密码强度 if len(password) 8: return 非常弱 # 检查字符多样性 has_upper any(c.isupper() for c in password) has_lower any(c.islower() for c in password) has_digit any(c.isdigit() for c in password) has_special any(not c.isalnum() for c in password) complexity sum([has_upper, has_lower, has_digit, has_special]) if complexity 1: return 弱 elif complexity 2: return 中等 elif complexity 3: return 强 else: return 非常强WiFi安全配置建议使用WPA2/WPA3加密避免使用已淘汰的WEP加密设置复杂密码至少12位包含大小写字母、数字和特殊符号关闭WPS功能防止PIN码暴力破解定期更换密码特别是怀疑可能泄露时启用MAC过滤限制允许连接的设备隐藏SSID减少被扫描发现的机会6. 图形界面开发与工具集成为了让工具更易用我们可以使用Tkinter为其添加图形界面。以下是关键组件的实现方法。主界面框架代码import tkinter as tk from tkinter import ttk, messagebox class WiFiToolApp: def __init__(self, root): self.root root self.root.title(WiFi安全测试工具) self.setup_ui() self.wifi pywifi.PyWiFi() self.iface self.wifi.interfaces()[0] def setup_ui(self): 设置界面组件 # 扫描按钮 self.scan_btn ttk.Button( self.root, text扫描网络, commandself.scan_networks ) self.scan_btn.pack(pady5) # 网络列表 self.tree ttk.Treeview(self.root, columns(ssid, bssid, signal)) self.tree.heading(#0, textID) self.tree.heading(ssid, textSSID) self.tree.heading(bssid, textBSSID) self.tree.heading(signal, text信号强度) self.tree.pack(filltk.BOTH, expandTrue) # 测试区域 self.test_frame ttk.LabelFrame(self.root, text连接测试) self.test_frame.pack(filltk.X, padx5, pady5) ttk.Label(self.test_frame, text密码:).grid(row0, column0) self.pwd_entry ttk.Entry(self.test_frame, show*) self.pwd_entry.grid(row0, column1) self.test_btn ttk.Button( self.test_frame, text测试连接, commandself.test_connection ) self.test_btn.grid(row0, column2, padx5) def scan_networks(self): 扫描网络并更新列表 self.tree.delete(*self.tree.get_children()) networks scan_wifi_networks(self.iface) for i, net in enumerate(networks): self.tree.insert(, end, textstr(i1), values(net[ssid], net[bssid], net[signal])) def test_connection(self): 测试连接按钮回调 selected self.tree.focus() if not selected: messagebox.showerror(错误, 请先选择要测试的网络) return ssid self.tree.item(selected)[values][0] password self.pwd_entry.get() if not password: messagebox.showerror(错误, 请输入密码) return try: success test_connection(self.iface, ssid, password) if success: messagebox.showinfo(成功, 连接测试成功) else: messagebox.showerror(失败, 连接测试失败) except Exception as e: messagebox.showerror(错误, str(e))界面优化建议添加进度指示长时间操作时显示进度实现多语言支持使用gettext模块添加主题切换支持亮/暗模式保存配置使用configparser保存用户设置日志记录记录重要操作便于排查问题7. 高级功能与扩展思路基础功能实现后我们可以考虑添加一些高级特性来增强工具的实用性。可能的扩展方向网络质量测试测量连接速度和延迟信号强度分析绘制信号强度随时间变化图自动诊断检测常见网络配置问题多网卡支持同时管理多个无线接口配置文件管理保存多个网络配置信号强度监测示例import matplotlib.pyplot as plt from collections import deque class SignalMonitor: 信号强度监测器 def __init__(self, max_samples100): self.samples deque(maxlenmax_samples) self.timestamps deque(maxlenmax_samples) def add_sample(self, signal_strength): 添加信号强度样本 self.samples.append(signal_strength) self.timestamps.append(time.time()) def plot_signal(self): 绘制信号强度变化图 if not self.samples: return plt.figure(figsize(10, 4)) plt.plot(self.timestamps, self.samples, b-) plt.title(WiFi信号强度变化) plt.xlabel(时间) plt.ylabel(信号强度(dBm)) plt.grid(True) plt.show()网络诊断检查项IP地址获取检查是否成功获取有效IPDNS解析验证域名解析是否正常网关连通性ping测试默认网关互联网访问测试常见网站的连通性MTU设置检查是否存在MTU不匹配问题8. 性能优化与生产级考量要让工具达到生产级质量我们需要关注性能、稳定性和错误处理等方面。性能优化技巧异步操作使用多线程避免界面冻结连接池复用网络配置减少开销缓存机制缓存扫描结果减少重复操作批量测试优化密码测试顺序提高效率资源清理确保及时释放系统资源异步测试实现示例import threading class AsyncWiFiTester: 异步WiFi测试器 def __init__(self, callback): self.callback callback self.running False def start_test(self, ssid, password_list): 启动异步测试 if self.running: return False self.running True thread threading.Thread( targetself._run_tests, args(ssid, password_list), daemonTrue ) thread.start() return True def _run_tests(self, ssid, password_list): 实际测试运行 wifi pywifi.PyWiFi() iface wifi.interfaces()[0] for password in password_list: if not self.running: break try: success test_connection(iface, ssid, password) self.callback(ssid, password, success) except Exception as e: self.callback(ssid, password, False, str(e)) self.running False错误处理清单[ ] 网卡不可用或未启用[ ] 驱动程序问题[ ] 权限不足[ ] 系统资源限制[ ] 网络管理器冲突[ ] 硬件兼容性问题9. 跨平台兼容性处理不同操作系统对无线网络的管理方式存在差异我们需要处理这些平台特性。各平台注意事项平台网卡管理权限要求特殊考虑WindowsNDIS API管理员权限防病毒软件可能拦截Linuxnl80211root权限NetworkManager冲突macOSCoreWLAN普通用户系统完整性保护平台检测与适配代码import platform def get_platform_specifics(): 获取平台特定配置 system platform.system().lower() if system windows: return { scan_timeout: 5, connect_timeout: 10, requires_admin: True } elif system linux: return { scan_timeout: 8, connect_timeout: 15, requires_admin: True } elif system darwin: return { scan_timeout: 3, connect_timeout: 5, requires_admin: False } else: return { scan_timeout: 5, connect_timeout: 8, requires_admin: False }兼容性测试矩阵功能Windows 10Ubuntu 20.04macOS Big Sur网卡枚举✓✓✓WiFi扫描✓✓✓连接测试✓✓✓断开连接✓✓✓状态检测✓✓✓10. 安全研究与合法测试框架作为负责任的开发者和安全研究人员我们必须建立合法的测试框架和伦理准则。安全研究原则知情同意确保所有测试都获得明确授权最小影响测试不应影响网络正常使用数据最小化仅收集必要信息及时删除测试数据透明度向网络所有者公开测试方法和结果责任对测试可能造成的任何影响负责伦理测试框架要素授权验证正式的文件记录和确认范围界定明确的测试边界和限制时间窗口约定的测试时间段应急计划出现问题时的恢复措施报告机制发现问题的反馈流程合法测试文档模板# WiFi安全测试授权书 **测试方信息** - 姓名/机构____________________ - 联系方式____________________ **网络所有者信息** - 姓名/机构____________________ - 联系方式____________________ - 网络标识(SSID)____________________ **测试授权** 本人作为上述网络的所有者或合法授权代表在此授权上述测试方在以下条件下对指定网络进行安全测试 1. 测试时间____年____月____日至____年____月____日 2. 测试范围仅限密码强度测试和连接验证 3. 测试方法____________________ 4. 数据处理所有测试数据将在测试完成后24小时内删除 **免责声明** 测试方承诺将采取一切合理措施避免对网络造成影响但对测试过程中可能出现的意外情况不承担责任。 **签署** 网络所有者签名__________ 日期__________ 测试方签名__________ 日期__________在实际项目中我们还需要考虑日志记录、测试报告生成等功能以及如何将工具集成到更大的安全测试流程中。这些高级主题超出了本文范围但值得进一步探索。

相关文章:

用Python的pywifi库写个WiFi密码测试工具,顺便聊聊网络安全那些事儿

Python实战:用pywifi构建WiFi安全测试工具的技术解析 在数字化生活高度普及的今天,WiFi网络已成为我们日常工作和生活的基础设施。作为开发者,理解WiFi连接原理并掌握相关安全知识,不仅能提升技术能力,也能更好地保护自…...

别再死记硬背了!用5分钟动画图解SpringMVC的Model数据流转(附源码)

5分钟动画拆解:SpringMVC数据流转的幕后剧场 想象一下你正在导演一场话剧——前台演员(用户界面)需要与后台道具组(服务器数据)无缝配合。SpringMVC的Model系统就像这场演出的幕后调度员,今天我们就用动画…...

CardEditor:桌游设计师的批处理卡牌生成神器,让创意批量落地

CardEditor:桌游设计师的批处理卡牌生成神器,让创意批量落地 【免费下载链接】CardEditor 一款专为桌游设计师开发的批处理数值填入卡牌生成器/A card batch generator specially developed for board game designers 项目地址: https://gitcode.com/g…...

Windows软件彻底卸载终极指南:Bulk Crap Uninstaller专业级批量清理方案

Windows软件彻底卸载终极指南:Bulk Crap Uninstaller专业级批量清理方案 【免费下载链接】Bulk-Crap-Uninstaller Remove large amounts of unwanted applications quickly. 项目地址: https://gitcode.com/gh_mirrors/bu/Bulk-Crap-Uninstaller 在Windows系…...

5分钟学会音频解锁:如何快速解密任何加密音乐文件

5分钟学会音频解锁:如何快速解密任何加密音乐文件 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库: 1. https://github.com/unlock-music/unlock-music ;2. https://git.unlock-music.dev/um/web 项目地址: https://g…...

B站字幕下载终极指南:3分钟掌握高效字幕处理技巧

B站字幕下载终极指南:3分钟掌握高效字幕处理技巧 【免费下载链接】BiliBiliCCSubtitle 一个用于下载B站(哔哩哔哩)CC字幕及转换的工具; 项目地址: https://gitcode.com/gh_mirrors/bi/BiliBiliCCSubtitle 还在为B站视频的字幕下载而烦恼吗?&#…...

别再只盯着原理了!用TensorRT INT8量化你的YOLOv5模型,实测推理速度翻倍(附完整C++代码)

实战指南:用TensorRT INT8量化加速YOLOv5模型推理(附完整C实现) 当你在深夜调试模型时,是否经历过这样的场景——模型精度达标了,但推理速度却像蜗牛爬行?部署到边缘设备时,显存占用直接爆表&am…...

从GROMACS轨迹到结合自由能:gmx_MMPBSA终极指南

从GROMACS轨迹到结合自由能:gmx_MMPBSA终极指南 【免费下载链接】gmx_MMPBSA gmx_MMPBSA is a new tool based on AMBERs MMPBSA.py aiming to perform end-state free energy calculations with GROMACS files. 项目地址: https://gitcode.com/gh_mirrors/gm/gmx…...

**发散创新:基于Flink的实时流处理架构设计与实战优化**在现代大数据系统中,**实时流处理已成为核心能力

发散创新:基于Flink的实时流处理架构设计与实战优化 在现代大数据系统中,实时流处理已成为核心能力之一。无论是金融风控、物联网监控还是用户行为分析,都依赖于对海量数据的秒级响应。Apache Flink 作为当前最主流的开源流处理框架之一&…...

猫抓Cat-Catch:3步解决网页视频下载难题的终极方案

猫抓Cat-Catch:3步解决网页视频下载难题的终极方案 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 当我们浏览网页时,总会遇…...

Genesis文件导出避坑指南:如何正确导出Panel和钻孔层(附常见错误解决方案)

Genesis文件导出避坑指南:如何正确导出Panel和钻孔层(附常见错误解决方案) 在PCB设计领域,Genesis作为一款专业的CAM软件,其文件导出功能直接影响着后续生产环节的顺利进行。许多工程师在项目交付前的关键时刻&#x…...

AD9833信号发生器DIY:从原理图绘制到PCB打样,打造你的桌面级测试工具

AD9833信号发生器DIY:从原理图绘制到PCB打样,打造你的桌面级测试工具 在电子实验室里,一台可靠的信号发生器是不可或缺的基础设备。无论是调试射频电路、测试滤波器响应,还是验证传感器性能,都需要精确可控的信号源。商…...

**发散创新:基于生成式AI的Python代码自动补全工具实战**在现代软件开发中,**提升编码效率**已成为每个开发

发散创新:基于生成式AI的Python代码自动补全工具实战 在现代软件开发中,提升编码效率已成为每个开发者关注的核心问题之一。近年来,随着生成式AI技术(如大语言模型)的迅猛发展,传统IDE插件正在被重新定义—…...

LaserGRBL:如何用开源软件实现专业级激光雕刻控制

LaserGRBL:如何用开源软件实现专业级激光雕刻控制 【免费下载链接】LaserGRBL Laser optimized GUI for GRBL 项目地址: https://gitcode.com/gh_mirrors/la/LaserGRBL LaserGRBL是一款专为激光雕刻和切割优化的GRBL控制器Windows图形界面软件,为…...

告别原生下拉框!用xm-select.js为你的Layui项目快速集成强大多选功能

告别原生下拉框!用xm-select.js为你的Layui项目快速集成强大多选功能 在后台管理系统开发中,表单交互的流畅度直接影响用户体验。Layui作为一款经典的前端框架,其原生下拉组件在单选场景下表现尚可,但面对多选、搜索过滤等进阶需求…...

从SD卡分区到上电启动:详解Exynos 4412开发板的完整启动流程与手动烧写

从SD卡分区到上电启动:详解Exynos 4412开发板的完整启动流程与手动烧写 当一块搭载Exynos 4412的开发板首次通电时,芯片内部会执行一系列精密编排的启动流程。这个看似瞬间完成的过程,实际上包含了从硬件初始化到操作系统加载的多个关键阶段。…...

Mermaid Live Editor:在线实时图表编辑的终极免费解决方案

Mermaid Live Editor:在线实时图表编辑的终极免费解决方案 【免费下载链接】mermaid-live-editor Edit, preview and share mermaid charts/diagrams. New implementation of the live editor. 项目地址: https://gitcode.com/GitHub_Trending/me/mermaid-live-ed…...

ESP8266-01S联网避坑大全:关于STA模式、TCP连接和透传的那些“反直觉”设定

ESP8266-01S联网避坑大全:关于STA模式、TCP连接和透传的那些“反直觉”设定 当你第一次拿到ESP8266-01S这个小小的Wi-Fi模块时,可能会被它强大的功能所吸引。但很快,你就会发现这个看似简单的模块背后隐藏着许多让人困惑的"反直觉"…...

【无线传感器】使用 MATLAB和 XBee连续监控温度传感器无线网络研究附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室👇 关注我领取海量matlab电子书和…...

如何快速将B站缓存视频转换为MP4:m4s-converter终极指南

如何快速将B站缓存视频转换为MP4:m4s-converter终极指南 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否曾经在B站缓存了珍贵的…...

融合柯西变异与动态权重的蝴蝶优化算法性能跃迁

1. 蝴蝶优化算法的瓶颈与突破方向 蝴蝶优化算法(BOA)作为一种模拟自然界蝴蝶觅食行为的群体智能算法,自提出以来就在工程优化、机器学习参数调优等领域展现出独特优势。但我在实际使用中发现,传统BOA存在两个明显短板:一是容易陷入局部最优解…...

MATLAB小白也能看懂的电场仿真:手把手教你用代码画三电荷电场线与等势面

MATLAB零基础实战:三电荷系统电场可视化全解析 刚接触电磁场仿真的同学往往会被复杂的公式和编程吓退,但今天我要分享的这套方法,能让没有任何MATLAB基础的小白也能轻松绘制出专业级的电场分布图。我们以经典的正三角形三电荷系统为例&#…...

从网卡驱动到主站线程:深入IgH EtherCAT主站的启动与绑定流程

从网卡驱动到主站线程:深入IgH EtherCAT主站的启动与绑定流程 在工业自动化领域,EtherCAT以其卓越的实时性能和高效的通信机制成为主流现场总线协议之一。作为开源EtherCAT主站实现,IgH EtherCAT Master凭借其稳定性和灵活性赢得了众多工程师…...

5个必学技巧:用OBS StreamFX插件瞬间提升直播画面质感

5个必学技巧:用OBS StreamFX插件瞬间提升直播画面质感 【免费下载链接】obs-StreamFX StreamFX is a plugin for OBS Studio which adds many new effects, filters, sources, transitions and encoders! Be it 3D Transform, Blur, complex Masking, or even custo…...

Visual C++ Redistributable AIO:一站式解决Windows运行时依赖问题的终极方案

Visual C Redistributable AIO:一站式解决Windows运行时依赖问题的终极方案 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 还在为"VCRUNTIME14…...

用RT-Thread BK7252开发板,5分钟搞定WiFi OTA升级(保姆级图文教程)

5分钟玩转BK7252开发板:WiFi OTA升级实战指南 第一次拿到BK7252开发板时,最让我惊喜的不是它丰富的板载资源,而是那个看似简单却极其实用的OTA升级功能。想象一下,当你的设备部署在难以触及的角落,或是需要频繁迭代固件…...

TP4056(x) 锂电线性充电电路设计实战指南

1. TP4056(x) 芯片基础解析 第一次接触TP4056这颗芯片时,我正为一个便携式设备项目寻找可靠的锂电池充电方案。当时被它"无需外接MOSFET和二极管"的特性吸引,实测后发现这确实是新手友好的设计利器。作为线性充电IC,TP4056系列通过…...

别再被‘平均’骗了!用Python手把手教你计算置信区间,看懂数据背后的不确定性

别再被‘平均’骗了!用Python手把手教你计算置信区间,看懂数据背后的不确定性 当我们看到"用户平均停留时长提升15%"或"新版本点击率增长20%"时,这些数字真的可靠吗?作为每天要处理AB测试结果的数据从业者&am…...

FanControl中文设置终极指南:5分钟轻松实现免费风扇控制软件本地化

FanControl中文设置终极指南:5分钟轻松实现免费风扇控制软件本地化 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub…...

Audiveris:10分钟将纸质乐谱转换为可编辑数字格式的开源神器

Audiveris:10分钟将纸质乐谱转换为可编辑数字格式的开源神器 【免费下载链接】audiveris Latest generation of Audiveris OMR engine 项目地址: https://gitcode.com/gh_mirrors/au/audiveris 你是否曾为整理大量纸质乐谱而烦恼?是否希望将那些珍…...