Commit 8fbf4e8e by wqc

新增组件

parent 19ea9fac
......@@ -119,7 +119,12 @@ public class CommonQueryController {
AssertUtils.notNull(id, "缺失ID");
Object tableName = body.get("tableName");
AssertUtils.notNull(tableName, "缺失表名");
return ResultVo.success(TableUtil.getColumns(Convert.toLong(id), Convert.toStr(tableName)));
}
@ApiOperation("查询表内容")
@PostMapping("/selectTable")
public ResultVo selectTable(@RequestBody Map<String, Object> body) throws Exception {
return ResultVo.success(commonQueryService.selectTable(body));
}
}
......@@ -169,4 +169,12 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo
}
return results;
}
public Object selectTable(Map<String, Object> body) throws Exception {
JSONObject jsonObject = JSONUtil.parseObj(body);
Long id = Long.valueOf(jsonObject.get("id").toString());
String tableName = jsonObject.get("tableName").toString();
String sql="SELECT * FROM "+tableName;
return commonQuery(sql,id);
}
}
......@@ -23,7 +23,7 @@ public class IdentityExecutor implements ShapeExecutor {
public Shape shape() {
Shape shape = new Shape();
//web界面上显示的图标
shape.setImage("");
shape.setImage("");
//拖放至容器里时默认的节点名称
shape.setLabel("身份证清洗");
//模板文件名
......@@ -51,8 +51,12 @@ public class IdentityExecutor implements ShapeExecutor {
}else if(IdentityUtils.is18BitLegalIdCard(metaData)!=true){
logger.warn("身份证不满18位!");
}else {
try{
// ExceptionUtils.wrapAndThrow(e);
}catch (Exception e){
logger.error("获取出错,异常信息:{}", e.getMessage(), e);
ExceptionUtils.wrapAndThrow(e);
}
}
}
}
package com.zq.spiderflow.core.executor.shape;
import com.zq.spiderflow.context.SpiderContext;
import com.zq.spiderflow.executor.ShapeExecutor;
import com.zq.spiderflow.model.Shape;
import com.zq.spiderflow.model.SpiderNode;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import java.util.Map;
/**
* @author Administrator
*/
@Component
public class MappingValueExecutor implements ShapeExecutor {
public static final String DATASOURCE_ID = "datasourceId";
public static final String META_DATA = "metaData";
public static final String TABLE_NAME = "tableName";
private static final Logger logger = LoggerFactory.getLogger(ExecuteSQLExecutor.class);
@Override
public Shape shape() {
Shape shape = new Shape();
//web界面上显示的图标
shape.setImage("");
//拖放至容器里时默认的节点名称
shape.setLabel("映射值");
//模板文件名
shape.setName("MappingValue");
//鼠标移动至图标上显示的名称
shape.setTitle("映射值");
return shape;
}
@Override
public String supportShape() {
return "MappingValue";
}
@Override
public void execute(SpiderNode node, SpiderContext context, Map<String, Object> variables) {
}
@Override
public boolean allowExecuteNext(SpiderNode node, SpiderContext context, Map<String, Object> variables) {
return false;
}
@Override
public boolean isThread() {
return false;
}
}
package com.zq.spiderflow.core.executor.shape;
import com.zq.spiderflow.context.SpiderContext;
import com.zq.spiderflow.core.utils.ConnectionUtil;
import com.zq.spiderflow.executor.ShapeExecutor;
import com.zq.spiderflow.model.Shape;
import com.zq.spiderflow.model.SpiderNode;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.exception.ExceptionUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Component;
import javax.sql.DataSource;
import java.sql.Connection;
import java.util.Map;
/**
* @author Administrator
*/
@Component
public class ReplaceStringExecutor implements ShapeExecutor {
public static final String DATASOURCE_ID = "datasourceId";
public static final String META_DATA = "metaData";
public static final String TABLE_NAME = "tableName";
private static final Logger logger = LoggerFactory.getLogger(ExecuteSQLExecutor.class);
@Override
public Shape shape() {
Shape shape = new Shape();
//web界面上显示的图标
shape.setImage("");
//拖放至容器里时默认的节点名称
shape.setLabel("字符串替换");
//模板文件名
shape.setName("ReplaceString");
//鼠标移动至图标上显示的名称
shape.setTitle("字符串替换");
return shape;
}
@Override
public String supportShape() {
return "ReplaceString";
}
@Override
public void execute(SpiderNode node, SpiderContext context, Map<String, Object> variables) {
}
@Override
public boolean allowExecuteNext(SpiderNode node, SpiderContext context, Map<String, Object> variables) {
return false;
}
@Override
public boolean isThread() {
return false;
}
}
package com.zq.spiderflow.core.executor.shape;
import com.zq.spiderflow.context.SpiderContext;
import com.zq.spiderflow.executor.ShapeExecutor;
import com.zq.spiderflow.model.Shape;
import com.zq.spiderflow.model.SpiderNode;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import java.util.Map;
/**
* @author Administrator
*/
@Component
public class SortRecordExecutor implements ShapeExecutor {
public static final String DATASOURCE_ID = "datasourceId";
public static final String META_DATA = "metaData";
public static final String TABLE_NAME = "tableName";
private static final Logger logger = LoggerFactory.getLogger(ExecuteSQLExecutor.class);
@Override
public Shape shape() {
Shape shape = new Shape();
//web界面上显示的图标
shape.setImage("");
//拖放至容器里时默认的节点名称
shape.setLabel("SortRecord");
//模板文件名
shape.setName("SortRecord");
//鼠标移动至图标上显示的名称
shape.setTitle("排序记录");
return shape;
}
@Override
public String supportShape() {
return "SortRecord";
}
@Override
public void execute(SpiderNode node, SpiderContext context, Map<String, Object> variables) {
}
@Override
public boolean allowExecuteNext(SpiderNode node, SpiderContext context, Map<String, Object> variables) {
return false;
}
@Override
public boolean isThread() {
return false;
}
}
package com.zq.spiderflow.core.service;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.zq.common.utils.PagingUtils;
import com.zq.common.vo.PageVo;
import com.zq.common.vo.ResultVo;
import com.zq.spiderflow.core.mapper.FlowNoticeMapper;
......@@ -116,18 +118,17 @@ public class SpiderFlowService extends ServiceImpl<SpiderFlowMapper, SpiderFlow>
.build();
spiderFlow.setNextExecuteTime(trigger.getStartTime());
}
SpiderFlow byId = sfMapper.selectById(spiderFlow.getId());
String id = UUID.randomUUID().toString().replace("-", "");
SpiderFlow build = SpiderFlow.builder().id(id).cron(spiderFlow.getCron()).xml(spiderFlow.getXml()).name(spiderFlow.getName()).createDate(DateUtil.now()).build();
if(byId!=null){
sfMapper.updateById(build);
if(StringUtils.isNotEmpty(spiderFlow.getId())){ //update 任务
sfMapper.updateSpiderFlow(spiderFlow.getId(), spiderFlow.getName(), spiderFlow.getXml());
spiderJobManager.remove(spiderFlow.getId());
spiderFlow = getById(spiderFlow.getId());
if("1".equals(spiderFlow.getEnabled()) && StringUtils.isNotEmpty(spiderFlow.getCron())){
spiderJobManager.addJob(spiderFlow);
}
}else{
sfMapper.insert(build);
}else{//insert 任务
String id = UUID.randomUUID().toString().replace("-", "");
sfMapper.insertSpiderFlow(id, spiderFlow.getName(), spiderFlow.getXml());
spiderFlow.setId(id);
}
File file = new File(workspace,spiderFlow.getId() + File.separator + "xmls" + File.separator + System.currentTimeMillis() + ".xml");
try {
......@@ -138,6 +139,28 @@ public class SpiderFlowService extends ServiceImpl<SpiderFlowMapper, SpiderFlow>
return ResultVo.success();
}
// SpiderFlow byId = sfMapper.selectById(spiderFlow.getId());
// String id = UUID.randomUUID().toString().replace("-", "");
// SpiderFlow build = SpiderFlow.builder().id(id).cron(spiderFlow.getCron()).xml(spiderFlow.getXml()).name(spiderFlow.getName()).createDate(DateUtil.now()).build();
// if(byId!=null){
// sfMapper.updateById(build);
// spiderJobManager.remove(spiderFlow.getId());
// spiderFlow = getById(spiderFlow.getId());
// if("1".equals(spiderFlow.getEnabled()) && StringUtils.isNotEmpty(spiderFlow.getCron())){
// spiderJobManager.addJob(spiderFlow);
// }
// }else{
// sfMapper.insert(build);
// }
// File file = new File(workspace,spiderFlow.getId() + File.separator + "xmls" + File.separator + System.currentTimeMillis() + ".xml");
// try {
// FileUtils.write(file,spiderFlow.getXml(),"UTF-8");
// } catch (IOException e) {
// logger.error("保存历史记录出错",e);
// }
// return ResultVo.success();
// }
public void stop(String id){
sfMapper.resetSpiderStatus(id,"0");
sfMapper.resetNextExecuteTime(id);
......@@ -232,21 +255,8 @@ public class SpiderFlowService extends ServiceImpl<SpiderFlowMapper, SpiderFlow>
return sfMapper.getFlowMaxTaskId(flowId);
}
public PageVo<SpiderFlowVo> getPageList(SpiderFlowVo vo) {
List<SpiderFlowVo> pageList = sfMapper.getPageList(vo);
int start=0;
PageVo<SpiderFlowVo> pageVo = new PageVo<>();
if (vo.getPage() - 1 == 0) {
pageVo.setStart(0);
start = 0;
} else {
pageVo.setStart((vo.getPage() - 1) * vo.getSize());
start = (vo.getPage() - 1) * vo.getSize();
}
pageVo.setPage(vo.getPage());
pageVo.setSize(vo.getSize());
pageVo.setRows(pageList);
pageVo.setTotal(pageList.size());
return pageVo;
public PageVo<SpiderFlow> getPageList(SpiderFlowVo vo) {
LambdaQueryWrapper<SpiderFlow> queryWrapper = new LambdaQueryWrapper<>();
return PagingUtils.paging(vo,sfMapper,queryWrapper,SpiderFlow.class);
}
}
......@@ -99,7 +99,7 @@ public class SpiderFlowController {
* @return Page<SpiderFlow> 所有爬虫的列表页
*/
@PostMapping("/list")
public PageVo<SpiderFlowVo> list(@RequestBody SpiderFlowVo vo) {
public PageVo<SpiderFlow> list(@RequestBody SpiderFlowVo vo) {
return spiderFlowService.getPageList(vo);
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment