|
@@ -4,6 +4,7 @@ import java.lang.reflect.InvocationTargetException;
|
|
|
import java.lang.reflect.Method;
|
|
|
import java.util.LinkedList;
|
|
|
import java.util.List;
|
|
|
+
|
|
|
import com.ruoyi.common.utils.StringUtils;
|
|
|
import com.ruoyi.common.utils.spring.SpringUtils;
|
|
|
import com.ruoyi.quartz.domain.SysJob;
|
|
@@ -13,27 +14,22 @@ import com.ruoyi.quartz.domain.SysJob;
|
|
|
*
|
|
|
* @author ruoyi
|
|
|
*/
|
|
|
-public class JobInvokeUtil
|
|
|
-{
|
|
|
+public class JobInvokeUtil {
|
|
|
/**
|
|
|
* 执行方法
|
|
|
*
|
|
|
* @param sysJob 系统任务
|
|
|
*/
|
|
|
- public static void invokeMethod(SysJob sysJob) throws Exception
|
|
|
- {
|
|
|
+ public static void invokeMethod(SysJob sysJob) throws Exception {
|
|
|
String invokeTarget = sysJob.getInvokeTarget();
|
|
|
String beanName = getBeanName(invokeTarget);
|
|
|
String methodName = getMethodName(invokeTarget);
|
|
|
List<Object[]> methodParams = getMethodParams(invokeTarget);
|
|
|
|
|
|
- if (!isValidClassName(beanName))
|
|
|
- {
|
|
|
+ if (!isValidClassName(beanName)) {
|
|
|
Object bean = SpringUtils.getBean(beanName);
|
|
|
invokeMethod(bean, methodName, methodParams);
|
|
|
- }
|
|
|
- else
|
|
|
- {
|
|
|
+ } else {
|
|
|
Object bean = Class.forName(beanName).newInstance();
|
|
|
invokeMethod(bean, methodName, methodParams);
|
|
|
}
|
|
@@ -42,21 +38,17 @@ public class JobInvokeUtil
|
|
|
/**
|
|
|
* 调用任务方法
|
|
|
*
|
|
|
- * @param bean 目标对象
|
|
|
- * @param methodName 方法名称
|
|
|
+ * @param bean 目标对象
|
|
|
+ * @param methodName 方法名称
|
|
|
* @param methodParams 方法参数
|
|
|
*/
|
|
|
private static void invokeMethod(Object bean, String methodName, List<Object[]> methodParams)
|
|
|
throws NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException,
|
|
|
- InvocationTargetException
|
|
|
- {
|
|
|
- if (StringUtils.isNotNull(methodParams) && methodParams.size() > 0)
|
|
|
- {
|
|
|
+ InvocationTargetException {
|
|
|
+ if (StringUtils.isNotNull(methodParams) && methodParams.size() > 0) {
|
|
|
Method method = bean.getClass().getDeclaredMethod(methodName, getMethodParamsType(methodParams));
|
|
|
method.invoke(bean, getMethodParamsValue(methodParams));
|
|
|
- }
|
|
|
- else
|
|
|
- {
|
|
|
+ } else {
|
|
|
Method method = bean.getClass().getDeclaredMethod(methodName);
|
|
|
method.invoke(bean);
|
|
|
}
|
|
@@ -64,81 +56,70 @@ public class JobInvokeUtil
|
|
|
|
|
|
/**
|
|
|
* 校验是否为为class包名
|
|
|
- *
|
|
|
+ *
|
|
|
* @param str 名称
|
|
|
* @return true是 false否
|
|
|
*/
|
|
|
- public static boolean isValidClassName(String invokeTarget)
|
|
|
- {
|
|
|
+ public static boolean isValidClassName(String invokeTarget) {
|
|
|
return StringUtils.countMatches(invokeTarget, ".") > 1;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 获取bean名称
|
|
|
- *
|
|
|
+ *
|
|
|
* @param invokeTarget 目标字符串
|
|
|
* @return bean名称
|
|
|
*/
|
|
|
- public static String getBeanName(String invokeTarget)
|
|
|
- {
|
|
|
+ public static String getBeanName(String invokeTarget) {
|
|
|
String beanName = StringUtils.substringBefore(invokeTarget, "(");
|
|
|
return StringUtils.substringBeforeLast(beanName, ".");
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 获取bean方法
|
|
|
- *
|
|
|
+ *
|
|
|
* @param invokeTarget 目标字符串
|
|
|
* @return method方法
|
|
|
*/
|
|
|
- public static String getMethodName(String invokeTarget)
|
|
|
- {
|
|
|
+ public static String getMethodName(String invokeTarget) {
|
|
|
String methodName = StringUtils.substringBefore(invokeTarget, "(");
|
|
|
return StringUtils.substringAfterLast(methodName, ".");
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 获取method方法参数相关列表
|
|
|
- *
|
|
|
+ *
|
|
|
* @param invokeTarget 目标字符串
|
|
|
* @return method方法相关参数列表
|
|
|
*/
|
|
|
- public static List<Object[]> getMethodParams(String invokeTarget)
|
|
|
- {
|
|
|
+ public static List<Object[]> getMethodParams(String invokeTarget) {
|
|
|
String methodStr = StringUtils.substringBetween(invokeTarget, "(", ")");
|
|
|
- if (StringUtils.isEmpty(methodStr))
|
|
|
- {
|
|
|
+ if (StringUtils.isEmpty(methodStr)) {
|
|
|
return null;
|
|
|
}
|
|
|
String[] methodParams = methodStr.split(",");
|
|
|
List<Object[]> classs = new LinkedList<>();
|
|
|
- for (int i = 0; i < methodParams.length; i++)
|
|
|
- {
|
|
|
+ for (int i = 0; i < methodParams.length; i++) {
|
|
|
String str = StringUtils.trimToEmpty(methodParams[i]);
|
|
|
// String字符串类型,包含'
|
|
|
- if (StringUtils.contains(str, "'"))
|
|
|
- {
|
|
|
- classs.add(new Object[] { StringUtils.replace(str, "'", ""), String.class });
|
|
|
+ if (StringUtils.contains(str, "'")) {
|
|
|
+ classs.add(new Object[]{StringUtils.replace(str, "'", ""), String.class});
|
|
|
}
|
|
|
// boolean布尔类型,等于true或者false
|
|
|
- else if (StringUtils.equals(str, "true") || StringUtils.equalsIgnoreCase(str, "false"))
|
|
|
- {
|
|
|
- classs.add(new Object[] { Boolean.valueOf(str), Boolean.class });
|
|
|
+ else if (StringUtils.equals(str, "true") || StringUtils.equalsIgnoreCase(str, "false")) {
|
|
|
+ classs.add(new Object[]{Boolean.valueOf(str), Boolean.class});
|
|
|
}
|
|
|
// long长整形,包含L
|
|
|
- else if (StringUtils.containsIgnoreCase(str, "L"))
|
|
|
- {
|
|
|
- classs.add(new Object[] { Long.valueOf(StringUtils.replaceIgnoreCase(str, "L", "")), Long.class });
|
|
|
+ else if (StringUtils.containsIgnoreCase(str, "L")) {
|
|
|
+ classs.add(new Object[]{Long.valueOf(StringUtils.replaceIgnoreCase(str, "L", "")), Long.class});
|
|
|
}
|
|
|
// double浮点类型,包含D
|
|
|
- else if (StringUtils.containsIgnoreCase(str, "D"))
|
|
|
- {
|
|
|
- classs.add(new Object[] { Double.valueOf(StringUtils.replaceIgnoreCase(str, "D", "")), Double.class });
|
|
|
+ else if (StringUtils.containsIgnoreCase(str, "D")) {
|
|
|
+ classs.add(new Object[]{Double.valueOf(StringUtils.replaceIgnoreCase(str, "D", "")), Double.class});
|
|
|
}
|
|
|
// 其他类型归类为整形
|
|
|
- else
|
|
|
- {
|
|
|
- classs.add(new Object[] { Integer.valueOf(str), Integer.class });
|
|
|
+ else {
|
|
|
+ classs.add(new Object[]{Integer.valueOf(str), Integer.class});
|
|
|
}
|
|
|
}
|
|
|
return classs;
|
|
@@ -146,16 +127,14 @@ public class JobInvokeUtil
|
|
|
|
|
|
/**
|
|
|
* 获取参数类型
|
|
|
- *
|
|
|
+ *
|
|
|
* @param methodParams 参数相关列表
|
|
|
* @return 参数类型列表
|
|
|
*/
|
|
|
- public static Class<?>[] getMethodParamsType(List<Object[]> methodParams)
|
|
|
- {
|
|
|
+ public static Class<?>[] getMethodParamsType(List<Object[]> methodParams) {
|
|
|
Class<?>[] classs = new Class<?>[methodParams.size()];
|
|
|
int index = 0;
|
|
|
- for (Object[] os : methodParams)
|
|
|
- {
|
|
|
+ for (Object[] os : methodParams) {
|
|
|
classs[index] = (Class<?>) os[1];
|
|
|
index++;
|
|
|
}
|
|
@@ -164,16 +143,14 @@ public class JobInvokeUtil
|
|
|
|
|
|
/**
|
|
|
* 获取参数值
|
|
|
- *
|
|
|
+ *
|
|
|
* @param methodParams 参数相关列表
|
|
|
* @return 参数值列表
|
|
|
*/
|
|
|
- public static Object[] getMethodParamsValue(List<Object[]> methodParams)
|
|
|
- {
|
|
|
+ public static Object[] getMethodParamsValue(List<Object[]> methodParams) {
|
|
|
Object[] classs = new Object[methodParams.size()];
|
|
|
int index = 0;
|
|
|
- for (Object[] os : methodParams)
|
|
|
- {
|
|
|
+ for (Object[] os : methodParams) {
|
|
|
classs[index] = (Object) os[0];
|
|
|
index++;
|
|
|
}
|