简介:
### 开发51单片机操作系统时应注意的问题#### 一、引言随着嵌入式系统的广泛应用,针对特定硬件平台的操作系统开发变得尤为重要。
51单片机作为一款经典的微控制器,在工业控制、家用电器等领域有着广泛的应用。
然而,由于其硬件资源的限制,在51单片机上开发操作系统面临诸多挑战。
本文将详细介绍开发51单片机操作系统时需要注意的关键问题。
#### 二、关键问题详解##### 1. 操作系统软件的代码长度控制51系列单片机由于硬件资源的限制(如ROM空间较小),因此对于操作系统代码的大小有严格的要求。
通常情况下,一个基于51单片机的应用程序大约需要7至8KB的ROM空间。
相比之下,如果操作系统本身就需要几十KB的空间,那么留给用户应用程序的空间将非常有限,这显然不利于实际应用。
例如,流行的嵌入式操作系统往往体积较大,无法适用于51单片机。
为了克服这一限制,开发者需要采取以下措施:- **精简设计**:简化操作系统的功能模块,确保核心功能的同时尽可能减小代码量。
- **模块化**:采用模块化设计,允许用户根据具体需求选择加载必要的模块,从而降低整体代码量。
- **代码优化**:通过高效的编码技巧来减少代码长度,比如使用更简洁的数据结构和算法。
##### 2. 控制操作系统对片内RAM的占用51系列单片机仅有128或256字节的片内RAM空间,这对于运行操作系统而言是非常有限的。
如果操作系统占用过多的RAM空间,将严重影响用户应用程序的正常运行。
因此,开发者需要特别注意以下几点:- **最小化RAM使用**:减少操作系统的RAM占用,确保有足够的空间供用户应用程序使用。
- **合理分配资源**:优化RAM的使用方式,避免不必要的资源浪费。
- **外部RAM利用**:在不影响性能的前提下,考虑将部分数据存储在外置RAM中,以减轻内部RAM的压力。
##### 3. 解决函数的重入问题对于实时占先式操作系统而言,函数的重入性至关重要。
重入函数能够在不破坏数据的情况下被多个任务调用。
要实现函数的重入性,必须满足以下条件之一:- **不使用共享资源**:确保函数内部没有依赖任何共享资源。
- **使用中断禁用**:在使用共享资源时暂时禁用中断,以保证数据的一致性。
- **信号量机制**:通过申请和释放信号量来管理对共享资源的访问。
在标准C中实现这些条件相对简单,但在Keil C51编译器环境下,由于局部变量的静态分配特性,实现起来较为复杂。
开发者可以通过以下策略应对这一挑战:- **手动管理资源**:显式地控制共享资源的访问,避免自动管理带来的不确定性。
- **代码审查**:仔细检查函数中的资源使用情况,确保符合重入性的要求。
- **测试验证**:通过严格的测试来验证函数的重入性,确保其在多任务环境下的正确运行。
##### 4. 堆栈的分配与管理在占先式操作系统中,任务之间的切换频繁发生,因此需要合理分配和管理堆栈空间。
每个任务都需要有自己的堆栈,用于保存任务状态信息。
由于51单片机的RAM空间有限,堆栈的分配策略成为了一项重要的考量因素。
- **按需分配**:根据任务的实际需求动态分配堆栈空间,避免过度预分配造成的资源浪费。
- **优化堆栈使用**:通过调整任务的设计和编码方式来减少堆栈的需求。
- **复用机制**:探索堆栈空间的复用机制,如在任务间共享堆栈空间等方法。
#### 三、结论开发51单片机操作系统是一项充满挑战的任务,需要开发者在有限的硬件资源下,精心设计并优化操作系统的各个方面。
通过本文所述的关键问题及解决方案的探讨,希望能够帮助开发者更好地理解和应对这些挑战,成功开发出高效、可靠的51单片机操作系统。
2025/6/15 19:58:32 63KB
1
简介:
随着计算机技术的成熟,互联网的建立,如今,PC平台上有许多关于租房方面的应用程序,但由于使用时间和地点上的限制,用户在使用上存在着种种不方便,而开发一款基于微信小程序的租房系统,能够有效地解决这个问题。
本基于微信小程序的无中介租房系统是针对租房而开发,采用MYSQL数据库、微信开发者工具进行微信端开发,满足用户通过微信客户端进行租房的需求。
本小程序是以微信为入口的,可以说是在自带接近10亿的流量人口。
整个系统不仅操作简单、便捷,而且节约用户的时间及资源成本等,仅需通过一部手机和微信号即可满足用户们的需求。
论文首先阐述了基于微信小程序的无中介租房系统的开发背景,并对开发基于微信小程序的无中介租房系统所采用的相关技术进行了详细的介绍,然后对此应用软件进行了需求分析、设计,最后对系统进行测试、维护,保证系统的正常运行。
关键词:微信小程序 ;
微信开发者工具;
租房;
MYSQL数据库
2025/6/15 19:58:17 54.99MB
1
简介:
1.版本:matlab2014/2019a/2021a 2.附赠案例数据可直接运行matlab程序。
3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。
4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
5.作者介绍:某大厂资深算法工程师,从事Matlab算法仿真工作10年;
擅长智能优化算法、神经网络预测、信号处理、元胞自动机等多种领域的算法仿真实验,更多仿真源码、数据集定制私信+。
替换数据可以直接使用,注释清楚,适合新手
2025/6/15 19:56:22 301KB
1
简介:
旋转电磁场对NaCl溶液电导率影响的实验研究,陈磊,程树康,以NaCl溶液为例,研究旋转电磁场对溶液的影响规律。
介绍了旋转电磁发生装置,分析了装置的磁场分布情况。
搭建了旋转电磁场循环处�
2025/6/15 19:56:14 411KB
1
简介:
PHP实现Google和Baidu风格分页代码的知识点涵盖了分页算法、PHP类的创建和使用、以及基本的Web页面导航。
下面详细介绍这些知识点。
### 分页算法分页算法是分页功能的核心,它需要根据当前页码和每页显示的记录数来计算出总页数以及记录的起止位置。
1. **计算总页数**:需要根据记录总数(recorbTotal)和每页显示的记录数(pageSize)来计算总页数(pageTotal)。
通常是将记录总数除以每页记录数,然后向上取整。
2. **获取当前页的起止记录**:分页算法还需要确定当前页显示的数据从哪一条记录开始,到哪一条记录结束。
这需要根据当前页码(currentPage)来计算。
3. **设置上一页和下一页**:确定了当前页码后,可以很轻易地得到上一页(previous)和下一页(next)的页码。
4. **分页导航**:为了方便用户在不同页间跳转,分页算法应提供一个分页导航,显示从起始页到终止页的页码按钮,通常是显示当前页周围的一组页码。
### PHP类的创建和使用代码中定义了一个名为`Pager`的PHP类,这个类封装了分页的功能,方便在项目中复用。
1. **属性**:`Pager`类中定义了一系列属性(variables),用于存储分页所需的所有信息,如总页数(pageTotal)、当前页(currentPage)、记录总数(recorbTotal)等。
2. **构造函数**:类的构造函数(constructor)用于初始化对象,设置默认值,如当前显示页、记录总数和每页显示记录数。
3. **方法**:类提供了一系列方法(methods)来操作这些属性,比如`setRecorbTotal()`设置记录总数,`setPageSize()`设置每页显示的记录数,`setCurrentPage()`设置当前显示页等。
同时,`execute()`方法用于输出分页导航。
4. **分页导航的生成**:`Pager`类中的`execute()`方法会根据当前页码和其他参数生成分页导航。
它会计算出分页导航中应该显示的页码,并输出为HTML链接,允许用户点击跳转到指定的页码。
### 基本的Web页面导航实现分页功能需要与Web页面的导航相结合,允许用户通过点击分页链接跳转到不同的页面视图。
1. **分页链接**:每个分页导航项应该被构造成一个链接(URL),这个URL应该包含参数,比如当前页码(page),以便于PHP脚本能根据这个参数来获取相应页面的数据。
2. **URL构造**:分页导航中的链接通常包括基础URL(baseUri)和查询字符串,查询字符串用于指定当前页码,例如`page.php?page=2`。
3. **页面跳转**:分页链接点击后,用户被重定向到相应的页面,并且PHP脚本会根据URL参数来查询和显示对应的数据页。
### 总结以上是基于提供的文档内容生成的相关知识点。
文档中的PHP代码展示了一个分页类的实现,这个类可以用于生成类似Google或百度搜索引擎结果页风格的分页功能。
了解和掌握这些知识点,对实现Web应用中的分页功能有很大帮助。
在实际应用中,开发者需要根据具体需求调整分页算法和样式,以达到最佳用户体验。
2025/6/15 19:56:00 34KB
1
简介:
《FX3U-ENET-ADP用户手册》是针对三菱FX3U系列PLC(可编程逻辑控制器)中的一款以太网模块——FX3U-ENET-ADP的详细使用指南。
该手册深入浅出地介绍了如何利用此模块进行网络通信、数据交换以及系统配置,对于理解和操作FX3U-ENET-ADP至关重要。
三菱FX3U系列PLC是一款高性能的小型PLC,广泛应用于自动化设备和生产线中。
FX3U-ENET-ADP作为其网络扩展模块,提供了以太网通信功能,使PLC能够与网络中的其他设备进行高效的数据交互,如上位机、HMI(人机界面)、服务器等。
1. **FX3U-ENET-ADP功能介绍**: - **以太网通信**:FX3U-ENET-ADP模块支持TCP/IP和UDP/IP协议,可以实现PLC与各种设备的网络连接。
- **多点通信**:支持最多16个站点的MODBUS TCP通信,适用于构建分布式控制系统。
- **高速数据传输**:具备高速数据传输能力,适合实时控制应用。
- **网络诊断**:提供网络状态监控功能,方便故障排查。
2. **硬件安装与接线**: - **安装位置**:FX3U-ENET-ADP通常安装在FX3U PLC的扩展槽上。
- **接线配置**:包括RJ45接口的网络线连接,以及可能的电源和接地线连接。
3. **软件配置**: - **GX Works3**:使用三菱提供的编程软件进行程序编写和配置,包括网络设置、I/O映射等。
- **通信参数设定**:设置IP地址、子网掩码、网关等网络参数,以及MODBUS通信的相关参数。
4. **通信协议**: - **MODBUS TCP**:FX3U-ENET-ADP支持MODBUS TCP协议,允许与支持此协议的各种设备进行通信。
- **三菱专用协议**:还支持三菱的私有协议,如FINS(Factory Integrated Network System),用于三菱设备间的通信。
5. **应用实例**: - **远程监控**:通过以太网连接,可以在远程位置监控和控制PLC的运行状态。
- **数据采集**:从PLC收集生产数据,上传至服务器进行数据分析和报表生成。
- **联网设备的集成**:如连接变频器、伺服驱动器等,实现设备间的协同工作。
6. **故障排查**: - 手册会提供详细的错误代码和解决方法,帮助用户快速定位并解决问题。
7. **安全注意事项**: - 遵守电气安全规范,避免电击或火灾风险。
- 定期检查网络设备的物理连接和网络状态,确保稳定运行。
通过《FX3U-ENET-ADP用户手册》的学习和实践,用户可以充分利用这一模块的功能,实现高效、稳定的PLC网络通信,提高自动化系统的整体性能。
无论是初学者还是经验丰富的工程师,都能从中获得宝贵的指导。
2025/6/15 19:55:36 5.37MB
1
简介:
在当今世界,随着能源需求的日益增长和环境保护意识的提升,液化天然气(LNG)作为一种清洁高效的能源,在全球能源市场中扮演着越来越重要的角色。
LNG的运输和储存需要依赖特殊的容器——薄膜罐,这种罐体结构因其优异的保温性能和节省空间的设计而被广泛采用。
然而,在海上运输过程中,LNG薄膜罐所面临的各种摇摆现象给整个运输和储存系统带来了巨大的安全挑战。
为了有效评估和管理这些风险,挪威船级社(DNV)发布了一份重要技术指南——DNV-CG-0158.pdf,为业界提供了一份详细的方法和标准。
DNV作为全球领先的船级社,其发布的技术指南向来受到船舶和海洋工程领域的高度重视。
最新版的DNV-CG-0158.pdf,发布于2021年10月,是在此前2016年2月版DNVGL-CG-0158的基础上进行了全面更新,更新内容包括对特定技术主题的参考和描述的修改,以反映最新的技术进步和行业标准。
这份技术指南不仅为设计、建造和运营LNG存储船舶和设施的专业人士提供了至关重要的参考依据,还明确了技术要求和责任限制,从而确保整个行业的一致性和安全性。
文档详细地介绍了液化天然气薄膜罐在海上运输过程中,面对不同海洋环境条件下的摇摆现象所应进行的安全评估方法。
该指南所包含的内容,严格遵循DNV的规则,并适用于相应分类的对象,尤其是LNG薄膜罐的摇摆分析。
摇摆分析对评估储存罐内部液态LNG晃动影响至关重要,关系到整个LNG运输和储存系统的安全性能。
作为用户,理解并正确应用这份技术指南中的方法和技术要求,对于确保LNG薄膜罐的结构安全和操作的可靠性至关重要。
这份指南提供了评估LNG薄膜罐在实际海洋运输环境下的动态响应的理论基础和实际操作流程,这包括了对罐体结构的运动和应力应变的详细分析,以及如何根据评估结果采取相应的安全措施。
然而,DNV也明确指出,任何第三方未经其书面许可不得基于本文档提供分类、认证或验证服务,包括发放证书或做出符合性声明。
这一点强调了在使用DNV-CG-0158.pdf时,用户必须严格遵守DNV的知识产权保护,同时也说明了DNV在技术指导文件领域的权威性和严肃性。
此外,DNV还声明了对使用该文档可能产生的后果不负责任。
这份指南是根据发布时的知识、技术和信息编写的,因此用户在使用本指南时,风险自负。
这种规定在一定程度上限制了DNV的责任范围,同时也提醒用户在使用过程中必须谨慎行事,并对可能出现的风险有充分的认识和准备。
在责任限制方面,DNV规定,其对于行为或疏忽所引起的直接损失承担责任,但是无论在合同还是侵权情况下,包括过失在内,责任都限于直接损失,并且在任何情况下不超过300,000美元。
这一规定对于用户而言是一种明确的风险提示,也反映了DNV在法律责任上的严谨态度。
DNV-CG-0158.pdf作为一份提供LNG薄膜罐摇摆分析的权威技术指南,对于确保LNG运输和储存的安全性具有不可替代的重要作用。
文档不仅包含详尽的技术要求和原则,还明确了使用和责任限制,是业内不可或缺的参考资料。
对于从事LNG相关业务的专业人士来说,它既是安全操作的保障,也是技术进步和行业标准的体现。
通过严格遵循指南中的建议和技术要求,可以最大程度地减少运输和储存过程中可能出现的安全事故,确保能源运输的安全和高效。
2025/6/15 19:52:41 4.9MB
1
简介:
### DB2数据库在Linux系统下的安装教程#### 一、环境准备与检查在开始安装DB2数据库之前,首先需要确保Linux系统的环境符合DB2的安装要求。
以下是一些基本的环境检查步骤:1. **确认Linux版本**: - 通过`uname -a`命令查看当前Linux系统的内核版本等信息。
- 通过`uname -r`命令确认内核版本。
- 通过`cat /etc/redhat-release`命令查看具体的发行版信息。
2. **系统信息示例**: - 系统名称:`Linux myrac1.oracle.com 2.6.32-358.el6.i686 #1 SMP Tue Jan 29 11:48:01 EST 2013 i686 i686 i386 GNU/Linux` - 内核版本:`2.6.32-358.el6.i686` - 发行版:`Red Hat Enterprise Linux Server release 6.4 (Santiago)`#### 二、安装DB2软件DB2的安装可以通过两种方式进行:1. **静默安装**: - 解压DB2安装包:`tar -zxvf v9.7_linuxia32_server.tar.gz` - 进入解压后的目录:`cd db2_install/` - 执行安装命令:`./db2_install`(并根据提示选择企业版)2. **图形界面安装**: - 同样先解压安装包并进入解压目录。
- 使用图形界面安装命令:`./db2setup`#### 三、创建用户组和用户为了满足DB2的权限需求,需要创建特定的用户组和用户:1. **创建用户组**: - `groupadd db2grp`:用于DB2实例的所有者。
- `groupadd db2fgrp`:用于DB2实例的围栏(fence)用户。
- `groupadd dasadm`:用于管理DAS(Distributed Access Services)的用户。
2. **创建用户**: - `useradd -m -g db2grp -d /home/db2inst -s /bin/bash db2inst`:创建DB2实例所有者用户。
- `useradd -m -g db2fgrp -d /home/db2fenc -s /bin/bash db2fenc`:创建围栏用户。
- `useradd -m -g dasadm -d /home/dasusr -s /bin/bash dasusr`:创建DAS用户。
3. **设置密码**: - `passwd db2inst`:为db2inst用户设置密码。
- `passwd db2fenc`:为db2fenc用户设置密码。
- `passwd dasusr`:为dasusr用户设置密码。
#### 四、安装DB2 License安装DB2许可是合法使用DB2的前提:1. **进入许可目录**: - `cd /opt/ibm/db2/V9.5/adm`2. **安装许可**: - `./db2licm -a /home/db2install/server/db2/license/db2ese_t.lic`#### 五、创建DAS和数据库实例1. **创建DAS**: - `./dascrt -udasusr`2. **创建数据库实例**: - `./db2icrt -p50000 -udb2fenc db2inst` - `-p50000`:指定DB2实例的服务端口为50000。
- `-udb2fenc`:指定围栏用户的用户名。
- `db2inst`:指定实例名和所有者名。
3. **设置数据库实例自动启动**: - `su - db2inst1` - `db2iauto on db2inst1`#### 六、配置实例用户为了使DB2实例用户能够正常工作,需要进行相应的环境配置:1. **编辑.bash_profile文件**: - 配置环境变量,如DB2_HOME、JAVA_HOME等,并设置CLASSPATH。
- 示例: ```bash DB2_HOME=/opt/ibm/db2/V9.7 JAVA_HOME=/opt/ibm/db2/V9.7/java/jdk32 CLASSPATH=$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$DB2_HOME/java/db2java.zip:$DB2_HOME/java/db2jcc.jar:$DB2_HOME/java/sqlj.zip:$DB2_HOME/java/db2jcc ```以上步骤详细介绍了在Linux环境下安装配置DB2数据库的过程,从环境准备到具体操作命令,为读者提供了全面且实用的指导。
2025/6/15 19:50:44 26KB
1
简介:
<项目介绍>- 页面可视化搭建框架的页面模板 - 基于 Vue -不懂运行,下载完可以私聊问,可远程教学1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。
3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。
下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。
--------
2025/6/15 19:48:50 41KB
1
简介:
### CAS单点登录服务器配置详解#### 一、CAS单点登录概述CAS(Central Authentication Service)是一种开放源代码的单点登录协议和服务框架,它为Web应用提供了一种简化了的身份验证流程。
通过CAS,用户只需要在一个地方完成登录过程,即可在多个应用间共享登录状态,无需重复登录。
#### 二、CAS服务器安装与配置##### 2.1 安装CAS服务端1. **下载CAS服务端**:首先从官方网址http://www.cas.org/下载最新的CAS服务端压缩包。
2. **部署WAR包**:将下载的WAR包复制到Tomcat的webapps目录下,并将其重命名为`cas.war`。
3. **启动Tomcat**:启动Tomcat服务器,自动解压WAR包,此时会在Tomcat的webapps目录下生成一个名为`cas`的文件夹。
4. **访问CAS**:通过浏览器访问`http://localhost:8896/cas`来测试CAS服务是否正常启动。
##### 2.2 配置CAS使用数据库验证为了实现更安全、更灵活的身份验证机制,我们可以配置CAS使用数据库进行用户身份验证。
具体步骤如下:1. **修改部署配置文件**:打开`cas-server-webapp\WEB-INF\deployerConfigContext.xml`文件,找到`SimpleTestUsernamePasswordAuthenticationHandler`配置项,将其替换为`QueryDatabaseAuthenticationHandler`。
```xml <bean id="authenticationHandler" class="org.jasig.cas.authentication.handler.QueryDatabaseAuthenticationHandler"> <!-- 数据库连接数据源 --> <property name="dataSource" ref="dataSource"/> <!-- 查询语句 --> <property name="sql" value="SELECT password FROM users WHERE username = ?"/> <!-- 密码加密方式 --> <property name="passwordEncoder" ref="passwordEncoder"/> </bean> ```2. **配置数据库连接**:在同一文件中添加一个新的`dataSource` bean来定义数据库连接信息。
```xml <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/casdb"/> <property name="username" value="casuser"/> <property name="password" value="password"/> </bean> ```3. **配置密码加密方式**:继续在同一文件中添加`passwordEncoder` bean来指定密码加密方式,这里使用MD5作为示例。
```xml <bean id="passwordEncoder" class="org.springframework.security.crypto.password.StandardPasswordEncoder"> <constructor-arg value="MD5"/> </bean> ```4. **测试数据库验证**:重启Tomcat服务器,访问CAS服务器页面,使用数据库中的用户名和密码尝试登录,验证是否可以成功登录。
#### 三、CAS工作原理CAS的工作原理主要分为以下几个步骤:1. **用户访问服务**:用户首次访问受保护的资源时,CAS客户端会检测到HTTP请求中缺少ServiceTicket(简称ST),表明用户尚未经过身份验证。
2. **重定向至CAS服务器**:CAS客户端会将用户重定向到CAS服务器进行身份验证,并携带用户的请求URL作为参数(service参数)。
3. **用户认证**:CAS服务器接收到来自用户的认证请求后,引导用户进入登录页面。
用户输入用户名和密码进行登录,若身份验证成功,则CAS服务器通过HTTPS协议返回一个TGC(Ticket-Granting Cookie)给浏览器。
4. **发放ServiceTicket**:CAS服务器生成一个随机的ServiceTicket(简称ST),并将用户重定向回CAS客户端。
5. **验证ServiceTicket**:CAS客户端收到ST后,向CAS服务器验证ST的有效性。
如果验证通过,则允许用户访问受保护资源。
6. **传输用户信息**:CAS服务器验证ST通过后,将用户的相关认证信息发送给CAS客户端。
通过以上步骤,CAS实现了单点登录的功能,极大地提升了用户体验和系统的安全性。
### 四、CAS与HTTPS在配置CAS服务器时,可以选择使用HTTPS协议来增强通信的安全性。
如果选择HTTPS协议,则需要在服务器上配置CAS证书。
证书的创建和导入过程可以参考以下链接:[http://m.blog..net/zrk1000/article/details/51166603](http://m.blog..net/zrk1000/article/details/51166603)### 总结本文详细介绍了如何配置CAS单点登录服务,并重点讲解了如何利用Java代码实现CAS的配置,包括使用数据库进行登录验证的具体步骤。
同时,还阐述了CAS的基本工作原理,帮助读者更好地理解CAS的工作流程和技术细节。
2025/6/15 19:47:19 293KB
1
共 1000 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡