mysql-connector-java-8.0.16.jar是java连接mysql数据库必备jar,2019年5月10号下载的,目前最新的。
注意连接url编写问题。
2025/6/27 9:06:12 2.19MB mysql-connector-
1
标题中的“自己制作在线翻译html”意味着我们要讨论的是如何利用HTML和相关技术构建一个自定义的在线翻译工具,这个工具可能会使用外部API,比如必应的翻译服务。
在这个项目中,我们将深入理解如何将HTML与JavaScript、AJAX以及可能的CSS结合,创建一个用户友好的界面,用于实时翻译文本。
描述中提到“用必应接口”,这表明我们将会使用微软的Bing翻译API。
Bing翻译API提供了一个RESTful服务,允许开发者在应用中集成多语言翻译功能。
它支持多种编程语言和平台,通过发送HTTP请求并处理响应来完成翻译任务。
我们需要了解HTML的基础,包括标签、属性和布局。
`index.html`文件通常包含了网页的基本结构,如``、``等元素,其中可能包含一个输入框让用户输入要翻译的文本,以及按钮触发翻译操作。
接着,`config.xml`可能是配置文件,用来存储API密钥、默认设置或翻译的语言对等信息。
在实际开发中,为了安全起见,API密钥通常不会直接写入源代码,而是通过配置文件动态加载,或者使用环境变量。
对于JavaScript部分,我们需要学习AJAX(异步JavaScript和XML)技术,它是现代Web应用中用于与服务器进行数据交互的重要手段。
通过创建XMLHttpRequest对象或使用jQuery、axios等库,我们可以发送HTTP请求到Bing翻译API,获取翻译结果。
请求的URL会包含API的端点、请求参数(如源语言、目标语言和要翻译的文本),以及API密钥。
在接收到API的翻译响应后,我们需要解析JSON格式的数据,提取出翻译结果,并更新HTML页面显示。
这可能涉及到DOM(文档对象模型)操作,例如使用`document.getElementById`或`document.querySelector`找到特定元素,然后修改其内容。
此外,为了提供良好的用户体验,我们可以考虑添加错误处理机制,比如当API调用失败时显示错误信息,或者当用户未输入文本时给出提示。
CSS可以用来美化界面,如设定字体、颜色、布局等,使界面更加友好。
`static`文件夹可能包含CSS样式表、图片和其他静态资源。
在HTML文件中通过``标签引用CSS文件,可以实现样式分离,提高代码可维护性。
总结起来,创建一个自定义的在线翻译HTML页面需要掌握HTML基本结构、JavaScript的AJAX请求、Bing翻译API的使用,以及简单的CSS样式设计。
通过实践这个项目,你可以提升Web开发技能,并对API集成有更深入的理解。
2025/6/24 0:26:46 37KB 在线翻译
1

ASP(Active Server Pages)是一种微软开发的服务器端脚本语言,常用于构建动态网页。
这个“asp常用函数.rar”压缩包包含了一些在ASP编程中常用的函数,这些函数可以帮助开发者更高效地处理字符串、数字和数据转换,从而提高开发效率。
1. **字符串处理函数** - `Len()`:返回字符串的长度,这对于确定字符串内容和处理字符串截取非常有用。
- `Left()`:从字符串的左侧提取指定数量的字符。
- `Right()`:从字符串的右侧提取指定数量的字符。
- `Mid()`:从字符串中间提取指定长度的子串。
- `Trim()`:删除字符串首尾的空格。
- `LTrim()`:删除字符串左侧的空格。
- `RTrim()`:删除字符串右侧的空格。
- `StrConv()`:进行字符串转换,如大小写转换、货币格式化等。
2. **数字处理函数** - `Int()`:将数字向下取整为最接近的整数。
- `Round()`:四舍五入到指定的小数位数。
- `FormatNumber()`:格式化数字,例如添加千位分隔符或控制小数位数。
3. **转换函数** - `CStr()`:将其他类型的数据转换为字符串。
- `CInt()`:将字符串或其他类型的数据转换为整数。
- `CDbl()`:将字符串或其他类型的数据转换为双精度浮点数。
- `CDate()`:将字符串转换为日期时间类型。
- `CLng()`:将字符串或其他类型的数据转换为长整型。
4. **其他常见函数** - `Request()`:获取HTTP请求中的数据,如表单变量、查询字符串等。
- `Response()`:发送HTTP响应,可以用来输出HTML、设置HTTP头等。
- `Server.URLEncode()`:对URL中的特殊字符进行编码,防止URL解析问题。
- `Session()`:处理用户会话状态,存储和检索用户的特定信息。
- `Application()`:在所有用户间共享数据,适用于全局变量。
这些函数是ASP编程的基础,了解并熟练掌握它们对于编写高效、可维护的ASP代码至关重要。
通过"asp常用函数.htm"文档,你可以深入学习每个函数的用法、参数和返回值,以便在实际项目中灵活应用。
记住,理解和实践这些函数是提升ASP编程技能的关键步骤。
2025/6/19 18:22:46 9KB
1

这篇内容将围绕“灰色渐变边框个人简历模板”这一主题,深入探讨如何利用网页模板设计一份具有专业感和个人特色的简历。
在这个数字化时代,一份出色的在线简历能够为求职者增添亮点,提高竞争力。
我们要了解的是“简历”在IT行业的应用。
在求职过程中,简历是展示个人技能、经历和成就的重要工具。
而随着互联网技术的发展,电子简历或在线简历变得越来越普遍,它们可以更直观地展示求职者的个性和专业能力,通过网页形式的简历,可以添加动态效果、多媒体元素,使内容更加生动。
“网页模板”是创建网页的一种快捷方式。
它提供了预设的布局、颜色方案和设计元素,使得非专业设计师也能快速构建出美观的网页。
在这个案例中,“灰色渐变边框个人简历模板”可能包含了一套简洁、专业的设计风格,利用灰色调的渐变边框来营造稳重而不失现代感的视觉效果。
在压缩包文件中,我们看到以下几个关键文件:1. **style.css**:这是CSS(Cascading Style Sheets)样式表文件,用于定义网页的样式,包括字体、颜色、布局等。
在这个模板中,它可能包含了边框的渐变效果和其他页面元素的样式规则。
2. **index.html**:这是HTML(HyperText Markup Language)文件,是网页的主体结构,包含文本、图像和其他元素的标记。
在这个简历模板中,它会指导浏览器如何呈现个人信息、工作经历、技能等部分。
3. **_desktop.ini**:这是一个系统文件,通常用于设置Windows系统中文件夹的属性,例如图标、显示方式等。
在这个上下文中,它可能与模板的桌面视图配置有关。
4. **ReadMe.txt**:这是一个常见的文本文件,通常包含关于软件或项目的基本信息、使用指南或注意事项。
在这个压缩包中,它可能会提供关于如何使用这个模板的说明。
5. **松设计漂亮的网页-mobanwang.com.url**:这是一个书签文件,指向一个网页设计资源网站,可能提供了更多模板或者其他设计相关的资源。
6. **images**:这是一个文件夹,通常包含网页中使用的图像文件。
在这个模板中,可能会有头像、示例作品或其他增强视觉效果的图片。
通过编辑和定制这些文件,用户可以根据自己的需求调整简历模板,例如替换个人照片、修改文字内容、调整边框样式等,以创造出独一无二的在线简历。
对于求职者而言,掌握基本的HTML和CSS知识可以帮助更好地利用这类模板,进一步优化自己的简历,提升求职成功率。
2025/6/19 16:47:07 28KB
1

所以Simple Control Panel经常性容易出问题,具体表现如下: Server Error We are sorry the system has encountered an error while processing your request. Home If you continue to receive this error please contact your system administrator. Your URL: /domain/edit.do Error details: CommandFailedException: Unable to get min/
2025/6/16 5:23:47 47KB
1

在IT行业中,ZTree是一款广泛应用于Web开发的前端插件,尤其在文件管理、权限控制等领域,它提供了强大的树形展示功能。
标题提到的“ztree的使用”着重于介绍如何在项目中集成和操作ZTree。
由于描述中提到了项目基于SSH(Spring、Struts2、Hibernate)框架,我们可以推测这是一个Java Web项目,ZTree在此类项目中常用于后台数据的前端展示。
ZTree的基础概念需要理解。
ZTree是一个基于jQuery的插件,它可以将静态或动态的数据结构渲染成交互式的树形视图。
它的主要特点包括节点的多级展示、可选的异步加载、丰富的事件机制以及自定义的节点样式和图标。
在SSH框架中使用ZTree,首先你需要在项目中引入ZTree的CSS和JavaScript文件。
这些文件通常可以从ZTree的官方网站下载,包含所需的样式表和脚本。
然后,在HTML页面中引入这些资源,并设置一个div元素作为ZTree的容器。
接下来,你需要准备ZTree的数据源。
在基于SSH的项目中,数据通常通过Ajax请求从后端获取。
数据格式应遵循ZTree的规范,一般为JSON格式,包含节点ID、父节点ID、节点文本等关键信息。
例如:```json[ { "id": "1", "pId": "0", "name": "父节点1" }, { "id": "1_1", "pId": "1", "name": "子节点1_1" }, { "id": "1_2", "pId": "1", "name": "子节点1_2" }]```在JavaScript中,你可以使用$.fn.zTree.init方法初始化ZTree,传入刚才创建的容器div和数据源。
同时,你还需要配置ZTree的参数,如是否启用异步加载、节点展开方式、是否允许拖拽等。
例如:```javascriptvar setting = { async: { enable: true, url: yourAjaxUrl, autoParam: [id], otherParam: {type: typeValue} }, data: { simpleData: { enable: true } }};var zNodes = []; // 前面准备的JSON数据$.fn.zTree.init($("#treeDemo"), setting, zNodes);```ZTree还提供了丰富的事件监听,如onClick、onDblClick等,你可以根据需要绑定相应的处理函数来实现节点点击后的业务逻辑。
例如:```javascriptvar treeObj = $.fn.zTree.getZTreeObj("treeDemo");treeObj.bind("onClick", function(event, treeId, treeNode) { console.log(点击了节点:, treeNode.id);});```此外,ZTree支持动态加载和异步数据获取,这对于大型数据集非常有用。
你可以通过配置async参数来开启异步加载,并指定获取数据的URL。
当用户展开节点时,ZTree会自动发送请求获取子节点数据。
“ztree的使用”涵盖了前端展示、后端数据交互、事件处理等多个方面。
理解ZTree的工作原理和配置选项,能够帮助你在SSH项目中构建出高效、交互性强的树形界面。
通过不断实践和优化,ZTree可以成为项目中不可或缺的一部分,提升用户体验并简化后台数据管理。
2025/6/15 22:18:37 17KB
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
简介:
### Spring注解学习:构建简单Web应用#### 引言Spring框架自引入注解支持以来,极大地简化了Java开发中的依赖注入与配置管理过程。
本文将深入探讨如何利用Spring注解来构建一个简单的Web应用,从控制器(Controller)到数据访问对象(DAO),通过实例演示注解在不同层次的应用。
#### Spring注解概述Spring框架提供了多种注解来简化应用的配置和组件的定义。
以下是一些常用的Spring注解:- `@Component`:标记类为Spring的Bean,可以被Spring容器管理和注入到其他Bean中。
- `@Repository`:用于数据访问层,通常标记DAO类,提供额外的异常转换支持。
- `@Service`:用于业务逻辑层,表示服务层的Bean。
- `@Controller`:用于Web层,表示一个控制层的Bean,处理HTTP请求。
- `@Autowired`:自动装配Bean,用于字段或构造函数,无需手动设置依赖。
- `@RequestMapping`:映射Web请求到特定的方法上,用于控制器类或方法上。
- `@Transactional`:用于方法上,声明该方法需要在事务中执行。
#### 构建Web应用:关键步骤1. **项目搭建**:创建一个Web项目,并添加必要的Jar包,如Spring框架的各个模块、AOP联盟、日志库等。
文中提到的Jar包包括aopalliance-1.0.jar、commons-logging-1.1.1.jar、log4j-1.2.15.jar等,这些包对于Spring框架的正常运行至关重要。
2. **配置web.xml**:这是Web应用的部署描述符,用于配置Servlet、过滤器等。
在本例中,配置了Spring的上下文参数、Log4J的日志配置以及字符编码过滤器,确保应用能够正确读取配置并处理请求。
```xml <context-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/applicationContext.xml</param-value> </context-param> ``` 这段配置指定了Spring的配置文件位置,即`applicationContext.xml`。
3. **编写控制器**:使用`@Controller`注解定义控制器类,并使用`@RequestMapping`注解来指定URL映射。
例如: ```java @Controller public class HelloWorldController { @RequestMapping("/hello") public String helloWorld() { return "hello"; } } ```4. **数据访问层**:使用`@Repository`注解定义DAO类,负责数据的存取操作。
例如: ```java @Repository public class UserRepository { // 数据库操作方法 } ```5. **业务逻辑层**:使用`@Service`注解定义服务层,处理业务逻辑。
例如: ```java @Service public class UserService { @Autowired private UserRepository userRepository; // 业务逻辑方法 } ```6. **事务管理**:在业务逻辑中,可能需要使用`@Transactional`注解来确保数据的一致性和完整性。
7. **测试**:对应用进行单元测试和集成测试,确保各部分功能按预期工作。
#### 结论通过上述步骤,我们可以构建一个基于Spring注解的简单Web应用。
Spring注解的使用极大地简化了配置,提高了开发效率,使得开发者能够更加专注于业务逻辑的实现。
在未来的学习中,我们将更深入地探讨每一层的细节,以及如何利用Spring注解来优化和扩展应用的功能。
2025/6/15 19:51:25 187KB
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
正则表达式是用于字符串匹配的强大工具,它能够使用一套规则来匹配文本中的字符组合。
在JavaScript中,正则表达式的应用非常广泛,可用于字符串的搜索、替换、提取等操作。
关于正则表达式的基本语法和应用场景:1.字符串长度的计算可以考虑字符的字节大小。
中文字符属于双字节字符,每个字符长度记为2,ASCII字符每个长度计为1。
可以使用正则表达式配合String的扩展方法来实现。
2.匹配中文字符的正则表达式使用Unicode范围来指定,`\u4e00-\u9fa5`包括了绝大多数汉字字符。
3.匹配双字节字符时,可以使用`[^\x00-\xff]`,这可以匹配任何非ASCII字符。
4.匹配空行,可以使用正则表达式`\n[\s|]*\r`,这能够识别连续换行符之间的空白字符。
5.匹配HTML标签通常使用较为复杂的正则表达式,例如`/<(.*)>.*<\/\1>|<(.*)\/>/`,这能够匹配开始标签和自结束标签。
6.去除字符串首尾的空格,可以使用正则表达式`(^\s*)|(\s*$)`,这在JavaScript中通过扩展String原型的方式实现。
7.IP地址的匹配和转换可以通过正则表达式解析IP地址的各部分数字,并将其转换为一个数值,例如`functionIP2V(ip)`,该函数会将IP地址转换为数值形式。
8.正则表达式也可以用于提取URL中的文件名,例如`varip="**.***.**.***"`,之后使用`split`函数处理字符串。
9.去除字符串中重复字符可以使用正则表达式和后向引用的组合,但需要注意到顺序有要求的字符串可能不适用此方法。
10.匹配Email地址和网址URL的正则表达式也是常见的需求,它们通常包含复杂的规则和结构。
11.利用正则表达式限制网页表单中的文本框输入内容,如限制只能输入中文,可以使用`onkeyup`和`onbeforepaste`事件处理函数结合正则表达式。
正则表达式的能力并非无限,它有时可能无法准确匹配某些复杂的字符串模式,尤其是当字符串顺序对结果有影响时,例如在去重字符串中的重复字符时,可能会出现匹配不正确的情况。
在使用正则表达式时,需要注意以下几点:-某些正则表达式操作可以通过非正则表达式的方法简化实现,例如使用`split`函数代替复杂的正则表达式来处理IP地址。
-在应用正则表达式进行匹配时,需要对结果进行验证,尤其是正则表达式自身可能会有匹配不精确的情况。
-在应用正则表达式于生产环境之前,要进行充分的测试,保证其正确性。
通过上述的知识点,可以看出正则表达式在JavaScript编程中发挥着至关重要的作用。
掌握其使用和技巧对于开发人员来说是非常重要的。
无论是在字符串处理、表单验证还是数据提取等场景,合理有效地使用正则表达式可以大大提高编程效率和代码质量。
2025/6/14 23:57:10 74KB
1
共 424 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡