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

自动连接校园网wifi脚本实践(自动网页认证)

目录

  • 起因
  • 执行步骤
    • 分析校园网登录逻辑
      • 如何判断当前是否处于未登录状态?
    • 书写代码
    • 打包
    • 设置开机自动启动

起因

我们一般通过远程控制的方式访问实验室电脑,但是最近实验室老是断电,但重启后也不会自动连接校园网账户认证,远程工具(向日葵、Todesk等)也就用不了,就想着用python做一个自动认证的脚本,下面是实践过程。

注:本脚本只是用于自动做校园网账户的认证(在已经连着校园网的情况下才能验证),并不是让windows去自动连接某个校园网wifi。

执行步骤

分析校园网登录逻辑

先登录校园网认证网页,先点击F12,选中网络并勾选保存日志
在这里插入图片描述
再输入账户密码,点击login,看看发了哪些请求(一般netword的前几个比较重要,后面的都是资源文件)
在这里插入图片描述
这里发现发了两个请求,第一个post请求,第二个get请求(每个学校的不一样,HHU的可以直接用本教程方法)
第一个是post请求
在这里插入图片描述
点击payload查看post请求携带的数据,发现里面包含了自己的校园网账户和密码
在这里插入图片描述
第二个是get请求
在这里插入图片描述
复制上面的request URL到浏览器,发现就是可以访问的认证界面。

总结:点击login按钮后,我的密码是先通过一个post请求提交到服务器,然后再通过一个get请求去实现登录的。

那脚本要做的事情就是:当发现当前处于未登录状态时,要模拟浏览器的行为,先发一个post请求,请求header和data都要和浏览器上的内容对应,然后再发一个get请求就可以了。(有点像爬虫做的事情)

如何判断当前是否处于未登录状态?

一般提交get请求时,当前已经登录和为登录状态得到html文档中的标签内容是不一样的。这里我们在已登录状态下,按F12,再按ctrl+F查找下的内容,发现果然有标识
在这里插入图片描述
也就是说,当get请求结果返回的title标签内容是“登录成功”时,当前就已经处于登录状态了,此时不需要再进行认证,如果不是tittle标签内容不是“登录成功”,则说明当前未登录,需要发请求进行认证。

书写代码

梳理一下脚本要实现的内容:

  1. 写一个死循环,不断判断当前是否处于登录状态:直接发get请求,如果返回的tittle为“登录成功”,则为已登录状态。
while(True):print("自动联网脚本开始运行...")# 请求校园网urlresponse = request.urlopen(get_URL)html = response.read()# 获取tittle元素内容res = re.findall('<title>(.*)</title>', html.decode(encoding="GBK", errors="strict"))print('res:', res)title = ''if len(res) == 0:print("访问",get_URL,"失败,请检查请求地址!")passelse:title = res[0]print("title:",title)
  1. 否则的话,就模拟浏览器的行为,给服务器发一个post请求(设置好header和data,示例如下),然后再发一个get请求进行认证。
    2.1设置header
    在这里插入图片描述
    变成如下

        # 设置post的请求头,浏览器点击F12,在Netword中选中post请求,点击Headers、request header面板中查看header = {"Accept": "*/*","Accept-Encoding": "gzip, deflate","Accept-Language": "zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7","Connection": "keep-alive","Content-Length": "762","Content-Type": "application/x-www-form-urlencoded; charset=UTF-8","Cookie": "EPORTAL_COOKIE_DOMAIN=false; EPORTAL_COOKIE_USERNAME=XXXXX; EPORTAL_COOKIE_SERVER=%E4%B8%AD%E5%9%E7%A7%BB%E5%8A%A8(CMCC%20NET); EPORTAL_COOKIE_SERVER_NAME=%E4%B8%AD%E5%9B%BA7%BB%E5%8A%A8(CMCC%20NET); EPORTAL_COOKIE_SAVEPASSWORD=true; EPORTAL_COOKIE_OPERATORPWD=; EPORTAL_COOKIE_NEWV=true; EPORTAL_COOKIE_PASSWORD=1e485d5861f50092df261f37ca6218c4d8675e6daf226f84489f5bd7ca8339a4e15b27b2fdb3a1ade55b553c96a04a76ad00a31cb46902d356babec2ced138dc40f97b6f5b489274aa5561d24a6f9610caf99e52e5a0d92bf2448819f44dfc2f2c37966d8554aa00fe530d0cbe52a0d4438f2640f04410e865ff3aeff6faf9ff; EPORTAL_AUTO_LAND=; EPORTAL_USER_GROUP=%E5%AD%A6%E7%94%9F; JSESSIONID=8A3372E32254B5F7321DF7B93A4851AA; JSESSIONID=F2C1BB4E6D58762763F36630541B5C38","Host": "eportal.hhu.edu.cn","Origin": "http://eportal.hhu.edu.cn","Referer": "http://eportal.hhu.edu.cn/eportal/index.jsp?wlanuserip=29fc0b608918b04682c9e6c6cf6c1c29&wlanacname=2356e8aa38c836625d91257381aaef57&ssid=ea65e712d7d12a1fb44ec48a1c5072b0&nasip=07ec241dffc0de15d87efe9c07b8c6e0&mac=027a460789bb1e7c9c4acc766c937e6e&t=wireless-v2&url=35e6780db7fde27a90f8986393791ca7b01578112b560bd2","User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36",}
    

    2.2设置data
    在这里插入图片描述
    变成如下

        # 设置post的请求数据,浏览器点击F12,在Netword中选中post请求,点击payload面板中查看data = {"userId": 'XXX',  # 需要根据自己的情况修改"password": '1e485d5861f50092df261f37ca621daf226f84489f5bd5b27b2fdb3a1ade55b553c96a04a76ad00aa31cb4ced138dc40f97b6f5b489274a6f9610caf99e52e5a0d92bf2448819f44dfc2f2c37966d8554ada00fe530d0cbe52a0d4438f2640f04410e865ff3aeff6faf9ff',  # 需要根据自己的情况修改"queryString": 'wlanuserip%3D29fc0b608918b04682c9e6c6cf6c1c29%26wlanacname%3D2356e8aa38c836625d91257381aaef57%26ssid%3Dea65e712d7d12a1fb44ec48a1c5072b0%26nasip%3D07ec241dffc0de15d87efe9c07b8c6e0%26mac%3D027a460789bb1e7c9c4acc766c937e6e%26t%3Dwireless-v2%26url%3D35e6780db7fde27a90f8986393791ca7b01578112b560bd2',"passwordEncrypt": 'true',"operatorPwd": '',"operatorUserId": '',"validcode": '',"service": '%E4%B8%AD%E5%9B%BD%E7%A7%BB%E5%8A%A8(CMCC%20NET)',}
    
  2. 打印状态码,判断是否认证成功。

  3. 休眠一段时间,然后进行下一次循环。

    # 每1h左右检测一次是否成功连接rand = random.uniform(0, 100)print("休眠",int(3600.0 + rand),"s")time.sleep(3600.0 + rand)

另外,由于这个脚本可以放到需要后台运行,看不到print输出。所以增加一个小功能,把日志输出到log文件中去,可以查看脚本运行状态。(各位可以考虑要不要这个功能)

完整代码如下:

import re    # 正则表达式,用于匹配字符
from urllib import request
import requests
import time
import random
import os# 设置日志文件路径
log_file_path = 'log.txt'# 第一个post请求的URL
post_URL = 'http://eportal.hhu.edu.cn/eportal/InterFace.do?method=login'
# 第二个get请求的URL(浏览器可访问的url)
get_URL = 'http://eportal.hhu.edu.cn/eportal/success.jsp?userIndex=3037656332343164666663306465asd3135643837656665396330376238633665305f31302e3139392e34362e38325f3232313630asd37303130303039&keepaliveInterval=0'
while(True):print("自动联网脚本开始运行...")# 请求校园网urlresponse = request.urlopen(get_URL)html = response.read()# 获取tittle元素内容res = re.findall('<title>(.*)</title>', html.decode(encoding="GBK", errors="strict"))print('res:', res)title = ''if len(res) == 0:print("访问",get_URL,"失败,请检查请求地址!")passelse:title = res[0]print("title:",title)# 根据title元素内容判断是否处于已登录状态if title == '登录成功':    print('当前状态为:已登陆成功!')else:print('当前状态为:未登录!')# 设置post的请求头,浏览器点击F12,在Netword中选中post请求,点击Headers、request header面板中查看header = {"Accept": "*/*","Accept-Encoding": "gzip, deflate","Accept-Language": "zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7","Connection": "keep-alive","Content-Length": "762","Content-Type": "application/x-www-form-urlencoded; charset=UTF-8","Cookie": "EPORTAL_COOKIE_DOMAIN=false; EPORTAL_COOKIE_USERNAME=xxx; EPORTAL_COOKIE_SERVER=%E4%B8%AD%E5%9B%BD%A7%BB%E%8A%A8(CMCC%20NET); EPORTAL_COOKIE_SERVER_NAME=%E4%BADE5%9B%D%E7%A7%BB%8A%A8(CMCC%20NET); EPORTAL_COOKIE_SAVEPASSWORD=true; EPORTAL_COOKIE_OPERATORPWD=; EPORTAL_COOKIE_NEWV=true; EPORTAL_COOKIE_PASSWORD=1e485d5861f50092df261f37ca6218c4d8675e6daf226f84489f5bd7ca8339a4e15b27b2fdb3a1ade55b553c96a04a76ad00a31cb46902d356babec2ced138dc40f97b6f5b489274aa5561d24a6f9610caf99e52e5a0d92bf2448819f44dfc2f2c37966d8554aa00fe530d0cbe52a0d4438f2640f04410e865ff3aeff6faf9ff; EPORTAL_AUTO_LAND=; EPORTAL_USER_GROUP=%E5%AD%A6%E7%94%9F; JSESSIONID=8A3372E32254B5F7321DF7B93A4851AA; JSESSIONID=F2C1BB4E6D58762763F36630541B5C38","Host": "eportal.hhu.edu.cn","Origin": "http://eportal.hhu.edu.cn","Referer": "http://eportal.hhu.edu.cn/eportal/index.jsp?wlanuserip=29fc0b608918b04682c9e6c6cf6c1c29&wlanacname=2356e8aa38c836625d91257381aaef57&ssid=ea65e712d7d12a1fb44ec48a1c5072b0&nasip=07ec241dffc0de15d87efe9c07b8c6e0&mac=027a460789bb1e7c9c4acc766c937e6e&t=wireless-v2&url=35e6780db7fde27a90f8986393791ca7b01578112b560bd2","User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36",}# 设置post的请求数据,浏览器点击F12,在Netword中选中post请求,点击payload面板中查看data = {"userId": 'XXX',  # 校园网账号"password": 'XXX',  # 校园网密码(密文)"queryString": 'wlanuserip%3D29fc0b608918b04682c9e6c6cf6c1c29%26wlanacname%3D2356e8aa38c836625d91257381aaef57%26ssid%3Dea65e712d7d12a1fbsa44ec48aa1c5072b0%26nasip%3D07ec241dffc0de15d87efe9c07b8c6e0%26mac%3D027a460789bb1e7c9c4acc7d66c937e6e%26t%3Dwireless-v2%26url%3D35e6780db7fde27a90f8986393791ca7b01578112b560bd2',"passwordEncrypt": 'true',"operatorPwd": '',"operatorUserId": '',"validcode": '',"service": '%E4%B8%AD%E5%9B%BD%E7%A7%BB%E5%8A%A8(CMCC%20NET)',}# 发送post请求(设置好header和data)response = requests.post(post_URL, data, headers=header)uft_str = response.text.encode("iso-8859-1").decode('utf-8')print("post请求状态码{}".format(response))  # 打印状态码# 发送get请求,登录校园网schoolWebLoginURL = get_URLresponse = requests.get(schoolWebLoginURL).status_code  # 直接利用 GET 方式请求这个 URL 同时获取状态码print("get请求状态码{}".format(response))  # 打印状态码# 将print的内容写入log文件with open(log_file_path, 'a', encoding='utf-8') as log_file:log_file.write("自动联网脚本开始运行...\n")log_file.write(f"res: {res}\n")log_file.write(f"title: {title}\n")log_file.write(f"当前状态为: {'已登陆成功' if title == '登录成功' else '未登录'}\n")log_file.write(f"状态码: {response}\n")# 检查文件大小,如果大于1KB则清空文件if os.path.getsize(log_file_path) > 1024:open(log_file_path, 'w').close()# 每1h左右检测一次是否成功连接rand = random.uniform(0, 100)print("休眠",int(3600.0 + rand),"s")time.sleep(3600.0 + rand)

打包

先安装好pyinstall工具

pip install pyinstall

最后用pyinstall工具把.py文件打包成.exe可执行文件

pyinstaller -F 你的脚本.py

注:-F是把所有内容都打包进一个exe文件的意思
在这里插入图片描述
打包后如下
在这里插入图片描述
在dist里面找到可执行程序,双击测试运行。
在这里插入图片描述

设置开机自动启动

win+r,输入shell:startup
在这里插入图片描述
把.exe拖入开机自启动文件夹里面
在这里插入图片描述

参考博客:
Python校园网(网页认证)开机/断网自动连接
手把手教你python实现校园网自动连接
校园自动联网python脚本

相关文章:

自动连接校园网wifi脚本实践(自动网页认证)

目录 起因执行步骤分析校园网登录逻辑如何判断当前是否处于未登录状态&#xff1f; 书写代码打包设置开机自动启动 起因 我们一般通过远程控制的方式访问实验室电脑&#xff0c;但是最近实验室老是断电&#xff0c;但重启后也不会自动连接校园网账户认证&#xff0c;远程工具&…...

HTTP/HTTPS ⑤-CA证书 || 中间人攻击 || SSL/TLS

这里是Themberfue ✨上节课我们聊到了对称加密和非对称加密&#xff0c;实际上&#xff0c;单纯地非对称加密并不能保证数据不被窃取&#xff0c;我们还需要一个更加重要的东西——证书 中间人攻击 通过非对称加密生成私钥priKey和公钥pubKey用来加密对称加密生成的密钥&…...

traceroute原理探究

文章中有截图&#xff0c;看不清的话&#xff0c;可以把浏览器显示比例放大到200%后观看。 linux下traceroute的原理 本文通过抓包观察一下linux下traceroute的原理 环境&#xff1a;一台嵌入式linux设备&#xff0c;内网ip是192.168.186.195&#xff0c;其上有192.168.202.…...

50_Lua垃圾回收

1.Lua垃圾回收机制概述 Lua采用了一种自动内存管理机制,称为垃圾回收(Garbage Collection, GC)。垃圾回收的主要目的是回收程序中不再被使用的内存,从而避免内存泄漏。Lua的垃圾回收器负责回收动态分配的对象,如函数、用户数据、表、字符串、线程、内部结构等。Lua的垃圾…...

Git-2-:Cherry-Pick 的使用场景及使用流程

前面我们说了 Git合并、解决冲突、强行回退等解决方案 >> 点击查看 这里再说一下 Cherry-Pick功能&#xff0c;Cherry-Pick不是merge&#xff0c;只是把部分功能代码Cherry-Pick到远程的目标分支 git cherry-pick功能简介&#xff1a; git cherry-pick 是用来从一个分…...

【C++】21.map和set的使用

文章目录 1. 序列式容器和关联式容器2. set系列的使用2.1 set和multiset参考文档2.2 set类的介绍2.3 set的构造和迭代器构造函数&#xff1a;双向迭代器迭代器&#xff1a; 2.4 set的增删查2.5 insert和迭代器遍历使用样例&#xff1a;2.6 find和erase使用样例&#xff1a;2.7 …...

burpsiute的基础使用(2)

爆破模块&#xff08;intruder&#xff09;&#xff1a; csrf请求伪造访问&#xff08;模拟攻击&#xff09;: 方法一&#xff1a; 通过burp将修改&#xff0c;删除等行为的数据包压缩成一个可访问链接&#xff0c;通过本地浏览器访问&#xff08;该浏览器用户处于登陆状态&a…...

ElasticSearch 同义词匹配

synonym.txt 电脑, 计算机, 主机 复印纸, 打印纸, A4纸, 纸, A3 平板电脑, Pad DELETE /es_sku_index_20_20250109 PUT /es_sku_index_20_20250109 {"settings": {"index": {"number_of_shards": "5","number_of_replicas&quo…...

linux RT-Preempt spin lock实现

一、spin_lock概述 Spinlock是linux内核中常用的一种互斥锁机制&#xff0c;和mutex不同&#xff0c;当无法持锁进入临界区的时候&#xff0c;当前执行线索不会阻塞&#xff0c;而是不断的自旋等待该锁释放。正因为如此&#xff0c;自旋锁也是可以用在中断上下文的。也正是因为…...

PySpark广播表连接解决数据倾斜的完整案例

使用PySpark解决数据倾斜问题的完整案例&#xff0c;通过广播表连接的方式来优化性能。 准备数据 假设我们有两张表&#xff0c;一张大表 big_table 和一张小表 small_table &#xff0c;小表将作为广播表。 from pyspark.sql import SparkSession# 初始化SparkSession spar…...

Chromium CDP 开发(十二):为自己的Domain建立custom_config.json

引言 本章详细介绍了如何为自定义的 CDP Domain 创建 custom_config.json 文件&#xff0c;并通过修改 BUILD.gn 文件来确保自定义的配置文件参与编译。我们通过 inspector_protocol_generate 配置段自动生成自定义 Domain 的头文件和实现文件&#xff0c;并成功将其集成到构建…...

【Vue】全局/局部组件使用流程(Vue2为例)

全局组件和局部组件区别 如何使用 全局组件&#xff1a;全局注册后&#xff0c;可以在任意页面中直接使用。局部组件&#xff1a;在页面中需要先导入子组件路径&#xff0c;注册组件才能使用。 适用场景 全局组件&#xff1a;适用于高频使用的组件&#xff0c;如导航栏、业…...

Vue.js组件开发详解

在现代前端开发中&#xff0c;Vue.js 凭借其简洁、高效、灵活的特性&#xff0c;成为了众多开发者的首选框架之一&#xff0c;而组件化开发则是 Vue.js 的核心优势。组件可以将复杂的 UI 界面拆分成一个个独立的、可复用的小块&#xff0c;极大地提高了开发效率和代码的可维护性…...

解决:ubuntu22.04中IsaacGymEnv保存视频报错的问题

1. IsaacGymEnvs项目介绍 IsaacGymEnvs&#xff1a;基于NVIDIA Isaac Gym的高效机器人训练环境 IsaacGymEnvs 是一个基于 NVIDIA Isaac Gym 的开源 Python 环境库&#xff0c;专为机器人训练提供高效的仿真环境。Isaac Gym 是由 NVIDIA 开发的一个高性能物理仿真引擎&#xf…...

深度学习camp-第J7周:对于ResNeXt-50算法的思考

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 &#x1f4cc;你需要解决的疑问&#xff1a;这个代码是否有错&#xff1f;对错与否都请给出你的思考 &#x1f4cc;打卡要求&#xff1a;请查找相关资料、逐步…...

java: 错误: 无效的源发行版:17解决办法

遇到“java: 错误: 无效的源发行版&#xff1a;17”的问题&#xff0c;通常是因为项目设置中指定的Java版本与当前环境不一致导致的。以下是几种可能的解决方案&#xff1a; 检查并升级Java版本&#xff1a;确保你已经安装了支持Java 17的JDK版本。你可以通过命令行输入java -v…...

Docker 安装开源的IT资产管理系统Snipe-IT

一、安装 1、创建docker-compose.yaml version: 3services:snipeit:container_name: snipeitimage: snipe/snipe-it:v6.1.2restart: alwaysports:- "8000:80"volumes:- ./logs:/var/www/html/storage/logsdepends_on:- mysqlenv_file:- .env.dockernetworks:- snip…...

Go语言封装加解密包(AES/DES/RSA)

Go语言封装加解密包&#xff08;AES/DES/RSA&#xff09; 1. Base64编码与解码2. AES加解密3. DES加解密4. RSA加解密5. SHA256哈希6. 单元测试1. AES加解密单元测试2. DES加解密单元测试3. RSA加解密单元测试4. SHA256哈希单元测试测试用例说明 总结 在现代软件开发中&#xf…...

sql server 对 nvarchar 类型的列进行 SUM() 运算

因为 SUM() 是一个数值聚合函数&#xff0c;不能直接应用于字符串类型的数据。为了正确汇总标准数量&#xff0c;你需要确保该列的数据类型是数值类型&#xff0c;如 int、decimal 或 float。 假设要统计数量列的和&#xff0c;由于数量列是 nvarchar 类型&#xff0c;你需要先…...

java中json字符串键值获取

<dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.83</version> </dependency>使用fastjson依赖 JSONObject jsonObject JSON.parseObject(s); 这个jsonObject本质就是一个map&…...

第6章 Mosquitto用户认证与访问控制

第6章 用户认证与访问控制 6.1 认证机制概览 #mermaid-svg-MTeZFweZQcx9XrLR{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}@keyframes edge-animation-frame{from{stroke-dashoffset:0;}}@keyframes dash{to{stroke-dashoffset:…...

Promise/A+ 规范:引用不可变 + 核心术语(对象 / 函数)详解

Promise/A 规范&#xff1a;引用不可变 核心术语&#xff08;对象 / 函数&#xff09;详解 文章目录Promise/A 规范&#xff1a;引用不可变 核心术语&#xff08;对象 / 函数&#xff09;详解前言一、“引用不可变” 是什么意思&#xff1f;二、为什么要强调 “引用不可变”&…...

ThinkPad散热控制新境界:TPFanCtrl2全方位应用指南

ThinkPad散热控制新境界&#xff1a;TPFanCtrl2全方位应用指南 【免费下载链接】TPFanCtrl2 ThinkPad Fan Control 2 (Dual Fan) for Windows 10 and 11 项目地址: https://gitcode.com/gh_mirrors/tp/TPFanCtrl2 一、核心价值解析&#xff1a;为何选择TPFanCtrl2 突破…...

量子囚笼小说(理论分析)

1&#xff0c;困顿 最近&#xff0c;地球物理研究所的研究员李吕薇媛&#xff0c;心头始终萦绕着一团难解的烦恼。当下的世界&#xff0c;正浮现着种种诡异的失衡与怪象&#xff1a;有人坐拥无尽财富&#xff0c;生活极尽繁华优渥&#xff1b;有人却深陷困顿&#xff0c;日子举…...

探索ai辅助开发新范式:在快马平台打造深度集成codex的智能编程助手

最近在尝试AI辅助开发时&#xff0c;发现InsCode(快马)平台的深度集成功能特别适合探索Codex这类智能编程助手的潜力。通过实际体验&#xff0c;总结了一套将AI能力融入完整开发流程的方法&#xff0c;分享几个关键发现&#xff1a; 智能补全的上下文感知 传统代码补全往往局限…...

MaixinVoiceAI 3.0 助力高校后勤报修自动化

在校园规模不断扩大、后勤服务需求持续攀升的当下&#xff0c;报修服务已成为高校保障教学秩序、提升师生满意度、塑造校园管理口碑的关键环节。但现实中&#xff0c;高校后勤报修体系普遍面临诸多难题&#xff1a;报修渠道分散、响应不及时&#xff0c;师生需反复描述故障情况…...

共聚焦显微技术在高分子科学中的应用与实践

研究高分子材料的微观结构&#xff0c;传统方法面临一个永恒的困境&#xff1a;要看到内部&#xff0c;就得破坏样品&#xff1b;要保持样品完整&#xff0c;就只能观察表面。如今已跨越学科边界&#xff0c;成为高分子材料工业研发的重要工具。下文是光子湾共聚焦显微镜解析这…...

如何高效构建雷达系统:Python雷达模拟的完整实战指南

如何高效构建雷达系统&#xff1a;Python雷达模拟的完整实战指南 【免费下载链接】radarsimpy Radar Simulator built with Python and C 项目地址: https://gitcode.com/gh_mirrors/ra/radarsimpy RadarSimPy是一个基于Python和C构建的开源雷达模拟器&#xff0c;为雷达…...

如何高效配置无人机电子调速器:专业级ESC配置工具实战指南

如何高效配置无人机电子调速器&#xff1a;专业级ESC配置工具实战指南 【免费下载链接】esc-configurator A Web-App to flash your BLHeli_S and AM32 based ESCs from the browser using the Web-Serial API. 项目地址: https://gitcode.com/gh_mirrors/es/esc-configurato…...

2026最权威的AI辅助写作神器解析与推荐

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 伴随人工智能技术迅猛发展&#xff0c;AI工具于毕业论文写作里的运用愈发广泛&#xff0c;学…...