This commit is contained in:
Looly 2022-05-30 07:49:47 +08:00
parent e1437f9b65
commit 28a565da25
4 changed files with 55 additions and 22 deletions

View File

@ -1242,12 +1242,13 @@ public class NumberUtil {
* @return 是否为整数 * @return 是否为整数
*/ */
public static boolean isInteger(final String s) { public static boolean isInteger(final String s) {
if(StrUtil.isNotBlank(s)) { if(StrUtil.isBlank(s)) {
try { return false;
Integer.parseInt(s); }
} catch (final NumberFormatException e) { try {
return false; Integer.parseInt(s);
} } catch (final NumberFormatException e) {
return false;
} }
return true; return true;
} }
@ -1261,12 +1262,13 @@ public class NumberUtil {
* @since 4.0.0 * @since 4.0.0
*/ */
public static boolean isLong(final String s) { public static boolean isLong(final String s) {
if (StrUtil.isNotBlank(s)) { if(StrUtil.isBlank(s)) {
try { return false;
Long.parseLong(s); }
} catch (final NumberFormatException e) { try {
return false; Long.parseLong(s);
} } catch (final NumberFormatException e) {
return false;
} }
return true; return true;
} }
@ -1278,15 +1280,16 @@ public class NumberUtil {
* @return 是否为{@link Double}类型 * @return 是否为{@link Double}类型
*/ */
public static boolean isDouble(final String s) { public static boolean isDouble(final String s) {
if (StrUtil.isNotBlank(s)) { if(StrUtil.isBlank(s)) {
try { return false;
Double.parseDouble(s);
return s.contains(".");
} catch (final NumberFormatException ignore) {
// ignore
}
} }
return false; try {
Double.parseDouble(s);
return s.contains(".");
} catch (final NumberFormatException ignore) {
// ignore
}
return true;
} }
/** /**

View File

@ -62,6 +62,9 @@ public class NumberUtilTest {
Assert.assertTrue(NumberUtil.isInteger("0256")); Assert.assertTrue(NumberUtil.isInteger("0256"));
Assert.assertTrue(NumberUtil.isInteger("0")); Assert.assertTrue(NumberUtil.isInteger("0"));
Assert.assertFalse(NumberUtil.isInteger("23.4")); Assert.assertFalse(NumberUtil.isInteger("23.4"));
Assert.assertFalse(NumberUtil.isInteger(null));
Assert.assertFalse(NumberUtil.isInteger(""));
Assert.assertFalse(NumberUtil.isInteger(" "));
} }
@Test @Test
@ -71,6 +74,9 @@ public class NumberUtilTest {
Assert.assertTrue(NumberUtil.isLong("0256")); Assert.assertTrue(NumberUtil.isLong("0256"));
Assert.assertTrue(NumberUtil.isLong("0")); Assert.assertTrue(NumberUtil.isLong("0"));
Assert.assertFalse(NumberUtil.isLong("23.4")); Assert.assertFalse(NumberUtil.isLong("23.4"));
Assert.assertFalse(NumberUtil.isLong(null));
Assert.assertFalse(NumberUtil.isLong(""));
Assert.assertFalse(NumberUtil.isLong(" "));
} }
@Test @Test

View File

@ -23,8 +23,9 @@ public class MailAccount implements Serializable {
private static final String SMTP_HOST = "mail.smtp.host"; private static final String SMTP_HOST = "mail.smtp.host";
private static final String SMTP_PORT = "mail.smtp.port"; private static final String SMTP_PORT = "mail.smtp.port";
private static final String SMTP_AUTH = "mail.smtp.auth"; private static final String SMTP_AUTH = "mail.smtp.auth";
private static final String SMTP_CONNECTION_TIMEOUT = "mail.smtp.connectiontimeout";
private static final String SMTP_TIMEOUT = "mail.smtp.timeout"; private static final String SMTP_TIMEOUT = "mail.smtp.timeout";
private static final String SMTP_CONNECTION_TIMEOUT = "mail.smtp.connectiontimeout";
private static final String SMTP_WRITE_TIMEOUT = "mail.smtp.writetimeout";
// SSL // SSL
private static final String STARTTLS_ENABLE = "mail.smtp.starttls.enable"; private static final String STARTTLS_ENABLE = "mail.smtp.starttls.enable";
@ -117,11 +118,17 @@ public class MailAccount implements Serializable {
* SMTP超时时长单位毫秒缺省值不超时 * SMTP超时时长单位毫秒缺省值不超时
*/ */
private long timeout; private long timeout;
/** /**
* Socket连接超时值单位毫秒缺省值不超时 * Socket连接超时值单位毫秒缺省值不超时
*/ */
private long connectionTimeout; private long connectionTimeout;
/**
* Socket写出超时值单位毫秒缺省值不超时
*/
private long writeTimeout;
/** /**
* 自定义的其他属性此自定义属性会覆盖默认属性 * 自定义的其他属性此自定义属性会覆盖默认属性
*/ */
@ -518,6 +525,17 @@ public class MailAccount implements Serializable {
return this; return this;
} }
/**
* 设置Socket写出超时值单位毫秒缺省值不超时
*
* @param writeTimeout Socket写出超时值单位毫秒缺省值不超时
* @return this
*/
public MailAccount setWriteTimeout(final long writeTimeout) {
this.writeTimeout = writeTimeout;
return this;
}
/** /**
* 获取自定义属性列表 * 获取自定义属性列表
* *
@ -563,6 +581,10 @@ public class MailAccount implements Serializable {
if (this.connectionTimeout > 0) { if (this.connectionTimeout > 0) {
p.put(SMTP_CONNECTION_TIMEOUT, String.valueOf(this.connectionTimeout)); p.put(SMTP_CONNECTION_TIMEOUT, String.valueOf(this.connectionTimeout));
} }
// issue#2355
if (this.writeTimeout > 0) {
p.put(SMTP_WRITE_TIMEOUT, String.valueOf(this.writeTimeout));
}
p.put(MAIL_DEBUG, String.valueOf(this.debug)); p.put(MAIL_DEBUG, String.valueOf(this.debug));

View File

@ -37,4 +37,6 @@ splitlongparameters = false
# SMTP超时时长单位毫秒缺省值不超时 # SMTP超时时长单位毫秒缺省值不超时
timeout = 0 timeout = 0
# Socket连接超时值单位毫秒缺省值不超时 # Socket连接超时值单位毫秒缺省值不超时
connectionTimeout = 0 connectionTimeout = 0
# Socket写出超时值单位毫秒缺省值不超时
writeTimeout = 0