| 
					
				 | 
			
			
				@@ -25,6 +25,7 @@ import com.ruoyi.common.utils.poi.ExcelUtil; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 import com.ruoyi.quartz.domain.SysJob;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 import com.ruoyi.quartz.service.ISysJobService;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 import com.ruoyi.quartz.util.CronUtils;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+import com.ruoyi.quartz.util.ScheduleUtils;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 /**
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  * 调度任务信息操作处理
 
			 | 
		
	
	
		
			
				| 
					
				 | 
			
			
				@@ -89,18 +90,22 @@ public class SysJobController extends BaseController 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				             return error("新增任务'" + job.getJobName() + "'失败,目标字符串不允许'rmi'调用");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-        else if (StringUtils.containsIgnoreCase(job.getInvokeTarget(), Constants.LOOKUP_LDAP))
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.LOOKUP_LDAP, Constants.LOOKUP_LDAPS }))
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				             return error("新增任务'" + job.getJobName() + "'失败,目标字符串不允许'ldap'调用");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.HTTP, Constants.HTTPS }))
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            return error("新增任务'" + job.getJobName() + "'失败,目标字符串不允许'http(s)//'调用");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            return error("新增任务'" + job.getJobName() + "'失败,目标字符串不允许'http(s)'调用");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), Constants.JOB_ERROR_STR))
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				             return error("新增任务'" + job.getJobName() + "'失败,目标字符串存在违规");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        else if (!ScheduleUtils.whiteList(job.getInvokeTarget()))
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            return error("新增任务'" + job.getJobName() + "'失败,目标字符串不在白名单内");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         job.setCreateBy(getUsername());
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         return toAjax(jobService.insertJob(job));
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				     }
 
			 | 
		
	
	
		
			
				| 
					
				 | 
			
			
				@@ -121,18 +126,22 @@ public class SysJobController extends BaseController 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				             return error("修改任务'" + job.getJobName() + "'失败,目标字符串不允许'rmi'调用");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-        else if (StringUtils.containsIgnoreCase(job.getInvokeTarget(), Constants.LOOKUP_LDAP))
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.LOOKUP_LDAP, Constants.LOOKUP_LDAPS }))
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				             return error("修改任务'" + job.getJobName() + "'失败,目标字符串不允许'ldap'调用");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), new String[] { Constants.HTTP, Constants.HTTPS }))
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            return error("修改任务'" + job.getJobName() + "'失败,目标字符串不允许'http(s)//'调用");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            return error("修改任务'" + job.getJobName() + "'失败,目标字符串不允许'http(s)'调用");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         else if (StringUtils.containsAnyIgnoreCase(job.getInvokeTarget(), Constants.JOB_ERROR_STR))
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				             return error("修改任务'" + job.getJobName() + "'失败,目标字符串存在违规");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        else if (!ScheduleUtils.whiteList(job.getInvokeTarget()))
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            return error("新增任务'" + job.getJobName() + "'失败,目标字符串不在白名单内");
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         job.setUpdateBy(getUsername());
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         return toAjax(jobService.updateJob(job));
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				     }
 
			 |