generated from mingliqiye/lib-tem
从java移动代码到kotlin
All checks were successful
Gitea Actions Build / Build (push) Successful in 5m39s
All checks were successful
Gitea Actions Build / Build (push) Successful in 5m39s
This commit is contained in:
parent
d12fbe0cce
commit
56080634c7
@ -16,7 +16,7 @@
|
|||||||
* ProjectName mingli-utils
|
* ProjectName mingli-utils
|
||||||
* ModuleName mingli-utils
|
* ModuleName mingli-utils
|
||||||
* CurrentFile build.gradle.kts
|
* CurrentFile build.gradle.kts
|
||||||
* LastUpdate 2025-09-10 11:08:55
|
* LastUpdate 2025-09-12 14:06:21
|
||||||
* UpdateUser MingLiPro
|
* UpdateUser MingLiPro
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -28,6 +28,8 @@ plugins {
|
|||||||
java
|
java
|
||||||
id("java-library")
|
id("java-library")
|
||||||
id("maven-publish")
|
id("maven-publish")
|
||||||
|
kotlin("jvm") version "2.2.20"
|
||||||
|
id("org.jetbrains.dokka") version "2.0.0"
|
||||||
}
|
}
|
||||||
|
|
||||||
val GROUPSID = project.properties["GROUPSID"] as String
|
val GROUPSID = project.properties["GROUPSID"] as String
|
||||||
@ -41,24 +43,31 @@ base {
|
|||||||
archivesName.set(ARTIFACTID)
|
archivesName.set(ARTIFACTID)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
val buildDir: java.nio.file.Path = File("build").toPath()
|
||||||
|
|
||||||
sourceSets {
|
sourceSets {
|
||||||
main {
|
main {
|
||||||
java {
|
java {
|
||||||
srcDirs("src/main/java")
|
srcDirs("src/main/java")
|
||||||
}
|
}
|
||||||
|
kotlin {
|
||||||
|
srcDirs("src/main/kotlin")
|
||||||
|
}
|
||||||
resources {
|
resources {
|
||||||
srcDirs("src/main/resources")
|
srcDirs("src/main/resources")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
configurations {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
java {
|
java {
|
||||||
withJavadocJar()
|
|
||||||
withSourcesJar()
|
withSourcesJar()
|
||||||
toolchain.languageVersion.set(JavaLanguageVersion.of(8))
|
toolchain.languageVersion.set(JavaLanguageVersion.of(8))
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
annotationProcessor("org.jetbrains:annotations:24.0.0")
|
annotationProcessor("org.jetbrains:annotations:24.0.0")
|
||||||
annotationProcessor("org.projectlombok:lombok:1.18.38")
|
annotationProcessor("org.projectlombok:lombok:1.18.38")
|
||||||
@ -74,7 +83,6 @@ dependencies {
|
|||||||
implementation("org.jetbrains:annotations:24.0.0")
|
implementation("org.jetbrains:annotations:24.0.0")
|
||||||
implementation("net.java.dev.jna:jna:5.17.0")
|
implementation("net.java.dev.jna:jna:5.17.0")
|
||||||
implementation("jakarta.annotation:jakarta.annotation-api:2.1.1")
|
implementation("jakarta.annotation:jakarta.annotation-api:2.1.1")
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -82,6 +90,21 @@ tasks.withType<JavaCompile> {
|
|||||||
options.encoding = "UTF-8"
|
options.encoding = "UTF-8"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tasks.register<Jar>("javaDocJar") {
|
||||||
|
group = "build"
|
||||||
|
archiveClassifier.set("javadoc")
|
||||||
|
dependsOn(tasks.dokkaGfm, tasks.dokkaHtml, tasks.dokkaJavadoc, tasks.dokkaJekyll)
|
||||||
|
from(buildDir.resolve("dokka/javadoc"))
|
||||||
|
}
|
||||||
|
tasks.register<Jar>("kotlinDocJar") {
|
||||||
|
group = "build"
|
||||||
|
archiveClassifier.set("kotlindoc")
|
||||||
|
dependsOn(tasks.dokkaHtml)
|
||||||
|
from(buildDir.resolve("dokka/html"))
|
||||||
|
}
|
||||||
|
tasks.build {
|
||||||
|
dependsOn("javaDocJar", "kotlinDocJar")
|
||||||
|
}
|
||||||
tasks.withType<JavaExec>().configureEach {
|
tasks.withType<JavaExec>().configureEach {
|
||||||
jvmArgs = listOf(
|
jvmArgs = listOf(
|
||||||
"-Dfile.encoding=UTF-8",
|
"-Dfile.encoding=UTF-8",
|
||||||
@ -91,12 +114,6 @@ tasks.withType<JavaExec>().configureEach {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
tasks.withType<Javadoc> {
|
|
||||||
options.encoding = "UTF-8"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
tasks.withType<org.gradle.jvm.tasks.Jar> {
|
tasks.withType<org.gradle.jvm.tasks.Jar> {
|
||||||
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
|
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
|
||||||
manifest {
|
manifest {
|
||||||
@ -143,6 +160,19 @@ publishing {
|
|||||||
groupId = GROUPSID
|
groupId = GROUPSID
|
||||||
artifactId = ARTIFACTID
|
artifactId = ARTIFACTID
|
||||||
version = VERSIONS
|
version = VERSIONS
|
||||||
|
artifact(tasks.named("javaDocJar"))
|
||||||
|
artifact(tasks.named("kotlinDocJar"))
|
||||||
|
pom {
|
||||||
|
name.set(project.name)
|
||||||
|
url.set("https://github.com/minglipro/mingli-utils")
|
||||||
|
|
||||||
|
licenses {
|
||||||
|
license {
|
||||||
|
name.set("Apache-2.0")
|
||||||
|
url.set("https://opensource.org/licenses/Apache-2.0")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,10 +16,10 @@
|
|||||||
# ProjectName mingli-utils
|
# ProjectName mingli-utils
|
||||||
# ModuleName mingli-utils
|
# ModuleName mingli-utils
|
||||||
# CurrentFile gradle.properties
|
# CurrentFile gradle.properties
|
||||||
# LastUpdate 2025-09-09 09:34:12
|
# LastUpdate 2025-09-12 14:10:24
|
||||||
# UpdateUser MingLiPro
|
# UpdateUser MingLiPro
|
||||||
#
|
#
|
||||||
JDKVERSIONS=1.8
|
JDKVERSIONS=1.8
|
||||||
GROUPSID=com.mingliqiye.utils
|
GROUPSID=com.mingliqiye.utils
|
||||||
ARTIFACTID=mingli-utils
|
ARTIFACTID=mingli-utils
|
||||||
VERSIONS=3.2.6
|
VERSIONS=3.2.7
|
||||||
|
@ -1,7 +0,0 @@
|
|||||||
/**
|
|
||||||
*
|
|
||||||
* AES 加密
|
|
||||||
* @author MingLiPro
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
package com.mingliqiye.utils.aes;
|
|
@ -1,3 +1,25 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2025 mingliqiye
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*
|
||||||
|
* ProjectName mingli-utils
|
||||||
|
* ModuleName mingli-utils.main
|
||||||
|
* CurrentFile Range.java
|
||||||
|
* LastUpdate 2025-09-12 17:12:29
|
||||||
|
* UpdateUser MingLiPro
|
||||||
|
*/
|
||||||
|
|
||||||
package com.mingliqiye.utils.iterator;
|
package com.mingliqiye.utils.iterator;
|
||||||
|
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
@ -7,7 +29,8 @@ import java.util.Iterator;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* 范围 Range<br>
|
* 范围 Range<br>
|
||||||
* 类似 KT的 {@code 0..10 = Range.of(0,10)}
|
* Iterable 可遍历对象<br>
|
||||||
|
* 类似 KT的 {@code 0..10 = Range.of(0,10)} {@code 0..10 step 2 = Range.of(0,10,2)}
|
||||||
* @author MingLiPro
|
* @author MingLiPro
|
||||||
* @since 3.2.6
|
* @since 3.2.6
|
||||||
*/
|
*/
|
||||||
@ -16,6 +39,7 @@ public class Range implements Iterable<Integer> {
|
|||||||
|
|
||||||
private final int start;
|
private final int start;
|
||||||
private final int end;
|
private final int end;
|
||||||
|
private final int step;
|
||||||
private int current;
|
private int current;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -27,8 +51,22 @@ public class Range implements Iterable<Integer> {
|
|||||||
* @see Integer
|
* @see Integer
|
||||||
*/
|
*/
|
||||||
public Range(int start, int end) {
|
public Range(int start, int end) {
|
||||||
|
this(start, end, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建一个范围 <br>
|
||||||
|
* 最大值{@code Integer.MAX_VALUE = 2147483647 } <br>
|
||||||
|
* 最小值{@code Integer.MIN_VALUE = -2147483648} <br>
|
||||||
|
* @param start 开始 (包含)
|
||||||
|
* @param end 完毕 (包含)
|
||||||
|
* @param step 步长
|
||||||
|
* @see Integer
|
||||||
|
*/
|
||||||
|
public Range(int start, int end, int step) {
|
||||||
this.start = start;
|
this.start = start;
|
||||||
this.current = start;
|
this.current = start;
|
||||||
|
this.step = step;
|
||||||
this.end = end + 1;
|
this.end = end + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -68,6 +106,32 @@ public class Range implements Iterable<Integer> {
|
|||||||
return new Range(start, end);
|
return new Range(start, end);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建一个范围 <br>
|
||||||
|
* 最大值{@code Integer.MAX_VALUE = 2147483647 } <br>
|
||||||
|
* 最小值{@code Integer.MIN_VALUE = -2147483648} <br>
|
||||||
|
* @param start 开始 (包含)
|
||||||
|
* @param end 完毕 (包含)
|
||||||
|
* @param step 步长
|
||||||
|
* @see Integer
|
||||||
|
*/
|
||||||
|
public static Range of(int start, int end, int step) {
|
||||||
|
return new Range(start, end, step);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建一个范围 <br>
|
||||||
|
* 最大值{@code Integer.MAX_VALUE = 2147483647 } <br>
|
||||||
|
* 最小值{@code Integer.MIN_VALUE = -2147483648} <br>
|
||||||
|
* @param start 开始 (包含)
|
||||||
|
* @param end 完毕 (包含)
|
||||||
|
* @param step 步长
|
||||||
|
* @see Integer
|
||||||
|
*/
|
||||||
|
public static Range range(int start, int end, int step) {
|
||||||
|
return new Range(start, end, step);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 创建一个范围 {@code 0 - range}<br>
|
* 创建一个范围 {@code 0 - range}<br>
|
||||||
* 最大值{@code Integer.MAX_VALUE = 2147483647 } <br>
|
* 最大值{@code Integer.MAX_VALUE = 2147483647 } <br>
|
||||||
@ -110,7 +174,12 @@ public class Range implements Iterable<Integer> {
|
|||||||
if (current >= end) {
|
if (current >= end) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return current++;
|
|
||||||
|
try {
|
||||||
|
return current;
|
||||||
|
} finally {
|
||||||
|
current = current + step;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -1,90 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2025 mingliqiye
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*
|
|
||||||
* ProjectName mingli-utils
|
|
||||||
* ModuleName mingli-utils.main
|
|
||||||
* CurrentFile RandomBytes.java
|
|
||||||
* LastUpdate 2025-09-09 08:37:34
|
|
||||||
* UpdateUser MingLiPro
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.mingliqiye.utils.random;
|
|
||||||
|
|
||||||
import com.mingliqiye.utils.collection.ForEach;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author MingLiPro
|
|
||||||
*/
|
|
||||||
public class RandomBytes {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生成指定长度的随机字节数组
|
|
||||||
* @param length 数组长度
|
|
||||||
* @return 包含随机字节的数组
|
|
||||||
*/
|
|
||||||
public static byte[] randomBytes(int length) {
|
|
||||||
byte[] bytes = new byte[length];
|
|
||||||
// 使用forEach遍历数组,为每个位置生成随机字节
|
|
||||||
ForEach.forEach(bytes, (b, i) ->
|
|
||||||
bytes[i] = randomByte((byte) 0x00, (byte) 0xff)
|
|
||||||
);
|
|
||||||
return bytes;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生成指定长度的随机字节数组
|
|
||||||
* 从给定的字节数组中随机选择字节来填充新数组
|
|
||||||
*
|
|
||||||
* @param length 要生成的随机字节数组的长度
|
|
||||||
* @param bytes 用于随机选择的源字节数组
|
|
||||||
* @return 包含随机字节的新数组
|
|
||||||
*/
|
|
||||||
public static byte[] randomBytes(int length, byte[] bytes) {
|
|
||||||
byte[] rbytes = new byte[length];
|
|
||||||
// 从源数组中随机选择字节填充到结果数组中
|
|
||||||
for (int i = 0; i < length; i++) {
|
|
||||||
rbytes[i] = bytes[RandomInt.randomInt(i, bytes.length - 1)];
|
|
||||||
}
|
|
||||||
return rbytes;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生成指定范围内的随机字节
|
|
||||||
* @param from 起始字节值(包含)
|
|
||||||
* @param to 结束字节值(包含)
|
|
||||||
* @return 指定范围内的随机字节
|
|
||||||
*/
|
|
||||||
public static byte randomByte(byte from, byte to) {
|
|
||||||
// 将byte转换为int进行计算,避免符号问题
|
|
||||||
int fromInt = from & 0xFF;
|
|
||||||
int toInt = to & 0xFF;
|
|
||||||
int randomValue = RandomInt.randomInt(fromInt, toInt);
|
|
||||||
return (byte) (randomValue & 0xFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生成指定范围内的随机字节(不包含边界值)
|
|
||||||
* @param from 起始字节值(不包含)
|
|
||||||
* @param to 结束字节值(不包含)
|
|
||||||
* @return 指定范围内的随机字节
|
|
||||||
*/
|
|
||||||
public static byte randomByteNoHave(byte from, byte to) {
|
|
||||||
// 将byte转换为int进行计算,避免符号问题
|
|
||||||
int fromInt = from & 0xFF;
|
|
||||||
int toInt = to & 0xFF;
|
|
||||||
int randomValue = RandomInt.randomIntNoHave(fromInt, toInt);
|
|
||||||
return (byte) (randomValue & 0xFF);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,59 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2025 mingliqiye
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*
|
|
||||||
* ProjectName mingli-utils
|
|
||||||
* ModuleName mingli-utils.main
|
|
||||||
* CurrentFile RandomInt.java
|
|
||||||
* LastUpdate 2025-09-09 08:37:33
|
|
||||||
* UpdateUser MingLiPro
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.mingliqiye.utils.random;
|
|
||||||
|
|
||||||
import java.util.concurrent.ThreadLocalRandom;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author MingLiPro
|
|
||||||
*/
|
|
||||||
public class RandomInt {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生成指定范围内的随机整数
|
|
||||||
* @param min 最小值(包含)
|
|
||||||
* @param max 最大值(不包含)
|
|
||||||
* @return 随机整数
|
|
||||||
*/
|
|
||||||
public static int randomIntNoHave(int min, int max) {
|
|
||||||
if (min > max) {
|
|
||||||
int t = min;
|
|
||||||
min = max;
|
|
||||||
max = t;
|
|
||||||
}
|
|
||||||
if (min == max) {
|
|
||||||
return min;
|
|
||||||
}
|
|
||||||
return ThreadLocalRandom.current().nextInt(min, max);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生成指定范围内的随机整数
|
|
||||||
* @param min 最小值(包含)
|
|
||||||
* @param max 最大值(包含)
|
|
||||||
* @return 随机整数
|
|
||||||
*/
|
|
||||||
public static int randomInt(int min, int max) {
|
|
||||||
return randomIntNoHave(min, ++max);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,63 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2025 mingliqiye
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*
|
|
||||||
* ProjectName mingli-utils
|
|
||||||
* ModuleName mingli-utils.main
|
|
||||||
* CurrentFile RandomString.java
|
|
||||||
* LastUpdate 2025-09-09 08:37:33
|
|
||||||
* UpdateUser MingLiPro
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.mingliqiye.utils.random;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 随机字符串生成工具类
|
|
||||||
* 提供生成指定长度随机字符串的功能
|
|
||||||
*
|
|
||||||
* @author MingLiPro
|
|
||||||
*/
|
|
||||||
public class RandomString {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生成指定长度和字符集的随机字符串
|
|
||||||
*
|
|
||||||
* @param length 要生成的随机字符串长度
|
|
||||||
* @param chars 用于生成随机字符串的字符集
|
|
||||||
* @return 指定长度的随机字符串
|
|
||||||
*/
|
|
||||||
public static String randomString(int length, String chars) {
|
|
||||||
String[] charsd = chars.split("");
|
|
||||||
StringBuilder sb = new StringBuilder(length);
|
|
||||||
// 循环生成随机字符并拼接
|
|
||||||
for (int i = 0; i < length; i++) {
|
|
||||||
int index = RandomInt.randomInt(0, charsd.length - 1);
|
|
||||||
sb.append(charsd[index]);
|
|
||||||
}
|
|
||||||
return sb.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生成指定长度的随机字符串,使用默认字符集(数字+大小写字母)
|
|
||||||
*
|
|
||||||
* @param length 要生成的随机字符串长度
|
|
||||||
* @return 指定长度的随机字符串
|
|
||||||
*/
|
|
||||||
public static String randomString(int length) {
|
|
||||||
return randomString(
|
|
||||||
length,
|
|
||||||
"0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
32
src/main/java/com/mingliqiye/utils/test/Main.java
Normal file
32
src/main/java/com/mingliqiye/utils/test/Main.java
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2025 mingliqiye
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*
|
||||||
|
* ProjectName mingli-utils
|
||||||
|
* ModuleName mingli-utils.main
|
||||||
|
* CurrentFile Main.java
|
||||||
|
* LastUpdate 2025-09-12 12:19:48
|
||||||
|
* UpdateUser MingLiPro
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.mingliqiye.utils.test;
|
||||||
|
|
||||||
|
import com.mingliqiye.utils.version.VersionUtils;
|
||||||
|
|
||||||
|
public class Main {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
System.out.println(VersionUtils.is("1.3", "1.2.3"));
|
||||||
|
}
|
||||||
|
}
|
@ -1,285 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2025 mingliqiye
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*
|
|
||||||
* ProjectName mingli-utils
|
|
||||||
* ModuleName mingli-utils.main
|
|
||||||
* CurrentFile UUID.java
|
|
||||||
* LastUpdate 2025-09-10 11:14:27
|
|
||||||
* UpdateUser MingLiPro
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.mingliqiye.utils.uuid;
|
|
||||||
|
|
||||||
import com.github.f4b6a3.uuid.UuidCreator;
|
|
||||||
import com.mingliqiye.utils.string.StringUtil;
|
|
||||||
import com.mingliqiye.utils.time.DateTime;
|
|
||||||
import com.mingliqiye.utils.time.DateTimeOffset;
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.nio.ByteBuffer;
|
|
||||||
import java.time.temporal.ChronoUnit;
|
|
||||||
import java.util.Locale;
|
|
||||||
import java.util.Objects;
|
|
||||||
import lombok.Data;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* UUID 工具类,用于生成、解析和操作 UUID。
|
|
||||||
* 支持时间戳型 UUID(版本1)以及标准 UUID 的创建与转换。
|
|
||||||
*
|
|
||||||
* @author MingLiPro
|
|
||||||
*/
|
|
||||||
@Data
|
|
||||||
public class UUID implements Serializable {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 内部封装的 java.util.UUID 实例
|
|
||||||
*/
|
|
||||||
private java.util.UUID uuid;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 构造一个由指定高位和低位组成的 UUID。
|
|
||||||
*
|
|
||||||
* @param msb 高64位
|
|
||||||
* @param lsb 低64位
|
|
||||||
*/
|
|
||||||
public UUID(long msb, long lsb) {
|
|
||||||
uuid = new java.util.UUID(msb, lsb);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 构造一个基于当前时间的时间戳型 UUID(版本1)。<br>
|
|
||||||
* 由于springboot 默认使用此构造函数构造UUID 导致致命BUG 废弃<br>
|
|
||||||
* 下个大版本删除<br>
|
|
||||||
* @deprecated 请使用 <code>UUID.getTimeBased()</code>
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public UUID() {
|
|
||||||
uuid = UUID.getTimeBased().GetUUID();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 使用给定的 java.util.UUID 对象构造一个新的 UUID 实例。
|
|
||||||
*
|
|
||||||
* @param uuid java.util.UUID 实例
|
|
||||||
*/
|
|
||||||
public UUID(java.util.UUID uuid) {
|
|
||||||
this.uuid = uuid;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 根据字符串表示的 UUID 构造一个新的 UUID 实例。
|
|
||||||
*
|
|
||||||
* @param uuid 字符串形式的 UUID
|
|
||||||
*/
|
|
||||||
public UUID(String uuid) {
|
|
||||||
this.uuid = java.util.UUID.fromString(uuid);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取一个基于当前时间生成的时间戳型 UUID(版本1)。
|
|
||||||
*
|
|
||||||
* @return 时间戳型 UUID
|
|
||||||
*/
|
|
||||||
public static UUID getTimeBased() {
|
|
||||||
return new UUID(UuidCreator.getTimeBased());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 将字节数组转换为 UUID 实例。
|
|
||||||
*
|
|
||||||
* @param bytes 表示 UUID 的 16 字节数据
|
|
||||||
* @return 新建的 UUID 实例
|
|
||||||
*/
|
|
||||||
public static UUID of(byte[] bytes) {
|
|
||||||
if (bytes == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
ByteBuffer bb = ByteBuffer.wrap(bytes);
|
|
||||||
long msb = bb.getLong();
|
|
||||||
long lsb = bb.getLong();
|
|
||||||
return new UUID(msb, lsb);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 将字符串解析为 UUID 实例,如果解析失败则抛出 UUIDException。
|
|
||||||
*
|
|
||||||
* @param data UUID 字符串
|
|
||||||
* @return 解析后的 UUID 实例
|
|
||||||
* @throws UUIDException 如果解析失败
|
|
||||||
*/
|
|
||||||
public static UUID of(String data) {
|
|
||||||
if (data == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
return new UUID(java.util.UUID.fromString(data));
|
|
||||||
} catch (Exception e) {
|
|
||||||
throw new UUIDException(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 将 UUID 转换为 16 字节的字节数组。
|
|
||||||
*
|
|
||||||
* @return 表示该 UUID 的字节数组
|
|
||||||
*/
|
|
||||||
public byte[] toBytes() {
|
|
||||||
if (this.uuid == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
ByteBuffer bb = ByteBuffer.wrap(new byte[16]);
|
|
||||||
bb.putLong(uuid.getMostSignificantBits());
|
|
||||||
bb.putLong(uuid.getLeastSignificantBits());
|
|
||||||
return bb.array();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取内部封装的 java.util.UUID 实例。
|
|
||||||
*
|
|
||||||
* @return java.util.UUID 实例
|
|
||||||
*/
|
|
||||||
public java.util.UUID GetUUID() {
|
|
||||||
return uuid;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 将 UUID 转换为字符串表示,默认使用小写格式。
|
|
||||||
*
|
|
||||||
* @return UUID 字符串
|
|
||||||
*/
|
|
||||||
public String toUUIDString() {
|
|
||||||
return toUUIDString(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 将 UUID 转换为字符串表示,并可选择是否使用大写。
|
|
||||||
*
|
|
||||||
* @param u 是否使用大写格式
|
|
||||||
* @return UUID 字符串
|
|
||||||
* @throws UUIDException 如果 uuid 为 null
|
|
||||||
*/
|
|
||||||
public String toUUIDString(boolean u) {
|
|
||||||
if (uuid == null) {
|
|
||||||
throw new UUIDException("uuid is null : NullPointerException");
|
|
||||||
}
|
|
||||||
if (u) {
|
|
||||||
return uuid.toString().toUpperCase(Locale.ROOT);
|
|
||||||
}
|
|
||||||
return uuid.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 计算此 UUID 的哈希码。
|
|
||||||
*
|
|
||||||
* @return 哈希码值
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
return Objects.hash(uuid);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 判断两个 UUID 是否相等。
|
|
||||||
*
|
|
||||||
* @param o 比较对象
|
|
||||||
* @return 如果相等返回 true,否则返回 false
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public boolean equals(Object o) {
|
|
||||||
if (this == o) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (o == null || getClass() != o.getClass()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
UUID uuid = (UUID) o;
|
|
||||||
return Objects.equals(this.uuid, uuid.uuid);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 返回此 UUID 的字符串表示,包含版本信息和时间戳(如果是版本1)。
|
|
||||||
*
|
|
||||||
* @return UUID 的详细字符串表示
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
if (uuid == null) {
|
|
||||||
return "UUID(null)";
|
|
||||||
}
|
|
||||||
return StringUtil.format(
|
|
||||||
"UUID(uuid={},version={})",
|
|
||||||
toUUIDString(true),
|
|
||||||
uuid.version()
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 从时间戳型 UUID 中提取时间戳并转换为 DateTime 对象。
|
|
||||||
*
|
|
||||||
* @return 对应的 DateTime 对象;如果 uuid 为 null,则返回 null
|
|
||||||
*/
|
|
||||||
public DateTime getDateTime() {
|
|
||||||
if (uuid == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
if (uuid.version() != 1) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
return DateTime.of(uuid.timestamp() / 10_000).add(
|
|
||||||
DateTimeOffset.of(-141427L, ChronoUnit.DAYS)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 从时间戳型 UUID 中提取 MAC 地址,默认使用冒号分隔符。
|
|
||||||
*
|
|
||||||
* @return MAC 地址字符串
|
|
||||||
* @throws UUIDException 如果 uuid 为 null
|
|
||||||
*/
|
|
||||||
public String extractMACFromUUID() {
|
|
||||||
return extractMACFromUUID(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 从时间戳型 UUID 中提取 MAC 地址,并允许自定义分隔符。
|
|
||||||
*
|
|
||||||
* @param spec 分隔符字符,默认为 ":"
|
|
||||||
* @return MAC 地址字符串
|
|
||||||
* @throws UUIDException 如果 uuid 为 null
|
|
||||||
*/
|
|
||||||
public String extractMACFromUUID(String spec) {
|
|
||||||
if (uuid == null) {
|
|
||||||
throw new UUIDException("uuid is null : NullPointerException");
|
|
||||||
}
|
|
||||||
if (spec == null) {
|
|
||||||
spec = ":";
|
|
||||||
}
|
|
||||||
long leastSigBits = uuid.getLeastSignificantBits();
|
|
||||||
long macLong = leastSigBits & 0xFFFFFFFFFFFFL;
|
|
||||||
byte[] macBytes = new byte[6];
|
|
||||||
// 提取 MAC 地址的每个字节
|
|
||||||
for (int i = 0; i < 6; i++) {
|
|
||||||
macBytes[5 - i] = (byte) (macLong >> (8 * i));
|
|
||||||
}
|
|
||||||
StringBuilder mac = new StringBuilder();
|
|
||||||
// 构造 MAC 地址字符串
|
|
||||||
for (int i = 0; i < 6; i++) {
|
|
||||||
mac.append(String.format("%02X", macBytes[i]));
|
|
||||||
if (i < 5) {
|
|
||||||
mac.append(spec);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return mac.toString();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,102 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2025 mingliqiye
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*
|
|
||||||
* ProjectName mingli-utils
|
|
||||||
* ModuleName mingli-utils.main
|
|
||||||
* CurrentFile VersionUtils.java
|
|
||||||
* LastUpdate 2025-09-09 08:37:33
|
|
||||||
* UpdateUser MingLiPro
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.mingliqiye.utils.version;
|
|
||||||
|
|
||||||
import java.util.Objects;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 版本工具类,提供版本比较相关的方法
|
|
||||||
*/
|
|
||||||
public class VersionUtils {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 判断当前版本是否比另一个版本新
|
|
||||||
*
|
|
||||||
* @param now 当前版本号字符串,格式如"1.0.0"
|
|
||||||
* @param other 要比较的版本号字符串,格式如"2.0.0"
|
|
||||||
* @return 如果当前版本更新则返回true,否则返回false
|
|
||||||
*/
|
|
||||||
public static boolean isNew(String now, String other) {
|
|
||||||
String[] currentParts = now.split("\\.");
|
|
||||||
String[] minimumParts = other.split("\\.");
|
|
||||||
|
|
||||||
for (
|
|
||||||
int i = 0;
|
|
||||||
i < Math.max(currentParts.length, minimumParts.length);
|
|
||||||
i++
|
|
||||||
) {
|
|
||||||
int currentNum = i < currentParts.length
|
|
||||||
? Integer.parseInt(currentParts[i])
|
|
||||||
: 0;
|
|
||||||
int minimumNum = i < minimumParts.length
|
|
||||||
? Integer.parseInt(minimumParts[i])
|
|
||||||
: 0;
|
|
||||||
|
|
||||||
if (currentNum < minimumNum) {
|
|
||||||
return true;
|
|
||||||
} else if (currentNum > minimumNum) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 判断当前版本是否比另一个版本旧
|
|
||||||
*
|
|
||||||
* @param now 当前版本号字符串,格式如"1.0.0"
|
|
||||||
* @param other 要比较的版本号字符串,格式如"2.0.0"
|
|
||||||
* @return 如果当前版本更旧则返回true,否则返回false
|
|
||||||
*/
|
|
||||||
public static boolean isOld(String now, String other) {
|
|
||||||
return !equals(now, other) && !isNew(now, other);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 判断两个版本号是否相等
|
|
||||||
*
|
|
||||||
* @param now 当前版本号字符串,格式如"1.0.0"
|
|
||||||
* @param other 要比较的版本号字符串,格式如"2.0.0"
|
|
||||||
* @return 如果两个版本号相等则返回true,否则返回false
|
|
||||||
*/
|
|
||||||
public static boolean equals(String now, String other) {
|
|
||||||
return Objects.equals(now, other);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 比较两个版本号的大小关系
|
|
||||||
*
|
|
||||||
* @param now 当前版本号字符串,格式如"1.0.0"
|
|
||||||
* @param other 要比较的版本号字符串,格式如"2.0.0"
|
|
||||||
* @return 如果当前版本更新返回2,如果更旧返回0,如果相等返回1
|
|
||||||
*/
|
|
||||||
public static byte is(String now, String other) {
|
|
||||||
if (isNew(now, other)) {
|
|
||||||
return 2;
|
|
||||||
} else if (isOld(now, other)) {
|
|
||||||
return 0;
|
|
||||||
} else {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -15,19 +15,18 @@
|
|||||||
*
|
*
|
||||||
* ProjectName mingli-utils
|
* ProjectName mingli-utils
|
||||||
* ModuleName mingli-utils.main
|
* ModuleName mingli-utils.main
|
||||||
* CurrentFile Main.java
|
* CurrentFile Main.kt
|
||||||
* LastUpdate 2025-09-09 08:37:33
|
* LastUpdate 2025-09-12 17:11:48
|
||||||
* UpdateUser MingLiPro
|
* UpdateUser MingLiPro
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package com.mingliqiye.utils;
|
@file:JvmName("Main")
|
||||||
|
|
||||||
import com.mingliqiye.utils.springboot.autoconfigure.AutoConfiguration;
|
package com.mingliqiye.utils
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
public class Main {
|
import com.mingliqiye.utils.springboot.autoconfigure.AutoConfiguration
|
||||||
|
|
||||||
public static void main(String[] args) throws IOException {
|
|
||||||
AutoConfiguration.printBanner();
|
fun main() {
|
||||||
}
|
AutoConfiguration.printBanner()
|
||||||
}
|
}
|
83
src/main/kotlin/com/mingliqiye/utils/random/RandomBytes.kt
Normal file
83
src/main/kotlin/com/mingliqiye/utils/random/RandomBytes.kt
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2025 mingliqiye
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*
|
||||||
|
* ProjectName mingli-utils
|
||||||
|
* ModuleName mingli-utils.main
|
||||||
|
* CurrentFile RandomBytes.kt
|
||||||
|
* LastUpdate 2025-09-12 17:11:19
|
||||||
|
* UpdateUser MingLiPro
|
||||||
|
*/
|
||||||
|
@file:JvmName("RandomBytes")
|
||||||
|
|
||||||
|
package com.mingliqiye.utils.random
|
||||||
|
|
||||||
|
import com.mingliqiye.utils.collection.ForEach
|
||||||
|
import com.mingliqiye.utils.iterator.Range
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 生成指定长度的随机字节数组
|
||||||
|
* @param length 数组长度
|
||||||
|
* @return 包含随机字节的数组
|
||||||
|
*/
|
||||||
|
fun randomBytes(length: Int): ByteArray {
|
||||||
|
val bytes = ByteArray(length)
|
||||||
|
ForEach.forEach(
|
||||||
|
Range(0, length - 1)
|
||||||
|
) { i: Int -> bytes[i] = randomByte(0x00.toByte(), 0xff.toByte()) }
|
||||||
|
return bytes
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 生成指定长度的随机字节数组
|
||||||
|
* 从给定的字节数组中随机选择字节来填充新数组
|
||||||
|
*
|
||||||
|
* @param length 要生成的随机字节数组的长度
|
||||||
|
* @param bytes 用于随机选择的源字节数组
|
||||||
|
* @return 包含随机字节的新数组
|
||||||
|
*/
|
||||||
|
fun randomBytes(length: Int, bytes: ByteArray): ByteArray {
|
||||||
|
val rbytes = ByteArray(length)
|
||||||
|
// 从源数组中随机选择字节填充到结果数组中
|
||||||
|
for (i in 0..<length) {
|
||||||
|
rbytes[i] = bytes[randomInt(i, bytes.size - 1)]
|
||||||
|
}
|
||||||
|
return rbytes
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 生成指定范围内的随机字节
|
||||||
|
* @param from 起始字节值(包含)
|
||||||
|
* @param to 结束字节值(包含)
|
||||||
|
* @return 指定范围内的随机字节
|
||||||
|
*/
|
||||||
|
fun randomByte(from: Byte, to: Byte): Byte {
|
||||||
|
val fromInt = from.toInt() and 0xFF
|
||||||
|
val toInt = to.toInt() and 0xFF
|
||||||
|
val randomValue = randomInt(fromInt, toInt)
|
||||||
|
return (randomValue and 0xFF).toByte()
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 生成指定范围内的随机字节(不包含边界值)
|
||||||
|
* @param from 起始字节值(不包含)
|
||||||
|
* @param to 结束字节值(不包含)
|
||||||
|
* @return 指定范围内的随机字节
|
||||||
|
*/
|
||||||
|
fun randomByteNoHave(from: Byte, to: Byte): Byte {
|
||||||
|
val fromInt = from.toInt() and 0xFF
|
||||||
|
val toInt = to.toInt() and 0xFF
|
||||||
|
val randomValue = randomIntNoHave(fromInt, toInt)
|
||||||
|
return (randomValue and 0xFF).toByte()
|
||||||
|
}
|
60
src/main/kotlin/com/mingliqiye/utils/random/RandomInt.kt
Normal file
60
src/main/kotlin/com/mingliqiye/utils/random/RandomInt.kt
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2025 mingliqiye
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*
|
||||||
|
* ProjectName mingli-utils
|
||||||
|
* ModuleName mingli-utils.main
|
||||||
|
* CurrentFile RandomInt.kt
|
||||||
|
* LastUpdate 2025-09-12 17:08:32
|
||||||
|
* UpdateUser MingLiPro
|
||||||
|
*/
|
||||||
|
@file:JvmName("RandomInt")
|
||||||
|
|
||||||
|
package com.mingliqiye.utils.random
|
||||||
|
|
||||||
|
import java.util.concurrent.ThreadLocalRandom
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 生成指定范围内的随机整数
|
||||||
|
* @param min 最小值(包含)
|
||||||
|
* @param max 最大值(不包含)
|
||||||
|
* @return 随机整数
|
||||||
|
*/
|
||||||
|
fun randomIntNoHave(min: Int, max: Int): Int {
|
||||||
|
var min = min
|
||||||
|
var max = max
|
||||||
|
if (min > max) {
|
||||||
|
val t = min
|
||||||
|
min = max
|
||||||
|
max = t
|
||||||
|
}
|
||||||
|
if (min == max) {
|
||||||
|
return min
|
||||||
|
}
|
||||||
|
return ThreadLocalRandom.current().nextInt(min, max)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 生成指定范围内的随机整数
|
||||||
|
* @param min 最小值(包含)
|
||||||
|
* @param max 最大值(包含)
|
||||||
|
* @return 随机整数
|
||||||
|
*/
|
||||||
|
fun randomInt(min: Int, max: Int): Int {
|
||||||
|
var max = max
|
||||||
|
return randomIntNoHave(min, ++max)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
54
src/main/kotlin/com/mingliqiye/utils/random/RandomString.kt
Normal file
54
src/main/kotlin/com/mingliqiye/utils/random/RandomString.kt
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2025 mingliqiye
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*
|
||||||
|
* ProjectName mingli-utils
|
||||||
|
* ModuleName mingli-utils.main
|
||||||
|
* CurrentFile RandomString.kt
|
||||||
|
* LastUpdate 2025-09-12 17:10:43
|
||||||
|
* UpdateUser MingLiPro
|
||||||
|
*/
|
||||||
|
@file:JvmName("RandomString")
|
||||||
|
|
||||||
|
package com.mingliqiye.utils.random
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 生成指定长度和字符集的随机字符串
|
||||||
|
*
|
||||||
|
* @param length 要生成的随机字符串长度
|
||||||
|
* @param chars 用于生成随机字符串的字符集
|
||||||
|
* @return 指定长度的随机字符串
|
||||||
|
*/
|
||||||
|
fun randomString(length: Int, chars: String): String {
|
||||||
|
val charsd: Array<String?> = chars.split("".toRegex()).dropLastWhile { it.isEmpty() }.toTypedArray()
|
||||||
|
val sb = StringBuilder(length)
|
||||||
|
// 循环生成随机字符并拼接
|
||||||
|
for (i in 0..<length) {
|
||||||
|
val index = randomInt(0, charsd.size - 1)
|
||||||
|
sb.append(charsd[index])
|
||||||
|
}
|
||||||
|
return sb.toString()
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 生成指定长度的随机字符串,使用默认字符集(数字+大小写字母)
|
||||||
|
*
|
||||||
|
* @param length 要生成的随机字符串长度
|
||||||
|
* @return 指定长度的随机字符串
|
||||||
|
*/
|
||||||
|
fun randomString(length: Int): String {
|
||||||
|
return randomString(
|
||||||
|
length, "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
|
||||||
|
)
|
||||||
|
}
|
244
src/main/kotlin/com/mingliqiye/utils/uuid/UUID.kt
Normal file
244
src/main/kotlin/com/mingliqiye/utils/uuid/UUID.kt
Normal file
@ -0,0 +1,244 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2025 mingliqiye
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*
|
||||||
|
* ProjectName mingli-utils
|
||||||
|
* ModuleName mingli-utils.main
|
||||||
|
* CurrentFile UUID.kt
|
||||||
|
* LastUpdate 2025-09-12 16:57:52
|
||||||
|
* UpdateUser MingLiPro
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.mingliqiye.utils.uuid
|
||||||
|
|
||||||
|
import com.github.f4b6a3.uuid.UuidCreator
|
||||||
|
import com.mingliqiye.utils.time.DateTime
|
||||||
|
import com.mingliqiye.utils.time.DateTimeOffset
|
||||||
|
import java.io.Serializable
|
||||||
|
import java.nio.ByteBuffer
|
||||||
|
import java.time.temporal.ChronoUnit
|
||||||
|
import java.util.*
|
||||||
|
import java.util.UUID as JUUID
|
||||||
|
|
||||||
|
|
||||||
|
class UUID : Serializable {
|
||||||
|
private val uuid: JUUID
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
/**
|
||||||
|
* 获取 UUIDV1 版本的随机实例
|
||||||
|
* @return UUID
|
||||||
|
*/
|
||||||
|
@JvmStatic
|
||||||
|
fun getV1(): UUID {
|
||||||
|
return UUID(UuidCreator.getTimeBased())
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取 UUIDV4 版本的随机实例
|
||||||
|
* @return UUID
|
||||||
|
*/
|
||||||
|
@JvmStatic
|
||||||
|
fun getV4(): UUID {
|
||||||
|
return UUID(UuidCreator.getRandomBased())
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取 UUIDV1Fast 版本的随机实例
|
||||||
|
* @return UUID
|
||||||
|
*/
|
||||||
|
@JvmStatic
|
||||||
|
fun getV4Fast(): UUID {
|
||||||
|
return UUID(UuidCreator.getRandomBasedFast())
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 从2个8个字节转换到UUID
|
||||||
|
* @param lsb 高位 8 字节的 Long
|
||||||
|
* @param msb 低位 8 字节的 Long
|
||||||
|
* @return UUID
|
||||||
|
*/
|
||||||
|
@JvmStatic
|
||||||
|
fun of(msb: Long, lsb: Long): UUID {
|
||||||
|
return UUID(msb, lsb)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 从字符串格式化
|
||||||
|
* @param uuid 字符串
|
||||||
|
* @return UUID
|
||||||
|
*/
|
||||||
|
@JvmStatic
|
||||||
|
fun of(uuid: String): UUID {
|
||||||
|
return UUID(uuid)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 从字节码转换到UUID
|
||||||
|
* @param array 16字节
|
||||||
|
* @return UUID
|
||||||
|
*/
|
||||||
|
@JvmStatic
|
||||||
|
fun of(array: ByteArray): UUID {
|
||||||
|
return UUID(array)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
internal constructor(msb: Long, lsb: Long) {
|
||||||
|
uuid = JUUID(msb, lsb)
|
||||||
|
}
|
||||||
|
|
||||||
|
internal constructor(uuid: JUUID) {
|
||||||
|
this.uuid = uuid
|
||||||
|
}
|
||||||
|
|
||||||
|
internal constructor(array: ByteArray) {
|
||||||
|
val bb = ByteBuffer.wrap(array)
|
||||||
|
this.uuid = JUUID(bb.getLong(), bb.getLong())
|
||||||
|
}
|
||||||
|
|
||||||
|
internal constructor(uuid: String) {
|
||||||
|
this.uuid = JUUID.fromString(uuid)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取对应的字节码
|
||||||
|
* @return 字节码
|
||||||
|
*/
|
||||||
|
fun toBytes(): ByteArray {
|
||||||
|
val bb = ByteBuffer.wrap(ByteArray(16))
|
||||||
|
bb.putLong(uuid.mostSignificantBits)
|
||||||
|
bb.putLong(uuid.leastSignificantBits)
|
||||||
|
|
||||||
|
return bb.array()
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取Java的UUID对象
|
||||||
|
* @return Java的UUID对象
|
||||||
|
*/
|
||||||
|
fun getUuid(): JUUID {
|
||||||
|
return uuid
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 将 UUID 转换为字符串表示,默认使用小写格式。
|
||||||
|
* @param u 是否大写
|
||||||
|
* @return UUID 字符串
|
||||||
|
*/
|
||||||
|
fun getString(u: Boolean): String {
|
||||||
|
return if (u) {
|
||||||
|
uuid.toString().uppercase(Locale.ROOT)
|
||||||
|
} else {
|
||||||
|
uuid.toString()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 将 UUID 转换为字符串表示,默认使用小写格式。
|
||||||
|
*
|
||||||
|
* @return UUID 字符串
|
||||||
|
*/
|
||||||
|
fun getString(): String {
|
||||||
|
return getString(false)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Deprecated("使用 getString()", ReplaceWith("getString"), level = DeprecationLevel.WARNING)
|
||||||
|
fun toUUIDString(): String {
|
||||||
|
return this.getString()
|
||||||
|
}
|
||||||
|
|
||||||
|
@Deprecated("使用 getString(u:Boolean)", ReplaceWith("getString(u)"), level = DeprecationLevel.WARNING)
|
||||||
|
fun toUUIDString(u: Boolean): String {
|
||||||
|
return this.getString(u)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 从时间戳型 UUID 中提取时间戳并转换为 DateTime 对象。
|
||||||
|
*
|
||||||
|
* @return 对应的 DateTime 对象;如果 不是 时间戳V1版本 返回 null
|
||||||
|
*/
|
||||||
|
fun getDateTime(): DateTime? {
|
||||||
|
if (uuid.version() != 1) {
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
return DateTime.of(uuid.timestamp() / 10000).add(
|
||||||
|
DateTimeOffset.of(-141427L, ChronoUnit.DAYS)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 从时间戳型 UUID 中提取 MAC 地址,默认使用冒号分隔符。
|
||||||
|
*
|
||||||
|
* @return MAC 地址字符串
|
||||||
|
*/
|
||||||
|
fun extractMACFromUUID(): String {
|
||||||
|
return extractMACFromUUID(null)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 从时间戳型 UUID 中提取 MAC 地址,并允许自定义分隔符。
|
||||||
|
*
|
||||||
|
* @param spec 分隔符字符,默认为 ":"
|
||||||
|
* @return MAC 地址字符串
|
||||||
|
*/
|
||||||
|
fun extractMACFromUUID(spec: String?): String {
|
||||||
|
var spec = spec
|
||||||
|
if (spec == null) {
|
||||||
|
spec = ":"
|
||||||
|
}
|
||||||
|
val leastSigBits = uuid.leastSignificantBits
|
||||||
|
val macLong = leastSigBits and 0xFFFFFFFFFFFFL
|
||||||
|
val macBytes = ByteArray(6)
|
||||||
|
for (i in 0..5) {
|
||||||
|
macBytes[5 - i] = (macLong shr (8 * i)).toByte()
|
||||||
|
}
|
||||||
|
val mac = StringBuilder()
|
||||||
|
for (i in 0..5) {
|
||||||
|
mac.append(String.format("%02X", macBytes[i]))
|
||||||
|
if (i < 5) {
|
||||||
|
mac.append(spec)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return mac.toString()
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 返回此 UUID 的字符串表示,包含版本信息和时间戳(如果是版本1)。
|
||||||
|
*
|
||||||
|
* @return UUID 的详细字符串表示
|
||||||
|
*/
|
||||||
|
override fun toString(): String {
|
||||||
|
return "UUID(uuid=${getString()},version=${uuid.version()})"
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 判断两个 UUID 是否相等。
|
||||||
|
*
|
||||||
|
* @param other 比较对象
|
||||||
|
* @return 如果相等返回 true,否则返回 false
|
||||||
|
*/
|
||||||
|
override fun equals(other: Any?): Boolean {
|
||||||
|
return uuid == other
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 计算此 UUID 的哈希码。
|
||||||
|
*
|
||||||
|
* @return 哈希码值
|
||||||
|
*/
|
||||||
|
override fun hashCode(): Int {
|
||||||
|
return uuid.hashCode()
|
||||||
|
}
|
||||||
|
}
|
99
src/main/kotlin/com/mingliqiye/utils/version/VersionUtils.kt
Normal file
99
src/main/kotlin/com/mingliqiye/utils/version/VersionUtils.kt
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2025 mingliqiye
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*
|
||||||
|
* ProjectName mingli-utils
|
||||||
|
* ModuleName mingli-utils.main
|
||||||
|
* CurrentFile VersionUtils.kt
|
||||||
|
* LastUpdate 2025-09-12 15:09:57
|
||||||
|
* UpdateUser MingLiPro
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
@file:JvmName("VersionUtils")
|
||||||
|
|
||||||
|
package com.mingliqiye.utils.version
|
||||||
|
|
||||||
|
import kotlin.math.max
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 判断是否需要更新
|
||||||
|
* @param now 当前版本
|
||||||
|
* @param other 比较版本
|
||||||
|
* @return 当前版本需要更新
|
||||||
|
* @since 3.2.7
|
||||||
|
*/
|
||||||
|
fun isNew(now: String, other: String): Boolean {
|
||||||
|
val otherA = now.split(".")
|
||||||
|
val otherB = other.split(".")
|
||||||
|
|
||||||
|
val maxLen = max(otherA.size, otherB.size)
|
||||||
|
|
||||||
|
for (i in 0..<maxLen) {
|
||||||
|
|
||||||
|
val a = if (otherA.size > i) otherA[i].toInt() else null
|
||||||
|
val b = if (otherB.size > i) otherB[i].toInt() else null
|
||||||
|
|
||||||
|
if (a == null) {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
if (b == null) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
if (a != b) {
|
||||||
|
return a < b
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 判断版本是否小于当前
|
||||||
|
* @param now 当前版本
|
||||||
|
* @param other 比较版本
|
||||||
|
* @return 是否小于
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
fun isOld(now: String, other: String): Boolean {
|
||||||
|
return (now != other) && !isNew(now, other)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 判断是否版本相同
|
||||||
|
* @param now 当前版本
|
||||||
|
* @param other 比较版本
|
||||||
|
* @return 是否相同
|
||||||
|
*/
|
||||||
|
fun equals(now: String, other: String): Boolean {
|
||||||
|
return now == other
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 判断是否需要更新
|
||||||
|
* @param now 当前版本
|
||||||
|
* @param other 比较版本
|
||||||
|
* @return null->版本相同 true->需要更新 false->不需要更新
|
||||||
|
*/
|
||||||
|
@JvmName("is")
|
||||||
|
fun isOther(now: String, other: String): Boolean? {
|
||||||
|
return if (isNew(now, other)) {
|
||||||
|
true
|
||||||
|
} else if (isOld(now, other)) {
|
||||||
|
false
|
||||||
|
} else {
|
||||||
|
null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user