一键秒连WiFi智能设备,uni-app全栈式物联开发指南。
如何使用 uni-app 框架实现通过 WiFi 连接设备并进行命令交互的硬件开发。为了方便理解和实践,我们将提供相应的源代码示例,帮助开发者快速上手。
1. 硬件准备
在开始之前,请确保你已经准备好以下硬件设备:
-
支持 WiFi 连接的设备:如 ESP8266、ESP32 等。
-
控制端设备:手机或电脑,安装有支持 uni-app 开发的开发环境(如 HBuilderX)。
-
网络环境:确保设备和控制端在同一个局域网内。
2. uni-app 项目设置
2.1 创建 uni-app 项目
首先,使用 HBuilderX 创建一个新的 uni-app 项目。选择默认模板即可。
2.2 添加插件依赖
在 manifest.json
文件中,添加以下插件依赖(如果需要):
{"name": "WiFiDeviceControl","appid": "","description": "","versionName": "1.0.0","versionCode": "100","plugins": {"WiFi": {"version": "1.0.0","provider": "your-plugin-provider"}}
}
注意:如果你使用的是自定义插件或第三方插件,请根据插件的文档配置
provider
和version
。
2.3 安装依赖
如果你的项目需要额外的依赖库,可以通过 npm 安装
npm install your-dependency
3. 实现 WiFi 设备连接
3.1 获取 WiFi 列表
在 uni-app 中,可以通过调用设备的 WiFi API 获取附近的 WiFi 列表。以下是一个示例代码:
<template><view class="container"><view class="wifi-list"><view v-for="(wifi, index) in wifiList" :key="index" class="wifi-item" @click="selectWifi(wifi)"><text>{{ wifi.ssid }}</text></view></view><view v-if="selectedWifi" class="password-input"><input v-model="password" type="password" placeholder="请输入WiFi密码" /><button @click="connectWifi">连接</button></view></view>
</template><script>
export default {data() {return {wifiList: [], // 存储获取到的WiFi列表selectedWifi: null, // 用户选择的WiFipassword: '', // 用户输入的密码};},methods: {// 获取WiFi列表async getWifiList() {// 调用设备的WiFi API获取列表const res = await uni.request({url: 'https://your-api-endpoint/get-wifi-list',method: 'GET',});if (res.statusCode === 200) {this.wifiList = res.data;} else {uni.showToast({title: '获取WiFi列表失败',icon: 'none',});}},// 选择WiFiselectWifi(wifi) {this.selectedWifi = wifi;},// 连接WiFiasync connectWifi() {if (!this.selectedWifi || !this.password) {uni.showToast({title: '请选择WiFi并输入密码',icon: 'none',});return;}// 调用连接WiFi的APIconst res = await uni.request({url: 'https://your-api-endpoint/connect-wifi',method: 'POST',data: {ssid: this.selectedWifi.ssid,password: this.password,},});if (res.statusCode === 200) {uni.showToast({title: '连接成功',icon: 'success',});} else {uni.showToast({title: '连接失败',icon: 'none',});}},},mounted() {this.getWifiList();},
};
</script><style>
.container {padding: 20px;
}.wifi-item {padding: 10px;border-bottom: 1px solid #ccc;
}.password-input {margin-top: 20px;
}input {width: 100%;padding: 10px;border: 1px solid #ccc;border-radius: 5px;margin-bottom: 10px;
}button {background-color: #007aff;color: #fff;padding: 10px;border-radius: 5px;text-align: center;
}
</style>
3.2 连接 WiFi 设备
用户选择 WiFi 并输入密码后,调用设备的连接 API 进行连接。连接成功后,可以进一步与设备进行命令交互。
4. 命令交互
连接 WiFi 设备后,可以通过 HTTP 或 WebSocket 协议与设备进行命令交互。以下是一个简单的命令发送示例:
async function sendCommand(command) {const res = await uni.request({url: 'http://your-device-ip/command',method: 'POST',data: {command: command,},});if (res.statusCode === 200) {console.log('命令发送成功:', res.data);} else {console.error('命令发送失败');}
}
5. 总结
通过以上步骤,我们实现了以下功能:
-
获取 WiFi 列表:扫描附近的 WiFi 网络。
-
连接 WiFi 设备:用户选择 WiFi 并输入密码进行连接。
-
命令交互:通过 HTTP 或 WebSocket 与设备进行通信。
本文提供的代码示例可以帮助开发者快速上手 uni-app 与 WiFi 设备的开发。如果你有任何问题或建议,欢迎在评论区留言!
根据上面的内容,下面是极速智联 - 一键秒连智能设备"的WiFi连接方案:
<template><view class="connect-container"><!-- 动态流光特效按钮 --><view class="nebula-button" @click="startScan"><text class="button-text">🚀 极速发现智能设备</text><view class="nebula-effect"></view></view><!-- WiFi列表弹窗 --><uni-popup ref="wifiPopup" type="bottom"><view class="wifi-dialog"><view class="dialog-header"><text class="title">📶 发现智能设备网络</text><text class="subtitle">选择您的智能设备热点</text></view><scroll-view class="wifi-list" scroll-y><view v-for="(wifi, index) in wifiList" :key="index" class="wifi-item" @click="selectWifi(wifi)"><view class="signal-strength"><text class="icon">📶</text><text class="strength">{{getSignalLevel(wifi.rssi)}}</text></view><text class="ssid">{{wifi.SSID}}</text><text v-if="wifi.secure" class="lock">🔒</text></view></scroll-view></view></uni-popup><!-- 动态密码输入框 --><uni-popup ref="pwdPopup" type="dialog"><view class="password-dialog"><view class="holographic-header"></view><input class="holographic-input" type="password"v-model="password"placeholder="输入设备连接密钥"placeholder-class="placeholder-style"/><button class="confirm-btn" @click="connectDevice">✨ 启动智能连接</button></view></uni-popup></view>
</template><script>
export default {data() {return {wifiList: [],selectedWifi: null,password: '',connectionStatus: 'disconnected'}},methods: {async startScan() {// 初始化WiFi模块try {await uni.startWifi()uni.showLoading({title: '正在扫描智能设备...', mask: true})// 获取WiFi列表uni.getWifiList({success: () => {uni.onGetWifiList(res => {this.wifiList = res.wifiList.filter(w => w.SSID.startsWith('SmartDevice_')).sort((a,b) => b.rssi - a.rssi)this.$refs.wifiPopup.open()})}})} catch (e) {this.showError('请开启手机定位权限')}},selectWifi(wifi) {this.selectedWifi = wifithis.$refs.wifiPopup.close()this.$refs.pwdPopup.open()},async connectDevice() {// 连接核心逻辑uni.showLoading({title: '建立安全通道...'})try {await uni.connectWifi({SSID: this.selectedWifi.SSID,password: this.password,success: () => {uni.showToast({title: '设备握手成功!', icon: 'success'})this.startCommandChannel()}})} catch (e) {this.showError(`连接失败: ${errMsgHandler(e.errCode)}`)}},// 信号强度可视化getSignalLevel(rssi) {const levels = ["▁▃▅", "▁▃▆", "▁▄▆", "▅▆▇"]return levels[Math.min(Math.floor((rssi + 90)/20), 3)]},// 错误处理增强showError(msg) {uni.showModal({title: '星际导航失败',content: msg,confirmText: '重新扫描',success: () => this.startScan()})}}
}
</script><style>
/* 添加星空背景和动态特效 */
.connect-container {background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);min-height: 100vh;padding: 30px;
}.nebula-button {position: relative;background: linear-gradient(45deg, #6a11cb, #2575fc);border-radius: 50px;padding: 20px 40px;overflow: hidden;transition: transform 0.3s;
}.nebula-effect {position: absolute;background: radial-gradient(circle, rgba(255,255,255,0.4) 20%, transparent 60%);animation: nebulaPulse 2s infinite;
}@keyframes nebulaPulse {0% { transform: scale(1); opacity: 0.8; }100% { transform: scale(3); opacity: 0; }
}</style>
相关文章:
一键秒连WiFi智能设备,uni-app全栈式物联开发指南。
如何使用 uni-app 框架实现通过 WiFi 连接设备并进行命令交互的硬件开发。为了方便理解和实践,我们将提供相应的源代码示例,帮助开发者快速上手。 1. 硬件准备 在开始之前,请确保你已经准备好以下硬件设备: 支持 WiFi 连接的设备…...
关于Docker是否被淘汰虚拟机实现连接虚拟专用网络Ubuntu 22.04 LTS部署Harbor仓库全流程
1.今天的第一个主题: 第一个主题是关于Docker是否真的被K8S弃用,还是可以继续兼容,因为我们知道在去年的时候,由于不可控的原因,docker的所有国内镜像源都被Ban了,再加上K8S自从V1.20之后,宣布…...
【C++】动态规划从入门到精通
一、动态规划基础概念详解 什么是动态规划 动态规划(Dynamic Programming,DP)是一种通过将复杂问题分解为重叠子问题,并存储子问题解以避免重复计算的优化算法。它适用于具有以下两个关键性质的问题: 最优子结构&…...
【专栏预告】《VR 360°全景视频开发:从GoPro到Unity VR眼镜应用实战》
【专栏预告】每周天12:00更新,欢迎指导与交流。 专栏地址:《VR 360全景视频开发:从GoPro到Unity VR眼镜应用实战》 前言 随着VR技术的不断发展,360全景视频的需求也在逐年增长。尤其是在VR眼镜端,360全景视频带来了…...
【leetcode100】搜索插入位置
1、题目描述 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 示例 1: 输入: nums [1,3,5,6], target 5 输出: 2…...
Java面试黄金宝典3
1. 什么是 NIO 原理 缓冲区(Buffer): 它是一个线性的、有限的基本数据元素序列,本质上是一块内存区域,被包装成了一个对象,以便于进行高效的数据读写操作。不同类型的基本数据都有对应的Buffer子类…...
vue3 报错 Could not find a declaration file for module ‘/App.vue‘
vue3 报错 Could not find a declaration file for module /App.vue.app.vue路径.js implicitly has an any type 问题描述原因分析:解决方案: 问题描述 Could not find a declaration file for module /App.vue.app.vue路径.js implicitly has an any …...
linux对串口设备文件进行重命名(删除、重建)
0.前言 最近在弄3562的自制板,有很多串口,然后发现设备文件名编号有些跳跃,不方便用户使用,因此,需要对这些设备文件进行重命名 1.查看设备号 我们需要知道目标设备文件的设备号,通过ls -l /dev/tty*查看…...
Linux内核传输层UDP源码分析
一、用户数据包协议(UDP) 1.UDP数据报头 UDP 提供面向消息的不可靠传输,但没有拥塞控制功能。很多协议都使用 UDP,如用于 IP 网络传输音频和视频的实时传输协议 (Real-time Transport Protocol,RTP),此类型…...
GitHub 超火的开源终端工具——Warp
Warp 作为近年来 GitHub 上备受瞩目的开源终端工具,以其智能化、高性能和协作能力重新定义了命令行操作体验。以下从多个维度深入解析其核心特性、技术架构、用户评价及生态影响力: 一、背景与核心团队 Warp 由前 GitHub CTO Jason Warner 和 Google 前…...
【Java基础巩固系列】异常
业务背景 业务开发中,总会遇到代码出现异常的情况,不合理的异常处理或不处理异常除了影响业务功能和中断业务功能外,还会增加排查问题的难度。所以我们要学会正确的使用异常处理。合理的异常处理能减少很多潜在的问题,是提高代码…...
sass介绍
1、Sass简介 Sass 是一种 CSS 的预编译语言。它提供了 变量(variables)、嵌套(nested rules)、 混合(mixins)、 函数(functions)等功能,并且完全兼容 CSS 语法。Sass 能…...
第1章:云原生时代:容器技术的发展历程与核心价值
第1章:云原生时代:容器技术的发展历程与核心价值 作者:DogDog_Shuai 阅读时间:约15分钟 难度:入门级 目录 1. 引言2. 容器技术的发展历程3. 容器技术的核心价值4. 云原生时代的机遇与挑战5. 总结1. 引言...
软考程序员考试知识点汇总
软考程序员考试(初级资格)主要考察计算机基础理论、编程能力及软件开发相关知识。以下是核心知识点总结及备考建议: 一、计算机基础 数制与编码 二进制、八进制、十进制、十六进制转换原码、反码、补码表示(整数与浮点数…...
JVM OOM问题如何排查和解决
在 Java 开发中,JVM OOM(OutOfMemoryError)问题通常是指程序运行时,JVM 无法为对象分配足够的内存空间,导致发生内存溢出的错误。这个问题往往和内存的配置、内存泄漏、或者资源过度使用等因素有关。 1. OOM 错误类型…...
折叠树报表
折叠树报表中包含了三种信息: 1.树组织信息-可展开、收拢 2.节点的统计信息(汇总求和) 3.每个节点对应的数据信息 一、准备数据 mysql8 数据库中存在两张表 org和store表。 org表和部分数据如下,其中orgname是组织的名称,codepath是完整的组织代码,seq是每个节点的顺序,可…...
python 数据可视化matplotib库安装与使用
要使用 matplotlib 库进行数据可视化,首先你需要确保已经安装了该库。如果你还没有安装,可以通过 Python 的包管理器 pip 来安装它。在你的命令行工具中运行以下命令来安装 matplotlib: pip install matplotlib安装完成后,你就可以…...
Springdoc配置参数详解
文章目录 **1. 基础配置****API 文档路径-springdoc.api-docs.path****Swagger UI 路径-springdoc.swagger-ui.path****是否启用 API 文档-springdoc.api-docs.enabled****是否启用 Swagger UI-springdoc.swagger-ui.enabled** **2. 全局元信息-info****应用标题-springdoc.inf…...
抖音视频数据获取实战:从API调用到热门内容挖掘
在短视频流量为王的时代,掌握抖音热门视频数据已成为内容运营、竞品分析及营销决策的关键。本文将手把手教你通过抖音开放平台API获取视频详情数据,并提供完整的代码实现及商业化应用思路。 一、抖音API权限申请与核心接口 抖音API需企业资质认证&…...
【数学建模】灰色关联分析模型详解与应用
灰色关联分析模型详解与应用 文章目录 灰色关联分析模型详解与应用引言灰色系统理论简介灰色关联分析基本原理灰色关联分析计算步骤1. 确定分析序列2. 数据无量纲化处理3. 计算关联系数4. 计算关联度 灰色关联分析应用实例实例:某企业生产效率影响因素分析 灰色关联…...
Spring Boot 与 Couchbase 整合教程
精心整理了最新的面试资料和简历模板,有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 Spring Boot 与 Couchbase 整合教程 环境要求 JDK 8Spring Boot 2.7.xCouchbase Server 7.xMaven/Gradle 步骤 1:创建Spring Boot项目 使用 st…...
Oracle ASM Failgroup故障组
Oracle ASM Failgroup故障组 1. 故障组的核心作用2. 故障组的配置规则3. 故障组的设计最佳实践4. 故障组的实际示例场景1:普通冗余(2个故障组)场景2:高冗余(3个故障组,跨数据中心) 关键注意事项…...
深度学习框架PyTorch——从入门到精通(2)张量
又名:张亮的一生~~ 张量(Tensors)初始化张量张量的属性张量上的操作与NumPy桥接 张量(Tensors) 张量是一种专门的数据结构,类似Python中的数组或者矩阵。在Torch中,我们使用张量来编码模型的输…...
pytorch小记(十三):pytorch中`nn.ModuleList` 详解
pytorch小记(十三):pytorch中nn.ModuleList 详解 PyTorch 中的 nn.ModuleList 详解1. 什么是 nn.ModuleList?2. 为什么不直接使用普通的 Python 列表?3. nn.ModuleList 的基本用法示例:构建一个包含两层全连…...
C语言-动态内存管理
1.为什么要有动态内存分配 我们现如今已经掌握的内存开辟方式有 int main() {int a 0;int arr[30] { 0 };return 0; } 这两种方式,但是这种开辟空间的方式有两个特点: 1.空间开辟大小是固定的 2.数组在申明的时候,必须指定数组的长度&…...
深入解析MySQL数据库分库分表技术
友情提示:本文内容由银河易创(https://ai.eaigx.com)AI创作平台gpt-4-turbo模型生成,仅供参考。 随着互联网应用的快速发展,单一数据库在面对大规模数据时可能会遇到性能瓶颈。因此,数据库分库分表作为一种…...
【Embedded World 2025:边缘 AI、存储革新与 1X nm 工艺重塑嵌入式未来】
Embedded World 2025于3月11-13日在德国纽伦堡举办,作为全球嵌入式系统领域顶级盛会,汇聚超千家展商与3万专业观众,聚焦嵌入式智能、安全管理及行业解决方案。展会呈现边缘AI、低功耗MCU、5G RedCap、新型存储及车规级技术等前沿方向…...
【人工智能基础2】机器学习、深度学习总结
文章目录 一、人工智能关键技术二、机器学习基础1. 监督、无监督、半监督学习2. 损失函数:四种损失函数3. 泛化与交叉验证4. 过拟合与欠拟合5. 正则化6. 支持向量机 三、深度学习基础:深度神经网络1、概念与原理2、多层神经网络训练方法 一、人工智能关键…...
MySQL如何存储表情符号?
存储表情符号 默认mysql的字符集是utf8,排序规则为 utf8_general_ci INSERT INTO department (name) VALUES (😄)在存储表情的时候会报 1366 - Incorrect string value: \xF0\x9F\x98\x84 for column name at row 1, Time: 0.007000s 这时需要修改字符…...
Unity Shader 学习16:全局光照 概念理解
- 全局光照 直接光 间接光,在没有开启GI的情况下是不计算间接光的(如果放了光照探针 倒是可以模拟间接光 <光照探针只影响动态物体>); - 处理对象:静态物体(static) 、 非静态(动态)物体; - 计算方…...
Jobby、Quarkus 和 Spring Boot对比
Jobby、Quarkus 和 Spring Boot 是三种不同的 Java 框架,各自有不同的设计目标和适用场景。以下是对它们的详细对比: 1. 设计目标 框架设计目标Jobby轻量级的任务调度框架,专注于任务调度和执行。Quarkus面向云原生和 Kubernetes 的 Java 框…...
Dubbo 服务发现
总览 学习 Dubbo 的服务发现机制,可以从以下几方面入手: 注册中心的配置服务的注册客户端拉取服务列表服务列表的本地缓存服务提供者列表变更的监听机制服务发现的接口设计 注册中心的配置 Dubbo 通过解析用户配置决定使用的注册中心。比如用户配置了…...
Pytorch使用手册—自定义 C++ 和 CUDA 运算符(专题五十一)
你将学到什么 如何将用 C++/CUDA 编写的自定义运算符与 PyTorch 集成如何使用 torch.library.opcheck 测试自定义运算符先决条件 1. PyTorch 2.4 或更高版本 2. 对 C++ 和 CUDA 编程有基本了解 注意 本教程也适用于 AMD ROCm,无需额外修改。 PyTorch 提供了一个庞大的运算符库…...
Linux 实时同步服务实现(Rsync 结合 Inotify)
文章目录 1. 实时同步服务介绍2. Inotify 机制介绍3. Inotify-toolRsync 实时同步实践3.1 确认远程数据传输服务部署完成3.2 检查Linux系统是否支持Inotify实时监控3.3 安装inotify-tools3.4 命令测试3.5 重要监控事件汇总3.6 使用步骤 4. Sersync 工具使用(重点&am…...
用Java写斗地主前期工作的一些小想法
目前我们并不是要实现一个游戏,而是要对斗地主游戏做准备,主要是做牌+洗牌+发牌+给发的牌进行排序。在这个过程中我希望通过集中方式来实现: 1. 使用集合+方法+字符串的运用完成以上功能 2. 使用面向对象思想,对1做改进,主要是对其排序的改进,从而理解面向对象的真正意…...
鸿蒙数据持久化之首选项
场景介绍 用户首选项为应用提供Key-Value键值型的数据处理能力,支持应用持久化轻量级数据,并对其修改和查询。当用户希望有一个全局唯一存储的地方,可以采用用户首选项来进行存储。Preferences会将该数据缓存在内存中,当用户读取…...
将bin文件烧录到STM32
将bin文件烧录到STM32 CoFlash下载生成hex文件hex2bin使用下载bin到单片机 CoFlash下载 选择需要安装的目录 在Config中可以选择目标芯片的类型 我演示的是 stm32f103c8t6 最小系统板 Adapter:烧录器类型 Max Clock:下载速度 Por:接口类型&am…...
AtCoder Beginner Contest 397(ABCDE)
目录 A - Thermometer 翻译: 思路: 实现: B - Ticket Gate Log 翻译: 思路: 实现: C - Variety Split Easy 翻译: 思路: 实现: D - Cubes 翻译:…...
jasypt-spring-boot-starter项目如何使用jasypt加密密码
import org.jasypt.encryption.pbe.StandardPBEStringEncryptor; import org.jasypt.iv.RandomIvGenerator; import org.jasypt.salt.RandomSaltGenerator;/*** 加密密码的工具** author xxx* since 2025-03-17*/ public class JasyptTest {public static void main(String[] a…...
[AI速读]混合语言IP集成:挑战与高效解决方案
在现代SoC(系统级芯片)设计中,IP(知识产权模块)复用是提升开发效率的关键。然而,当设计涉及多种硬件描述语言(如SystemVerilog、VHDL、SystemC)时,如何高效集成不同语言的IP模块成为一大难题。本文将从实际设计场景出发,探讨混合语言IP集成的核心挑战,并介绍一套方法…...
SpringSecurity——如何获取当前登录用户的信息
目录 1. 直接注入 Principal 2. 直接注入 Authentication 3. 注入 UsernamePasswordAuthenticationToken 4. 通过 SecurityContextHolder 获取 5. 使用自定义工具方法 总结 如何获取更多的用户信息 自定义用户实体类 如何忽略某些字段(不返回前端ÿ…...
ospf动态路由
一、为什么使用动态路由 OSPF(open shortest path first开放最短路径优先)是内部网关协议(IGP)的一种,基于链路状态算法(LS)。 OSPF企业级路由协议(RFC2328 OSPFv2),核心重点协议 OSPF共三个版本,OSPFV1主要是实验室…...
在react当中利用IntersectionObserve实现下拉加载数据
目录 一、传统的下拉加载方案 二、存在问题 1.性能较差 2.不够精确 三、IntersectionObserve版本下拉加载 1、callback 2、options 四、IntersectionObserver实例 1、Intersection的优势 2、实现思路 3、代码实现 在进行前端开发的过程中,常常会碰到下拉…...
SpringBoot之如何集成SpringDoc最详细文档
文章目录 一、概念解释1、OpenAPI2、Swagger3、Springfox4、Springdoc5. 关系与区别 二、SpringDoc基本使用1、导包2、正常编写代码,不需要任何注解3、运行后访问下面的链接即可 三、SpringDoc进阶使用1、配置文档信息2、配置文档分组3、springdoc的配置参数**1. 基…...
Transaction rolled back because it has been marked as rollback-only问题解决
transaction rolled back because it has been marked as rollback-only 简略总结> 发生场景:try-catch多业务场景 发生原因:业务嵌套,事务管理混乱,外层业务与内层业务抛出异常节点与回滚节点不一致。 解决方式:修…...
单片机写的小液晶屏驱动+汉字滚屏
单片机写的小液晶屏驱动汉字滚屏 stm32f401freertos内置HZK16 单片机汉字滚屏...
SpringBoot整合LangChain4j操作AI大模型实战详解
一、引言 在当今这个人工智能飞速发展的时代,AI大模型已经逐渐渗透到我们生活的方方面面,为企业和开发者带来了前所未有的机遇。然而,如何高效地接入并利用这些AI大模型,成为了摆在许多开发者面前的一道难题。SpringBoot作为一款…...
深度解析 | Android 13 Launcher3分页指示器改造:横线变圆点实战指南
一、需求背景与技术挑战 在Android 13系统定制开发中,我们面临将Launcher3桌面从传统双层架构优化为现代单层布局的挑战。原生系统采用的分页横线指示器在视觉呈现上存在两点不足: 风格陈旧不符合Material You设计规范 空间占用较大影响屏幕利用率 通…...
【Qt】private槽函数可以被其他类中的信号连接
private槽函数可以被其他类中的信号连接。 即使 B 类的槽函数是 private 的,A 类通过信号连接 B 类的槽函数也没有问题。这是因为 Qt 的信号和槽机制是通过元对象系统(Meta-Object System)实现的,而不是直接调用函数。只要信号和…...
C语言每日一练——day_7
引言 针对初学者,每日练习几个题,快速上手C语言。第七天。(连续更新中) 采用在线OJ的形式 什么是在线OJ? 在线判题系统(英语:Online Judge,缩写OJ)是一种在编程竞赛中用…...