监控系统升级改造方案旨在提高安全监控的质量和效率,以适应现代社会对安防需求的不断提升。
本文档主要探讨了监控系统升级的必要性、当前系统的不足、需求分析、系统架构设计以及前端和设备选型。
监控系统在治安防范中扮演着至关重要的角色,尤其在预防、发现和控制潜在风险方面,其作用不可忽视。
鉴于现有的监控系统建立已久,使用的是SYV-75-5同轴电缆传输信号的模拟标清系统,随着时间推移和视频技术的进步,系统存在的问题逐渐暴露:视频清晰度低,设备老化,监控盲区以及无法与下属单位平台对接进行紧急联动。
这些问题使得原有的监控系统效能大打折扣,急需进行数字化高清改造。
改造的目标是将整个监控系统从模拟标清升级为数字高清,包括替换前端摄像机、存储设备等,确保所有设备支持高清图像效果。
新增监控点位以消除盲区,同时在关键位置设置显示系统,如门卫处,以便实时监控和录像回放。
系统架构设计方面,改造后的网络高清视频监控系统主要由前端图像采集、高清传输、高清存储和综合管理平台等模块组成。
网络摄像机作为图像采集设备,通过网络线缆连接至接入交换机,再通过核心层交换机实现高密度接入。
传输交换系统确保数据的安全接入和稳定传输,而高清存储系统则利用IP存储技术提供灵活的存储资源管理,支持备份和生命周期管理。
管理平台作为系统核心,负责图像资源的调度、管理、分发和互通。
在前端设备选型上,重要区域和出入口将安装高清枪机和半球,室外点位可能采用全景网络摄像机或枪机和球机。
同时,文档提到了网络摄像机的分类,包括标清和高清网络摄像机,以满足不同分辨率的需求。
监控系统的升级改造是一个综合性的工程,涉及硬件设备更新、网络架构优化以及管理平台的升级,旨在提升监控系统的清晰度、稳定性和联动能力,从而更好地服务于安防需求,提高公共安全防控水平。
这一过程需要充分考虑实际使用场景、设备兼容性以及未来扩展的可能性,确保投资的有效性和系统的可持续性。
2025/6/16 5:23:23 1.03MB
1
目录前言1.翻译说明1.在Tomcat中快速上手1.1.开始Hibernate之旅1.2.第一个可持久化类1.3.映射cat1.4.与猫同乐1.5.结语2.体系结构2.1.总览2.2.JMX集成2.3.JCA支持3.SessionFactory配置3.1.可编程配置方式3.2.获取SessionFactory3.3.用户自行提供JDBC连接3.4.Hibernate提供的JDBC连接3.5.可选配置属性3.5.1.SQLDialectsSQL方言3.5.2.外连接抓取(OuterJoinFetching)3.5.3.二进制流3.5.4.自定义CacheProvider3.5.5.事务策略配置3.5.6.绑定SessionFactory到JNDI3.5.7.查询语言替换3.6.Logging3.7.实现NamingStrategy(命名策略)3.8.XML配置文件4.持久化类(PersistentClasses)4.1.POJO简单示例4.1.1.为持久化字段声明访问器(accessors)和是否可变的标志(mutators)4.1.2.实现一个默认的构造方法(constructor)4.1.3.提供一个标识属性(identifierproperty)(可选)4.1.4.建议使用不是final的类(可选)4.2.实现继承(Inheritance)4.3.实现equals()和hashCode()4.4.持久化生命周期(Lifecycle)中的回调(Callbacks)4.5.合法性检查(Validatable)回调4.6.XDoclet标记示例5.O/RMapping基础5.1.映射声明(Mappingdeclaration)5.1.1.Doctype5.1.2.hibernate-mapping5.1.3.class5.1.4.id5.1.4.1.generator5.1.4.2.高/低位算法(Hi/LoAlgorithm)5.1.4.3.UUID算法(UUIDAlgorithm)5.1.4.4.标识字段和序列(IdentitycolumnsandSequences)5.1.4.5.程序分配的标识符(AssignedIdentifiers)5.1.5.composite-id联合ID5.1.6.识别器(discriminator)5.1.7.版本(version)(可选)5.1.8.时间戳(timestamp)(可选)5.1.9.property5.1.10.多对一(many-to-one)5.1.11.一对一5.1.12.组件(component),动态组件(dynamic-component)5.1.13.子类(subclass)5.1.14.连接的子类(joined-subclass)5.1.15.map,set,list,bag5.1.16.引用(import)5.2.Hibernate的类型5.2.1.实体(Entities)和值(values)5.2.2.基本值类型5.2.3.持久化枚举(Persistentenum)类型5.2.4.自定义值类型5.2.5.映射到"任意"(any)类型5.3.SQL中引号包围的标识符5.4.映射文件的模块化(Modularmappingfiles)6.集合类(Collections)映射6.1.持久化集合类(PersistentCollections)6.2.映射集合(MappingaCollection)6.3.值集合和多对多关联(CollectionsofValuesandMany-To-ManyAssociations)6.4.一对多关联(One-To-ManyAssociations)6.5.延迟初始化(延迟加载)(LazyInitializa
2025/6/15 21:44:18 262KB hibernate 教程 hibernate教程
1

本例中敏感词ciku.txt放在C盘根目录下,采用的ActiveXObject插件获取本地文件内容。
使用此插件不需网上下插件,直接用如下js代码即可。
浏览器需修改interner安全选项的级别,启用ActiveX才能获取到代码中的ActiveXObject插件。
如下图所示:js代码实现如下:[removed] // -------------- 全局变量,用来判断文本域中是否包含脏词,默认为false,即不包含脏词------- var isDirty = false; //使用ActiveX读取本地文件获取dirt在JavaScript中,有时我们需要在用户提交表单时检查输入内容是否包含敏感词,以防止不当内容的发布。
本文介绍了一种使用ActiveXObject技术在IE浏览器中实现这一功能的方法。
ActiveXObject是Internet Explorer特有的,它允许JavaScript与本地操作系统交互,如读取本地文件。
我们需要在本地(例如C盘根目录)创建一个名为`ciku.txt`的文本文件,其中包含了我们定义的敏感词。
然后,通过JavaScript的ActiveXObject来读取这个文件的内容。
以下是关键的JavaScript代码:```javascriptvar isDirty = false;function readFile() { var fso = new ActiveXObject("Scripting.FileSystemObject"); var openF = fso.OpenTextFile("c:\\ciku.txt", 1); var cikuStr = openF.ReadAll(); return cikuStr;}````readFile()`函数使用`Scripting.FileSystemObject`对象打开并读取`ciku.txt`文件,然后将敏感词返回给其他函数处理。
当用户尝试提交表单时,会触发`submitForm1()`函数。
这个函数首先获取用户在表单文本域中输入的内容,然后检查是否包含敏感词。
如果发现敏感词,它会调用`filterWord()`函数替换敏感词,并弹出提示让用户确认是否继续提交。
如果用户确认,表单会被提交;
否则,提交操作会被取消。
`filterWord()`函数接收用户输入的内容,读取敏感词列表,然后对每个敏感词调用`filterOneWord()`函数进行替换。
`filterOneWord()`使用正则表达式和`replace()`方法将敏感词替换为星号("**")。
表单部分的HTML代码如下:```html<form name="message_board" id="message_board" action="aaa.html"> <textarea name="message" id="message" cols="50" rows="10">"This is you post messsage"——phpdream</textarea> <br/> <input type="button" value="提交留言" id="submitMessage" onclick="submitForm1()" /></form>```需要注意的是,由于ActiveXObject是IE特有的,这种方法在其他非IE浏览器(如Chrome、Firefox、Safari或Edge)上无效。
为了实现跨浏览器兼容,可以考虑使用其他技术,如FileReader API(适用于现代浏览器)或者将敏感词库保存在服务器端,通过Ajax请求获取。
此外,为了使用ActiveXObject,用户需要在浏览器的安全设置中启用ActiveX控件,这可能带来安全风险,因此在实际应用中应谨慎使用,并确保对用户有明确的提示和说明。
2025/6/15 22:22:47 97KB
1

在IT领域,文本编辑器是开发人员日常工作中不可或缺的工具,尤其对于编程语言如C#的开发者来说。
本文将深入探讨一个由C#构建的文本编辑器,它具备多文档支持、拖放功能、查找替换等多种特性,为用户提供高效且舒适的编辑体验。
这个文本编辑器具有“多文档”支持,意味着用户可以同时打开并编辑多个文本文件,无需在不同的窗口间频繁切换。
这一特性极大地提高了工作效率,尤其是在处理多个项目或者需要对比不同文件内容时。
“可直接拉文件”功能是该编辑器的一大亮点。
用户可以直接通过鼠标将文件从文件管理器拖放到编辑器界面上,快速打开文件进行编辑,这比传统的通过菜单或文件打开对话框选择文件的方式更为便捷。
此外,编辑器提供了“查找替换”功能,这是文本编辑器的核心功能之一。
用户可以通过输入关键词进行快速查找,同时也可以进行替换操作,对大量文本进行快速修改,这对于代码调试、文档整理等场景非常实用。
查找替换功能通常会支持正则表达式,使得搜索和替换操作更加灵活和强大。
至于“记事本”标签,暗示了这个编辑器的设计可能受到了Windows系统内置的记事本程序的启发,但显然它的功能更为丰富,界面设计更友好,用户体验更好。
记事本虽然简单,但在某些场合下可能无法满足专业开发的需求,而这款C#文本编辑器则弥补了这些不足。
在C#编程语言的支持下,这个文本编辑器可以利用.NET框架提供的丰富的类库和API,实现高效稳定的操作。
C#的面向对象特性使得代码结构清晰,易于维护和扩展,同时也为编辑器的定制化提供了可能,用户可以根据需要添加自定义插件或功能。
这款C#多文档文本编辑器是一个高效、易用的开发工具,其拖放功能、多文档支持以及强大的查找替换功能,为开发者带来了极大的便利。
配合C#的编程优势,这款编辑器无论是对于初学者还是经验丰富的开发者,都是一个值得尝试的选择。
在实际使用中,用户可以进一步探索其特性,提升工作效率,享受更加优质的文本编辑体验。
2025/6/15 22:15:24 1.56MB
1
简介:
在面对从较旧版本的SQL Server数据库向新一代SQL Server数据库迁移时,经常会遇到兼容性问题。
本文所探讨的SQL Server 2008与SQL Server 2005之间的备份还原兼容问题,以及解决方法,对于数据库管理员来说,是非常有价值的信息。
由于版本升级,SQL Server 2008与SQL Server 2005在数据库引擎方面存在一些差异,这些差异可能导致在还原备份文件时遇到阻碍。
SQL Server 2005的备份文件在SQL Server 2008中遇到的主要问题是兼容性,因为SQL Server 2008使用的是更新的数据库引擎和功能集。
解决方法的第一步涉及界面操作的调整,具体操作为:在SQL Server Management Studio(SSMS)中,不要在数据库名字上直接点击右键来选择还原,而是应该点击左上角的“数据库”节点后,再右键点击选择还原,并在弹出的界面中选择目标数据库。
这一操作实际上是在引导SQL Server 2008识别并处理备份文件时,使用正确的还原方法和路径。
如果上述方法没有解决问题,接下来可以采用SQL语句的方式来进行还原操作。
使用的SQL语句是RESTORE DATABASE命令,该命令是用来恢复一个数据库到一个特定的状态。
这个语句中,‘databaseName’应该替换为你实际想要还原的数据库名称,‘X:\数据库备份\database.bak’则应该替换为实际的备份文件路径。
参数‘withreplace’表示如果存在同名数据库时将被替换,‘NOUNLOAD’表示在还原期间不会卸载磁带,‘STATS=10’则表示在还原过程中每处理10%的信息时显示一次状态信息。
使用SQL语句进行还原的这种方法,优点是灵活性高,可以根据需要进行更细致的控制和调整。
例如,如果需要更详细地控制还原过程中的行为,还可以添加其它参数,如‘MOVE’可以指定数据文件和日志文件的位置,‘FILE’可以指定还原特定的文件等。
以上介绍的两种方法可以有效地帮助数据库管理员解决SQL Server 2008还原SQL Server 2005备份文件遇到的兼容性问题。
对于遇到3154错误代码的用户,第二种方法通过命令行的方式进行操作,提供了一种可以绕过图形界面限制的解决方案。
3154错误通常出现在还原数据库时,源数据库文件的头信息无法正确读取,这可能与备份文件和SQL Server版本不匹配有关。
需要指出的是,在进行数据库还原操作之前,务必确保对备份文件的完整性进行验证,以及做好相关的数据备份,以防还原过程中发生意外导致数据丢失。
此外,在实际操作中,数据库管理员应根据自己的具体情况灵活选择解决方案,并且在操作之前,建议在测试环境中先行验证方法的有效性,以避免生产环境出现不可预测的风险。
总结来说,升级数据库版本是许多组织发展历程中的必经之路,而在升级过程中处理好数据库的备份与还原问题,是保证数据安全与业务连续性的关键。
本文所提到的解决方法,针对SQL Server 2008与SQL Server 2005之间的兼容性问题给出了实用的解决方案,对于数据库管理员来说,不仅可以作为参考,而且可以在实际工作中付诸实践,以应对类似的挑战。
2025/6/15 19:59:36 33KB
1
简介:
1.版本:matlab2014/2019a/2021a 2.附赠案例数据可直接运行matlab程序。
3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。
4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
5.作者介绍:某大厂资深算法工程师,从事Matlab算法仿真工作10年;
擅长智能优化算法、神经网络预测、信号处理、元胞自动机等多种领域的算法仿真实验,更多仿真源码、数据集定制私信+。
替换数据可以直接使用,注释清楚,适合新手
2025/6/15 19:56:22 301KB
1
简介:
Reap是一个开源项目,它的主要目标是对开源软件进行优化处理,去除其中的冗余部分,并用依赖项替换它们。
这个过程对于提升软件的效率、减少资源占用以及优化整体性能至关重要。
在开源社区中,Reap可能被视为一种工具或框架,帮助开发者更有效地管理和维护他们所使用的开源组件。
在Reap的背景下,"sage-2.8.5.1"这个文件可能是Sage数学软件的一个特定版本。
Sage是一个强大的开源数学计算环境,它集合了多个数学软件包,如Python、NumPy、SciPy等,为用户提供了一个统一的界面来执行各种数学运算。
Reap对Sage的这个版本进行了处理,可能去除了其中不必要的部分,或者更新了某些过时的依赖,使得用户可以得到一个更轻量级且高效的版本。
在开源软件的世界里,冗余代码和不必要的依赖性可能会导致软件体积庞大,运行缓慢,甚至可能导致兼容性问题。
Reap的工作原理可能是通过分析软件的源代码和依赖关系,找出可以被其他库或模块替代的部分,然后进行替换,或者直接删除无用的代码,以实现瘦身和优化。
这个过程涉及到的知识点包括:1. **开源软件管理**:理解开源软件的许可证、版本控制、社区协作和贡献机制是Reap能够有效工作的基础。
2. **代码分析**:Reap可能使用静态代码分析技术来识别冗余和无效的代码段。
3. **依赖管理**:Reap需要处理不同开源组件之间的依赖关系,可能涉及到版本控制和冲突解决。
4. **编译与构建**:优化后的软件需要重新编译和构建,以确保所有改动正确无误。
5. **性能优化**:通过删除冗余代码和优化依赖,Reap旨在提高软件的运行速度和资源利用率。
6. **版本控制**:Reap处理的每个软件版本都需要在版本控制系统(如Git)中妥善管理,以便追踪和回溯修改。
7. **软件分发**:优化后的软件可能需要以不同的格式(如安装包、容器镜像等)提供给用户,这就涉及到软件打包和分发的知识。
8. **兼容性测试**:在优化软件后,必须进行全面的兼容性和功能测试,以确保改动不影响软件的正常使用。
9. **社区参与**:Reap作为一个开源项目,其发展和维护离不开开源社区的支持和参与,包括代码贡献、问题报告和反馈。
通过Reap这样的工具,开发者可以更高效地管理和维护开源项目,同时为用户提供更加精简、优化的软件体验。
这对于个人开发者和大型团队来说都是一种有价值的资源优化方式。
2025/6/15 19:55:47 93.59MB
1
简介:
【标题与描述解析】"AdminPanel后台管理页面html静态模板.zip" 这个标题表明我们正在处理一个HTML静态模板,特别设计用于构建后台管理界面。
"AdminPanel"可能是该模板的名称,暗示它可能包含一系列专为管理员使用的交互式元素和布局。
"zip"文件格式表明这是一个压缩文件,通常用于集合多个文件或文件夹以便于存储和传输。
描述中的内容与标题相同,进一步确认这是一份HTML静态模板,主要用于构建后台管理系统。
由于没有提供更多的描述性信息,我们将依赖通用的后台管理页面设计知识来展开讨论。
【HTML静态模板】HTML静态模板是预先设计的网页结构,包含了HTML、CSS和JavaScript等基本网页元素,开发者可以在此基础上添加功能和内容。
对于后台管理页面,这些模板通常具有以下特征:1. **布局**:后台管理页面通常有清晰的布局,如侧边导航栏、顶部菜单、内容区域和底部版权信息等,便于用户快速定位和操作。
2. **响应式设计**:考虑到不同设备的使用,模板应具备响应式设计,能适应手机、平板和桌面电脑等不同屏幕尺寸。
3. **表单元素**:后台页面经常涉及数据输入和编辑,因此模板会包含各种表单元素,如输入框、下拉选择、复选框、单选按钮等。
4. **数据展示**:表格、图表和卡片式布局是常见用于展示统计数据和信息的方式。
5. **交互元素**:按钮、提示信息、模态对话框、通知和进度条等元素提供了良好的用户体验。
6. **图标和图形**:使用SVG图标库或者Font Awesome等图标集,可以提高页面的视觉效果。
7. **框架和库**:Bootstrap、Foundation等前端框架常用于构建后台模板,jQuery和其他JavaScript库可以简化交互处理。
【开发与应用】在使用"AdminPanel"这样的HTML静态模板时,开发者需要根据实际项目需求进行定制:1. **内容替换**:将模板中的占位符文本和图片替换为实际内容。
2. **功能添加**:根据业务逻辑添加动态功能,如AJAX请求、表单验证、数据处理等。
3. **API集成**:与后端服务器的API接口进行对接,实现数据的获取和提交。
4. **样式调整**:根据品牌风格指南调整颜色、字体和间距等样式。
5. **性能优化**:减少HTTP请求,合并CSS和JavaScript文件,利用CDN加速资源加载。
总结,"AdminPanel后台管理页面html静态模板.zip"是一个用于创建后台管理界面的基础框架,开发人员可以通过自定义内容和功能,结合后端服务,构建出满足特定业务需求的高效管理平台。
2025/6/15 19:52:51 1.2MB
1
简介:
sfb sfb可帮助SQL测试和估算取决于扫描量的服务成本。
描述检查SQL语法免费估算查询费用每次运行每月自动替换查询参数在持续集成中很有用使用dryrun include安装$ pip install sfb要求Python> = 3.6 Jupyter笔记本Google合作实验室google-cloud-bigquery> = 2.6.1 pyyaml> = 5.4.1用法估算查询费用# If runs with no arguments, execute files in ./sql/*.sql.$ sfb{ " Succeeded " : [ { " SQL File " : " /home/admin/project/sfb_test/sql/covid19_open_data.covid19_open_da
2025/6/15 19:48:03 14KB
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
共 856 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡