JSR303,全称为JavaSpecificationRequest303,是JavaCommunityProcess(JCP)提出的一个关于BeanValidation的标准,旨在提供一种统一的方式来验证JavaBeans对象的属性。
这个标准定义了一种元数据模型以及相关的API,使得开发者可以在运行时对对象进行校验,确保数据的正确性。
在JSR303中,主要涉及到三个关键组件,这些组件在描述中提到的三个jar包中体现:1.**HibernateValidator**:作为JSR303的实现,HibernateValidator是领先的JavaBeanValidation框架。
`hibernate-validator-4.3.2.Final.jar`就是这个实现的版本。
它提供了丰富的约束注解,如`@NotNull`,`@Size`,`@Pattern`等,可以方便地在bean的字段上声明验证规则。
此外,HibernateValidator还支持自定义验证注解和约束,以及国际化消息支持,以适应不同的应用场景。
2.**JBossLogging**:`jboss-logging-3.1.0.CR2.jar`是JBoss社区开发的日志框架,它为应用提供了一个统一的日志接口,可以适配多种日志实现,如Log4j、Logback等。
在HibernateValidator中,JBossLogging用于处理验证过程中产生的日志信息,帮助开发者追踪错误和调试代码。
3.**ValidationAPI**:`validation-api-1.0.0.GA.jar`是JSR303规范的API接口定义,包含了验证的核心接口和注解。
例如,`javax.validation.Validation`接口提供了验证器的创建,`javax.validation.ConstraintViolation`接口表示验证失败的情况。
这个API使得其他库可以轻松地与JSR303兼容,无论它们是否使用了HibernateValidator的具体实现。
这三个库一起构成了JSR303验证机制的基础。
在实际开发中,通常会将这些jar包加入到项目的类路径中,然后在Bean对象的属性上使用JSR303提供的注解进行约束声明,通过`Validator`接口进行验证操作。
例如:```javapublicclassUser{@NotNullprivateStringname;@Size(min=6,max=20)privateStringpassword;//gettersandsetters}```在此基础上,可以创建一个`Validator`实例,对User对象进行验证:```javaValidatorFactoryfactory=Validation.buildDefaultValidatorFactory();Validatorvalidator=factory.getValidator();Useruser=newUser();Set>violations=validator.validate(user);if(!violations.isEmpty()){for(ConstraintViolationviolation:violations){System.out.println(violation.getMessage());}}```这样,当用户输入不符合规则的数据时,系统将打印出相应的错误信息,从而提供良好的用户体验和数据安全性。
JSR303和其相关实现的使用,简化了数据验证的代码,提高了代码的可读性和可维护性,是现代Java应用中不可或缺的一部分。
2025/11/8 7:37:49 496KB hibernate validator jboss logging
1
magento颜色属性切换图片,兼容1.4-1.9,有说明文档,和安装截图
2025/11/7 4:30:03 752KB magento 颜色属性
1
第1章绪论1.1计算机图形学及其相关概念1.2计算机图形学的发展1.2.1计算机图形学学科的发展1.2.2图形硬件设备的发展1.2.3图形软件的发展1.3计算机图形学的应用1.3.1计算机辅助设计与制造1.3.2计算机辅助绘图1.3.3计算机辅助教学1.3.4办公自动化和电子出版技术1.3.5计算机艺术1.3.6在工业控制及交通方面的应用1.3.7在医疗卫生方面的应用1.3.8图形用户界面1.4计算机图形学研究动态1.4.1计算机动画1.4.2地理信息系统1.4.3人机交互1.4.4真实感图形显示1.4.5虚拟现实1.4.6科学计算可视化1.4.7并行图形处理第2章计算机图形系统及图形硬件2.1计算机图形系统概述2.1.1计算机图形系统的功能2.1.2计算机图形系统的结构2.2图形输入设备2.2.1键盘2.2.2鼠标器2.2.3光笔2.2.4触摸屏2.2.5操纵杆2.2.6跟踪球和空间球2.2.7数据手套2.2.8数字化仪2.2.9图像扫描仪2.2.10声频输入系统2.2.11视频输入系统2.3图形显示设备2.3.1阴极射线管2.3.2CRT图形显示器2.3.3平板显示器2.3.4三维观察设备2.4图形显示子系统2.4.1光栅扫描图形显示子系统的结构2.4.2绘制流水线2.4.3相关概念2.5图形硬拷贝设备2.5.1打印机2.5.2绘图仪2.6OpenGL图形软件包2.6.1OpenGL的主要功能2.6.2OpenGL的绘制流程2.6.3OpenGL的基本语法2.6.4一个完整的OpenGL程序第3章用户接口与交互式技术3.1用户接口设计3.1.1用户模型3.1.2显示屏幕的有效利用3.1.3反馈3.1.4一致性原则3.1.5减少记忆量3.1.6回退和出错处理3.1.7联机帮助3.1.8视觉效果设计3.1.9适应不同的用户3.2逻辑输入设备与输入处理3.2.1逻辑输入设备3.2.2输入模式3.3交互式绘图技术3.3.1基本交互式绘图技术3.3.2三维交互技术3.4OpenGL中橡皮筋技术的实现3.4.1基于鼠标的实现3.4.2基于键盘的实现3.5OpenGL中拾取操作的实现3.6OpenGL的菜单功能第4章图形的表示与数据结构4.1基本概念4.1.1基本图形元素4.1.2几何信息与拓扑信息4.1.3坐标系4.1.4实体的定义4.1.5正则集合运算4.1.6平面多面体与欧拉公式4.2三维形体的表示4.2.1多边形表面模型4.2.2扫描表示4.2.3构造实体几何法4.2.4空间位置枚举表示4.2.5八叉树4.2.6BSP树4.2.7OpenGL中的实体模型函数4.3非规则对象的表示4.3.1分形几何4.3.2形状语法4.3.3粒子系统4.3.4基于物理的建模4.3.5数据场的可视化4.4层次建模4.4.1段与层次建模4.4.2层次模型的实现4.4.3OpenGL中层次模型的实现第5章基本图形生成算法5.1直线的扫描转换5.1.1数值微分法5.1.2中点Bresenham算法5.1.3Bresenham算法5.2圆的扫描转换5.2.1八分法画圆5.2.2中点Bresenham画圆算法5.3椭圆的扫描转换5.3.1椭圆的特征5.3.2椭圆的中点Bresenham算法5.4多边形的扫描转换与区域填充5.4.1多边形的扫描转换5.4.2边缘填充算法5.4.3区域填充5.4.4其他相关概念5.5字符处理5.5.1点阵字符5.5.2矢量字符5.6属性处理5.6.1线型和线宽5.6.2字符的属性5.6.3区域填充的属性5.7反走样5.7.1过取样5.7.2简单的区域取样5.7.3加权区域取样5.8在OpenGL中绘制图形5.8.1点的绘制5.8.2直线的绘制5.8.3多边形面的绘制5.8.4OpenGL中的字符函数5.8.5Op
2025/11/5 19:37:38 110.55MB 图形学 VR
1
"java写三国杀源文件"揭示了一个基于Java编程语言开发的三国杀游戏项目。
在软件工程中,源文件是程序员编写代码的原始文本文件,通常以`.java`为扩展名,它们被编译成字节码,然后由Java虚拟机执行。
这个项目的名称"Alpha"版本0.5.11表明它仍处于早期开发阶段,可能存在一些未完善的功能或错误。
提到“基本实现了三国杀标准版的25个武将104张牌的所有技能”,这意味着开发者已经成功地编程实现了游戏的核心机制。
三国杀是一款基于三国历史背景的桌面策略卡牌游戏,其中包含各种武将角色,每个武将有独特的技能,以及多样的卡牌用于攻击、防御和策略。
25个武将对应了游戏中不同的角色选择,104张牌则是游戏中的道具和事件。
开发者已经把这些复杂的游戏规则转化为可执行的计算机程序。
在Java中实现这样的游戏,开发者可能使用面向对象编程思想,为每个武将和卡牌创建类,并定义相应的属性和方法。
例如,武将类可能包含一个表示其技能的方法,而卡牌类可能包含关于其效果的逻辑。
此外,游戏流程的控制可能通过一个主循环实现,处理玩家的回合、出牌、判定等过程。
由于项目还处于Alpha阶段,这意味着它可能缺乏完整的用户界面、稳定性测试、优化以及详细的文档。
开发者可能还在进行功能添加、bug修复和性能改进。
对于有兴趣深入学习或者参与该项目的人来说,这提供了一个很好的实践平台,可以了解如何将复杂的规则系统转化为代码,以及如何进行游戏逻辑的实现和调试。
"java"和"源文件"明确指出项目的技术栈和交付物,而"三国杀"则说明了应用领域。
Java是一种广泛应用的编程语言,以其跨平台性、稳定性和强大的库支持而闻名,非常适合开发这样的桌面游戏。
源文件的提供意味着源代码是公开的,允许其他人学习、修改和扩展项目。
这个Java实现的三国杀项目为学习游戏开发、Java编程以及项目管理提供了宝贵的资源。
开发者需要理解游戏规则,将其抽象为数据结构和算法,然后用Java语言表达出来。
同时,通过参与到这个项目,可以提升问题解决能力、代码组织技巧以及团队协作经验。
对于对三国杀游戏感兴趣的爱好者来说,这是一个将爱好与技术结合的绝佳机会。
2025/11/5 18:22:38 6.39MB java
1
Tomcat是Apache软件基金会下的一个开源项目,主要负责运行JavaServlet和JavaServerPages(JSP)的应用服务器。
它是JavaEEWeb应用的标准实现之一,广泛应用于各种规模的企业级应用开发和部署。
本压缩包"tomcat8.5.47全部版本集合(linux-window64位-window32位).rar"提供了Tomcat8.5.47在三种操作系统环境下的版本:Linux、Windows64位以及Windows32位,确保了在不同平台上的兼容性。
Tomcat8.5系列是Tomcat的一个重要版本,它引入了许多增强和改进。
以下是关于Tomcat8.5.47的一些关键知识点:1.**性能优化**:Tomcat8.5对连接器(Connector)进行了优化,提高了处理HTTP请求的效率,特别是在高并发场景下,性能表现更为出色。
2.**SSL/TLS支持**:8.5版本加强了对SSL/TLS协议的支持,包括支持TLSv1.1和TLSv1.2,以应对日益增长的安全需求。
同时,提供了一种名为“SNI”(ServerNameIndication)的扩展,可以在一个IP地址上托管多个使用不同SSL证书的网站。
3.**NIO2连接器**:除了原有的BIO和NIO连接器,8.5版本引入了NIO2连接器,利用Java7的FileChannel和AsynchronousFileChannel,提供了更好的异步I/O能力。
4.**WebSocket支持**:Tomcat8.5开始全面支持WebSocket协议,这是HTML5标准的一部分,允许双向通信,为实时Web应用提供了基础。
5.**JMX改进**:管理工具得到了增强,包括JavaManagementExtensions(JMX)的改进,使得监控和管理Tomcat服务器变得更加便捷。
6.**部署灵活性**:支持热部署,开发者可以在线修改Web应用,而无需停止服务。
同时,提供了自动解压缩WAR文件的功能,方便快速部署。
7.**MBean注册**:每个Servlet、Filter和Listener都会被注册为一个MBean,增强了可管理和可监控性。
8.**JSP引擎升级**:使用了Jasper6,对JSP编译过程进行了优化,提升了JSP页面的处理速度。
9.**安全性**:8.5版本强化了安全策略,修复了多个安全漏洞,以保护服务器免受恶意攻击。
10.**配置改进**:配置文件更加简洁,易于理解和维护,同时也支持XML和属性文件混合配置。
针对不同的操作系统,安装和配置Tomcat的方法略有不同。
例如,Linux环境下通常需要通过命令行操作,而Windows用户则可以使用图形界面进行安装。
无论哪种系统,都需要确保JavaDevelopmentKit(JDK)已经安装并设置好JAVA_HOME环境变量,因为Tomcat依赖于JDK来运行。
在解压此压缩包后,你可以根据需要选择对应操作系统的版本进行安装。
对于Linux,通常需要将Tomcat目录复制到指定的服务器路径,如`/opt/tomcat`,然后设置相应的启动脚本和服务配置。
Windows用户则可以直接运行bin目录下的startup.bat或startup.sh来启动服务。
Tomcat8.5.47是JavaWeb应用开发和部署的重要工具,这个集合包提供了跨平台的解决方案,适应了开发者和运维人员的不同需求。
无论是进行本地开发测试还是在生产环境中部署,都有相应的版本可以选择。
1
《matlabgui设计学习手记(第2版)》首先介绍了gui设计的预备知识;
然后详细讲解了gui对象的属性及两种创建gui的方法:采用函数创建和采用guide创建;
之后深入讲解了activex控件、定时器、串口及mcc编译的相关知识;
最后,书中给出两个综合实例,供读者研究学习。
书中穿插了大量的图表和例题,方便读者边查边练。
《matlabgui设计学习手记(第2版)》适合需要短时间内迅速掌握matlabgui设计的初学者,也可作为相关专业师生或工程开发人员的参考手册。
第1章GUl设计预备知识第2章文件1/O第3章二维绘图简介第4章句柄图形系统第5章预定义对话框第6章采用GUIDE建立GUI第7章ActiveX控件第8章定时器第9章串口编程第10章mcc编译第11章综合实例附录MATLABGUI设计常用函数
2025/10/29 4:26:03 45.69MB matlab GUI设计
1
第二次作业:1.编写点类(Point类),属性成员有x,y,都是double数据类型。
需要为Point类编写构造函数。
编写直线类(Line类),需要提供两点确定一条直线的函数功能。
如果两点重合,可以返回异常或者返回null引用来解决这个问题。
直线类的数据成员和函数成员请自行设计。
2.给定文本文件,文件名称为a.txt,文件内容为一个8行8列的字符矩阵,内容为1和0字符,请编程计算出该矩阵中水平方向或者垂直方向或者斜线方向连续1最多的个数。
例如:1100110110110101010101011100100001010101110011010001100011110000 3.编写程序求出1万以内的所有素数,并将这些素数输出到一个文本文件中,每行文本只包含一个素数数据。
该文本文件内容要求可以用记事本程序来查看。
4.编写程序求出1万以内的所有素数,然后再判断这些素数中哪些是由素数拼接而成的。
例如素数23就符合条件,23本身是素数,其由素数2,和素数3拼接(连接)组成。
素数29就不满足条件,2是素数,而9不是素数。
素数307不满足条件,不能忽略0. 7907这个素数符合条件,7是素数,907是素数。
需要把符合条件的拼接素数全部输出,并统计个数。
5.要求从控制台输入英语单词及单词解释两项数据,把录入的数据追加到文件中。
要求提供单词查询功能。
用户输入单词后,从单词库文件中查找,如果存在则输出该单词的解释。
注意,单词不能有重复,如果重复则覆盖替换以前的解释数据。
6.通过命令行参数输入一个文件夹的路径名称,然后编写程序找出该文件夹下文件名称重复并且文件大小也一样的文件,如果没有“重复文件”,则输出“没有重复文件”的提示,如果有,需要输出文件名称,和文件所在的文件夹路径(绝对路径)。
提示,需要遍历该文件夹下所有子文件夹,设计一个文件类,属性包括文件名称,文件路径,文件大小,然后进行“重复” 判断,如果文件重复,则需要记录并输出,有可能有文件名重复,但是文件大小不一样,重复的文件可能不止2个,可能 在不同的子文件夹下有多个文件重复。
7.霍夫曼编码实现压缩文本文件,见文件huffman.rar.对文件数据读写等功能已经实现,程序在Q2Resources.zip中。
Q2Resources.zip中的文件禁止修改。
请将TextZip.java文件所有未实现的函数按照要求给以实现。
2025/10/28 6:08:10 49KB Java
1
MFCwindow鼠标钩子,windows桌面鼠标钩子,获取鼠标位置窗口属性,鼠标消息等等
138KB mousehook mfc
1
前半部分讲解的很基础而详细,后半部分附有大量案例。
发下目录,自己看着办吧。
目录译者序前言第一部分基础第1章概述 11.1Windows基础 11.1.1窗口类结构 21.1.2消息 21.1.3客户区和非客户区 21.1.4重叠窗口、弹出窗口和子窗口 21.1.5父窗口和宿主窗口 31.2Windows消息 31.2.1发送或寄送消息 41.2.2消息类型 41.2.3接收消息 41.2.4窗口处理函数的子类化 51.3窗口绘图 51.3.1设备环境 51.3.2绘图工具 61.3.3映射模式 61.3.4窗口视和视口视 61.3.5逻辑单位和设备单位 71.3.6绘图函数 71.3.7抖动和非抖动颜色 71.3.8设备无关位图 81.3.9元文件 81.3.10何时绘图 81.4MFC基础 81.5DeveloperStudio基础 91.6Windows和MFC总结 101.7基本类 101.8应用类 111.8.1文档视 111.8.2CWinApp(OC) 111.8.3文档模板 121.8.4线程 121.8.5CFrameWnd(OCW) 121.8.6CDocument(OC) 121.8.7CView(OCW) 131.8.8对话框应用程序 131.8.9SDI应用程序 131.8.10MDI应用程序 131.9其余用户界面类 131.9.1通用控件类 131.9.2菜单类(O) 141.9.3对话框类 151.9.4通用对话框MFC类 151.9.5控件条类(OCW) 151.9.6属性类 151.10绘图类 161.11其他MFC类 161.11.1文件类 161.11.2CArchive和序列化 161.11.3数据库类 171.11.4ODBC类 171.11.5DAO类 171.11.6数据集合类 171.11.7通信类 181.12类的消息机制 181.12.1MFC如何接收一个寄送消息 181.12.2MFC如何处理接收的消息 181.12.3UI对象 201.13小结 20第2章控制条 212.1通用控制条 212.2用API创建控制条 222.3用MFC创建控制条 242.3.1CToolBarCtrl和CStatusBarCtrl 242.3.2CToolBar和CStatusBar 242.3.3CControlBar 262.4停靠栏 272.4.1设置停靠功能 282.4.2自动改变大小和移动 302.4.3停靠栏小结 302.5浮动条 312.6MFC的高级控制条类小结 322.7视和控制条如何共享客户区 322.7.1CFrameWnd::RecalcLayout() 32 2.7.2CWnd::RepositionBars() 332.7.3CControlBar::OnSizeParent() 332.7.4CalcDynamicLayout()和CalcFixedLayout() 342.7.5CToolBar::CalcFixedLayout()和CToolBar::CalcDynamicLayout() 352.7.6工具栏布局 352.7.7CStatusBar::CalcFixedLayout() 362.7.8CDockBar::CalcFixedLayout() 362.7.9共享客户区小结 362.8对话条 372.9伸缩条 382.9.1CReBar和CReBarCtrl 392.9.2CReBar::CalcFixedLayout() 392.10命令条 392.11控制条窗口小部件风格 402.11.1工具栏按钮风格 402.11.2状态栏窗格风格 402.11.3伸缩条段风格 402.12设计自己的控制条 412.12.1重载CControlBar::CalcDynamic-Layout() 412.12.2增加WM_SIZEPARENT消息处理器 412.12.3重载CMainFrame::RecalcLayout() 412.12.4从CDockBar派生 422.13实例 422.14总结 42第3章通信 433.1进程间通信 433.1.1通信策略 433.1.2同步和异步通信 443.2窗口消息 443.2.1打开和关闭 443.2.2读与写 453.2.3回顾 453.3动态数据交换 463.3.1客户/服务器 463.3.2打开和关闭 463.3.3读和写 473.3.4其他DDE函数 483.3.5MFC支持 483.3.6回顾 493.4消息管道 493.4.1打开和关闭 493.4.2读和写 503.4.3回顾 513.5Windows套接字 513.5.1打开和关闭 523.5.2读和写 523.5.2通过Windows套接字序列化 533.5.3数据流和数据报 533.5.4回顾 543.6串行/并行通信 543.6.1打开和关闭 543.6.2读和写 543.6.3配置端口 553.6.4回顾 553.7Internet通信 563.7.1打开和关闭文件 563.7.2读文件 563.7.3打开和关闭连接 563.7.4其他Internet类 573.8通信方式小结 573.9共享数据 583.10共享内存文件 583.10.1创建和销毁 583.10.2读和写 583.10.3回顾 593.11文件映射 593.11.1打开和关闭 593.11.2读和写 603.11.3数据同步 603.11.4回顾 603.12客户/服务器 613.12.1传递调用参数 613.12.2远程过程调用 623.13小结 62第二部分用户界面实例第4章应用程序和环境 644.1实例1:在工具栏中添加静态标识符 644.2实例2:在工具栏中添加动态标识符 714.3实例3:只启动一个实例 754.4实例4:创建对话框/MDI混合式应用程序 774.5实例5:在系统托盘中添加图标 794.6实例6:主菜单状态栏中的标记 81第5章菜单、控件条和状态栏 855.1实例7:在菜单中添加图标 855.2实例8:调整命令条外观 975.3实例9:可编程工具栏 1025.4实例10:在对话框中添加工具栏、菜单和状态栏 1275.5实例11:在弹出菜单中增加位图标记 1295.6实例12:工具栏上的下拉按钮 1315.7实例13:在状态栏中添加图标 1365.8实例14:使用伸缩条 141第6章视 1436.1实例15:创建标签窗体视 1436.2实例16:创建具有通用控件的视 1506.3实例17:打印报表 1566.4实例18:打印视 1676.5实例19:绘制MDI客户视 1746.6实例20:拖放文件到视 177第7章对话框和对话条 1797.1实例21:动态改变对话框的尺寸 1797.2实例22:自定义数据交换并验证 1847.3实例23:重载通用文件对话框 1877.4实例24:重载通用颜色对话框 1907.5实例25:获得目录名 1927.6实例26:子对话框 1977.7实例27:子属性表 198第8章控件窗口 2008.1实例28:自己绘制的控件 2008.2实例29:在窗口标题中添加按钮 2048.3实例30:添加热键控件 211第9章绘图 2139.1实例31:使用非散射颜色 2139.2实例32:伸展位图 2279.3实例33:抓取屏幕 2319.4实例34:输出DIB位图文件 236第10章帮助 24310.1实例35:添加帮助菜单项 24310.2实例36:添加上下文相关帮助 24510.3实例37:添加气泡帮助 247第11章普通窗口 25411.1实例38:创建普通窗口 25411.2实例39:创建短调用形式窗口类 25611.3实例40:创建长调用形式窗口类 258第12章特定的应用程序 26112.1实例41:创建简单的文本编辑器 26112.2实例42:生成简单的RTF编辑器 26212.3实例43:创建资源管理器界面 26512.4实例44:创建简单的ODBC数据库编辑器 28412.5实例45:创建简单的DAO数据库编辑器 28712.6实例46:创建简单的向导 289第三部分内部处理实例第13章消息和通信 29513.1实例47:等待消息 29613.2实例48:清除消息 29713.3实例49:向其他应用程序发送消息 29813.4实例50:与其他应用程序共享数据 30013.5实例51:使用套接字与任意的应用程序通信 30113.6实例52:使用串行或并行I/O 321第14章多任务 33114.1实例53:后台处理 33114.2实例54:运行其他应用程序 33214.3实例55:改变优先级 33414.4实例56:应用程序内部的多任务工作者线程 33614.5实例57:应用程序内部的多任务—用户界面线程 33914.6实例58:向用户界面线程发送消息 34214.7实例59:线程间的数据共享 343第15章其他 34715.1实例60:创建定时器 34715.2实例61:播放声音 34915.3实例62:创建VC++宏 35015.4实例63:使用函数地址 35115.5实例64:二进制字符串 35215.6实例65:重新启动计算机 35615.7实例66:获得可用磁盘空间 35715.8实例67:闪烁窗口和文本 358第四部分附录附录A消息和重载顺序 361附录B绘图结构 385
2025/10/26 16:29:39 6.89MB MFC
1
C++语言编写的关于属性重要度的算法实现,对粗糙集初学者来说主要很好的指导价值
2025/10/26 7:45:30 17KB 属性重要度 C++ 算法 粗糙集
1
共 1000 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡