generated from mingliqiye/lib-tem
docs: 添加项目 README 文档并更新 Main 类
- 新增 README.md 文件,详细介绍项目功能、技术栈、使用示例等信息- 更新 Main 类,添加字符串、时间和集合工具的使用示例
This commit is contained in:
parent
57efd3c8c4
commit
ab97ba57c8
167
README.md
Normal file
167
README.md
Normal file
@ -0,0 +1,167 @@
|
||||
# mingli-utils
|
||||
|
||||
一个功能丰富的Java工具类库,提供字符串处理、时间处理、文件操作、网络工具、哈希计算等常用工具方法。
|
||||
|
||||
## 项目概述
|
||||
|
||||
mingli-utils 是一个 Java 工具类库,提供各种常用的工具方法,旨在简化开发流程,减少重复代码。
|
||||
|
||||
## 技术栈
|
||||
|
||||
- JDK 版本: Java 8
|
||||
- 构建工具: Gradle (Kotlin DSL)
|
||||
- 依赖库:
|
||||
- Lombok 1.18.38: 用于简化 Java Bean 代码
|
||||
- Jackson Databind 2.19.2: 用于 JSON 序列化
|
||||
- MyBatis 3.5.19: 持久层框架
|
||||
- Spring Boot Starter 2.7.14: Spring Boot基础依赖
|
||||
- Bouncy Castle 1.81: 加密算法库
|
||||
- UUID Creator 6.1.0: UUID生成工具
|
||||
- jBCrypt 0.4: BCrypt加密实现
|
||||
- JetBrains Annotations 24.0.0: 注解库
|
||||
|
||||
## 主要功能模块
|
||||
|
||||
### 字符串处理 (StringUtil)
|
||||
|
||||
提供常用的字符串操作方法:
|
||||
|
||||
- `toString()`: 对象转字符串
|
||||
- `format()`: 格式化字符串
|
||||
- `isEmpty()`: 判断字符串是否为空
|
||||
- `join()`: 连接字符串
|
||||
- `split()`: 分割字符串
|
||||
|
||||
### 集合工具 (Lists)
|
||||
|
||||
提供创建各种List实现的便捷方法:
|
||||
|
||||
- `newArrayList()`: 创建ArrayList实例
|
||||
- `newLinkedList()`: 创建LinkedList实例
|
||||
- `newVector()`: 创建Vector实例
|
||||
|
||||
### 时间处理 (time)
|
||||
|
||||
提供时间相关功能:
|
||||
|
||||
- `DateTime`: 时间处理类,封装了LocalDateTime的操作
|
||||
- `DateTimeOffset`: 时间偏移量处理
|
||||
- `Formatter`: 常用时间格式枚举
|
||||
- `DateTimeUnit`: 时间单位常量定义
|
||||
|
||||
### 文件操作 (FileUtil)
|
||||
|
||||
提供文件读写等操作:
|
||||
|
||||
- `readFileToString()`: 读取文件内容为字符串
|
||||
- `writeStringToFile()`: 将字符串写入文件
|
||||
- `readLines()`: 读取文件内容为字符串列表(按行分割)
|
||||
- `writeLines()`: 将字符串列表写入文件(每行一个元素)
|
||||
- `copyFile()`: 复制文件
|
||||
- `deleteFile()`: 删除文件
|
||||
- `exists()`: 检查文件是否存在
|
||||
- `getFileSize()`: 获取文件大小
|
||||
|
||||
### 网络工具 (network)
|
||||
|
||||
提供网络地址处理功能:
|
||||
|
||||
- `NetworkEndpoint`: 网络端点(IP+端口)封装
|
||||
- `NetworkAddress`: 网络地址处理(支持IPv4/IPv6)
|
||||
- `NetworkPort`: 网络端口处理
|
||||
|
||||
### 哈希工具 (HashUtils)
|
||||
|
||||
提供哈希计算功能:
|
||||
|
||||
- `calculateFileHash()`: 计算文件哈希值
|
||||
- `bcrypt()`: BCrypt加密
|
||||
- `checkBcrypt()`: 验证BCrypt哈希
|
||||
|
||||
### 系统工具 (SystemUtil)
|
||||
|
||||
提供系统相关工具方法:
|
||||
|
||||
- `isWindows()/isMac()/isUnix()`: 操作系统类型判断
|
||||
- `getJdkVersion()`: 获取JDK版本
|
||||
- `getLocalIps()`: 获取本地IP地址
|
||||
|
||||
### UUID工具 (uuid)
|
||||
|
||||
提供UUID处理功能:
|
||||
|
||||
- `UUID`: UUID封装类,支持时间戳型UUID
|
||||
|
||||
### 并发工具 (concurrent)
|
||||
|
||||
提供线程安全的数据结构:
|
||||
|
||||
- `IsChanged`: 基于CAS操作的线程安全包装类
|
||||
|
||||
### 函数式工具 (functions)
|
||||
|
||||
提供函数式编程支持:
|
||||
|
||||
- `Debouncer`: 防抖器实现
|
||||
|
||||
## 使用示例
|
||||
|
||||
```java
|
||||
// 字符串格式化
|
||||
String message =
|
||||
StringUtil.format("Hello {}, you are {} years old", "张三", 25);
|
||||
|
||||
// 创建列表
|
||||
List<String> fruits = Lists.newArrayList("苹果", "香蕉", "橙子");
|
||||
|
||||
// 连接字符串
|
||||
String result = StringUtil.join(", ", fruits);
|
||||
|
||||
// 时间处理
|
||||
DateTime now = DateTime.now();
|
||||
String formatted = now.format(Formatter.STANDARD_DATETIME);
|
||||
|
||||
// 文件操作
|
||||
FileUtil.
|
||||
|
||||
writeStringToFile("example.txt","Hello World");
|
||||
|
||||
String content = FileUtil.readFileToString("example.txt");
|
||||
|
||||
// 网络地址处理
|
||||
NetworkEndpoint endpoint = NetworkEndpoint.of("127.0.0.1", 8080);
|
||||
InetSocketAddress address = endpoint.toInetSocketAddress();
|
||||
|
||||
// 哈希计算
|
||||
String hash = HashUtils.bcrypt("password");
|
||||
boolean matches = HashUtils.checkBcrypt("password", hash);
|
||||
```
|
||||
|
||||
## 构建和运行
|
||||
|
||||
使用以下命令构建项目:
|
||||
|
||||
```bash
|
||||
./gradlew build
|
||||
```
|
||||
|
||||
发布到本地Maven仓库:
|
||||
|
||||
```bash
|
||||
./gradlew publishToMavenLocal
|
||||
```
|
||||
|
||||
## 项目配置
|
||||
|
||||
项目在 `gradle.properties` 中定义了以下配置:
|
||||
|
||||
```properties
|
||||
JDKVERSIONS=1.8
|
||||
GROUPSID=com.mingliqiye.utils
|
||||
ARTIFACTID=mingli-utils
|
||||
VERSIONS=1.0.4
|
||||
```
|
||||
|
||||
## License
|
||||
|
||||
本项目采用Apache 2.0许可证,详细信息请查看 [LICENSE](LICENSE) 文件。
|
@ -1,6 +1,39 @@
|
||||
package com.mingliqiye.utils;
|
||||
|
||||
import com.mingliqiye.utils.collection.Lists;
|
||||
import com.mingliqiye.utils.string.StringUtil;
|
||||
import com.mingliqiye.utils.time.DateTime;
|
||||
import com.mingliqiye.utils.time.Formatter;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public class Main {
|
||||
|
||||
public static void main(String[] args) {}
|
||||
}
|
||||
public static void main(String[] args) {
|
||||
// 字符串工具使用示例
|
||||
System.out.println("=== 字符串工具使用示例 ===");
|
||||
String formatted = StringUtil.format("你好 {},今天是{}年{}月{}日", "张三", 2025, 7, 25);
|
||||
System.out.println(formatted);
|
||||
|
||||
List<String> fruits = Lists.newArrayList("苹果", "香蕉", "橙子");
|
||||
String joined = StringUtil.join(", ", fruits);
|
||||
System.out.println("水果列表: " + joined);
|
||||
|
||||
// 时间工具使用示例
|
||||
System.out.println("\n=== 时间工具使用示例 ===");
|
||||
DateTime now = DateTime.now();
|
||||
System.out.println("当前时间: " + now);
|
||||
System.out.println("标准格式: " + now.format(Formatter.STANDARD_DATETIME));
|
||||
|
||||
DateTime specificDate = DateTime.of(2025, 1, 1, 12, 0, 0);
|
||||
System.out.println("指定时间: " + specificDate.format(Formatter.STANDARD_DATETIME));
|
||||
|
||||
// 集合工具使用示例
|
||||
System.out.println("\n=== 集合工具使用示例 ===");
|
||||
List<Integer> numbers = Lists.newArrayList(10, 20, 30);
|
||||
System.out.println("数字列表: " + numbers);
|
||||
|
||||
List<String> linkedList = Lists.newLinkedList("第一个", "第二个", "第三个");
|
||||
System.out.println("链表内容: " + linkedList);
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user