Commit 4190cf2d by ljb

commit all

parent 24f51ccd
...@@ -13,6 +13,9 @@ spiderflow.name: SPIDER-FLOW ...@@ -13,6 +13,9 @@ spiderflow.name: SPIDER-FLOW
model.port: 9877 model.port: 9877
model.name: MODEL-SERVER model.name: MODEL-SERVER
data.port: 9688
data.name: DATAOPERATION-SERVER
datacollect.port: 9697 datacollect.port: 9697
datacollect.name: DATA-COLLECT-SERVER datacollect.name: DATA-COLLECT-SERVER
......
...@@ -93,9 +93,9 @@ ...@@ -93,9 +93,9 @@
<plugin> <plugin>
<groupId>org.springframework.boot</groupId> <groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId> <artifactId>spring-boot-maven-plugin</artifactId>
<configuration> <!-- <configuration>-->
<skip>true</skip> <!-- <skip>true</skip>-->
</configuration> <!-- </configuration>-->
</plugin> </plugin>
</plugins> </plugins>
......
...@@ -6,9 +6,9 @@ import org.springframework.boot.autoconfigure.SpringBootApplication; ...@@ -6,9 +6,9 @@ import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication @SpringBootApplication
@MapperScan({"com.zq.datacollect.mapper"}) @MapperScan({"com.zq.datacollect.mapper"})
public class DataCollectAppliction { public class DataCollectApplication {
public static void main(String[] args) { public static void main(String[] args) {
SpringApplication.run(DataCollectAppliction.class, args); SpringApplication.run(DataCollectApplication.class, args);
} }
} }
\ No newline at end of file
package com.zq.datacollect.holder; package com.zq.datacollect.holder;
import com.alibaba.druid.pool.DruidDataSource;
import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.JdbcTemplate;
import java.sql.Connection; import java.sql.Connection;
...@@ -24,7 +25,7 @@ public class DatabaseHolder { ...@@ -24,7 +25,7 @@ public class DatabaseHolder {
public static Connection getConnection(Integer id){ public static Connection getConnection(Integer id){
try { try {
return jdbcTemplateMap.get(id).getDataSource().getConnection(); return ((DruidDataSource) jdbcTemplateMap.get(id).getDataSource()).getConnection().getConnection();
} catch (SQLException e) { } catch (SQLException e) {
throw new RuntimeException(e); throw new RuntimeException(e);
} }
......
...@@ -76,11 +76,11 @@ ...@@ -76,11 +76,11 @@
<artifactId>poi</artifactId> <artifactId>poi</artifactId>
<version>4.1.1</version> <version>4.1.1</version>
</dependency> </dependency>
<!-- <dependency>--> <!-- <dependency>-->
<!-- <groupId>com.oracle</groupId>--> <!-- <groupId>com.oracle</groupId>-->
<!-- <artifactId>ojdbc6</artifactId>--> <!-- <artifactId>ojdbc6</artifactId>-->
<!-- <version>11.2.0.3</version>--> <!-- <version>11.2.0.3</version>-->
<!-- </dependency>--> <!-- </dependency>-->
<!-- https://mvnrepository.com/artifact/com.oracle.database.nls/orai18n --> <!-- https://mvnrepository.com/artifact/com.oracle.database.nls/orai18n -->
<!-- swagger start--> <!-- swagger start-->
<dependency> <dependency>
......
...@@ -60,9 +60,8 @@ public class CommonQueryController { ...@@ -60,9 +60,8 @@ public class CommonQueryController {
AssertUtils.notNull(queryDb.getDbType(), "缺少数据库类型"); AssertUtils.notNull(queryDb.getDbType(), "缺少数据库类型");
AssertUtils.hasText(queryDb.getUsername(), "缺少连接用户名"); AssertUtils.hasText(queryDb.getUsername(), "缺少连接用户名");
AssertUtils.hasText(queryDb.getPassword(), "缺少连接密码"); AssertUtils.hasText(queryDb.getPassword(), "缺少连接密码");
queryDb.setUpdateTime(DateUtil.date()); commonQueryService.updateDatasource(queryDb);
boolean b = queryDbService.updateById(queryDb); return ResultVo.success("操作成功!");
return b ? ResultVo.success("操作成功!") : ResultVo.fail("操作失败");
} }
/** /**
...@@ -73,10 +72,10 @@ public class CommonQueryController { ...@@ -73,10 +72,10 @@ public class CommonQueryController {
*/ */
@ApiOperation("根据ID删除数据源") @ApiOperation("根据ID删除数据源")
@DeleteMapping("/deleteDatasource/{id}") @DeleteMapping("/deleteDatasource/{id}")
public ResultVo deleteDatasource(@PathVariable Long id) { public ResultVo deleteDatasource(@PathVariable Integer id) {
AssertUtils.notNull(id, "删除至少需要一个ID!"); AssertUtils.notNull(id, "删除至少需要一个ID!");
boolean b = queryDbService.removeById(id); commonQueryService.deleteDatasource(id);
return b ? ResultVo.success("操作成功!") : ResultVo.fail("操作失败!"); return ResultVo.success("操作成功!");
} }
......
package com.zq.dataoperation.holder; package com.zq.dataoperation.holder;
import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;
import com.zq.common.exception.BusinessException;
import com.zq.common.utils.AssertUtils;
import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.JdbcTemplate;
import java.sql.Connection; import java.sql.Connection;
...@@ -9,14 +13,33 @@ import java.util.Map; ...@@ -9,14 +13,33 @@ import java.util.Map;
public class DatabaseHolder { public class DatabaseHolder {
private static Map<Integer, JdbcTemplate> jdbcTemplateMap; private static Map<Integer, JdbcTemplate> jdbcTemplateMap = new HashMap<>();
public static void set(Map<Integer, JdbcTemplate> map) { public static void add(Integer dbType, String dbIp, Integer dbPort, String dbName, String username, String password, Integer id) {
jdbcTemplateMap = map; DruidDataSource druidDataSource = new DruidDataSource();
String url = "";
String className = "";
switch (dbType) {
case 1:
className = "com.mysql.cj.jdbc.Driver";
url = "jdbc:mysql://" + dbIp + ":" + dbPort + "/" + dbName + "?characterEncoding=utf8&useSSL=false&serverTimezone=GMT%2B8&autoReconnect=true";
break;
case 2:
className = "oracle.jdbc.driver.OracleDriver";
url = "jdbc:oracle:thin:@//" + dbIp + ":" + dbPort + "/" + dbName;
break;
case 3:
className = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
url = "jdbc:sqlserver://" + dbIp + ":" + dbPort + "/" + dbName;
break;
default:
throw new BusinessException("不支持的数据库");
} }
druidDataSource.setDriverClassName(className);
public static void add(Integer id, JdbcTemplate jdbcTemplate){ druidDataSource.setUrl(url);
jdbcTemplateMap.put(id, jdbcTemplate); druidDataSource.setUsername(username);
druidDataSource.setPassword(password);
jdbcTemplateMap.put(id, new JdbcTemplate(druidDataSource));
} }
public static JdbcTemplate getJdbcTemplate(Integer id){ public static JdbcTemplate getJdbcTemplate(Integer id){
...@@ -27,7 +50,13 @@ public class DatabaseHolder { ...@@ -27,7 +50,13 @@ public class DatabaseHolder {
try { try {
return jdbcTemplateMap.get(id).getDataSource().getConnection(); return jdbcTemplateMap.get(id).getDataSource().getConnection();
} catch (SQLException e) { } catch (SQLException e) {
throw new RuntimeException(e); e.printStackTrace();
throw new BusinessException("获取数据库连接失败");
} }
} }
public static void remove(Integer id){
((DruidDataSource)jdbcTemplateMap.get(id).getDataSource()).close();
jdbcTemplateMap.remove(id);
}
} }
\ No newline at end of file
package com.zq.dataoperation.runner; package com.zq.dataoperation.runner;
import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;
import com.zq.common.exception.BusinessException;
import com.zq.dataoperation.entity.QueryDb; import com.zq.dataoperation.entity.QueryDb;
import com.zq.dataoperation.holder.DatabaseHolder; import com.zq.dataoperation.holder.DatabaseHolder;
import com.zq.dataoperation.service.CommonQueryService; import com.zq.dataoperation.service.CommonQueryService;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.ApplicationArguments; import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner; import org.springframework.boot.ApplicationRunner;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import javax.annotation.Resource;; import javax.annotation.Resource;;
import java.sql.SQLException; import java.sql.SQLException;
import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map;
@Slf4j @Slf4j
@Component @Component
...@@ -25,39 +19,12 @@ public class DatabaseRunner implements ApplicationRunner { ...@@ -25,39 +19,12 @@ public class DatabaseRunner implements ApplicationRunner {
@Resource @Resource
private CommonQueryService service; private CommonQueryService service;
private Map<Integer, JdbcTemplate> jdbcTemplateMap = new HashMap<>();
@Override @Override
public void run(ApplicationArguments args) throws SQLException { public void run(ApplicationArguments args) {
List<QueryDb> datasource = service.getDatasource(); List<QueryDb> datasource = service.getDatasource();
for (QueryDb ds : datasource) { for (QueryDb ds : datasource) {
DruidDataSource druidDataSource = DruidDataSourceBuilder.create().build(); DatabaseHolder.add(ds.getDbType(), ds.getDbIp(), ds.getDbPort(), ds.getDbName(), ds.getUsername(), ds.getPassword(), ds.getId());
String url = "";
String className = "";
switch (ds.getDbType()) {
case 1:
className = "com.mysql.cj.jdbc.Driver";
url = "jdbc:mysql://" + ds.getDbIp() + ":" + ds.getDbPort() + "/" + ds.getDbName() + "?characterEncoding=utf8&useSSL=false&serverTimezone=GMT%2B8&autoReconnect=true";
break;
case 2:
className = "oracle.jdbc.driver.OracleDriver";
url = "jdbc:oracle:thin:@//" + ds.getDbIp() + ":" + ds.getDbPort() + "/" + ds.getDbName();
break;
case 3:
className = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
url = "jdbc:sqlserver://" + ds.getDbIp() + ":" + ds.getDbPort() + "/" + ds.getDbName();
break;
default:
throw new BusinessException("不支持的数据库");
}
druidDataSource.setDriverClassName(className);
druidDataSource.setUrl(url);
druidDataSource.setUsername(ds.getUsername());
druidDataSource.setPassword(ds.getPassword());
druidDataSource.init();
jdbcTemplateMap.put(ds.getId(), new JdbcTemplate(druidDataSource));
} }
DatabaseHolder.set(jdbcTemplateMap); log.info("成功加载数据库:{}个", datasource.size());
log.info("成功加载数据库:{}个", jdbcTemplateMap.size());
} }
} }
\ No newline at end of file
package com.zq.dataoperation.service; package com.zq.dataoperation.service;
import cn.hutool.core.date.DateUtil;
import cn.hutool.json.JSONObject; import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil; import cn.hutool.json.JSONUtil;
import com.alibaba.druid.pool.DruidPooledConnection; import com.alibaba.druid.pool.DruidPooledConnection;
...@@ -7,6 +8,7 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; ...@@ -7,6 +8,7 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.zq.common.context.ThreadContext; import com.zq.common.context.ThreadContext;
import com.zq.common.exception.BusinessException; import com.zq.common.exception.BusinessException;
import com.zq.common.utils.AssertUtils;
import com.zq.common.vo.PageVo; import com.zq.common.vo.PageVo;
import com.zq.common.vo.ResultVo; import com.zq.common.vo.ResultVo;
import com.zq.dataoperation.dao.CommonQuerySettingDao; import com.zq.dataoperation.dao.CommonQuerySettingDao;
...@@ -50,9 +52,8 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo ...@@ -50,9 +52,8 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo
} }
public ResultVo addDatasource(QueryDb queryDb) { public ResultVo addDatasource(QueryDb queryDb) {
if (queryDbDao.insert(queryDb) != 1) { AssertUtils.isTrue(queryDbDao.insert(queryDb) == 1, "添加失败,请检查后重试");
throw new BusinessException("添加失败"); DatabaseHolder.add(queryDb.getDbType(), queryDb.getDbIp(), queryDb.getDbPort(), queryDb.getDbName(), queryDb.getUsername(), queryDb.getPassword(), queryDb.getId());
}
return ResultVo.success(); return ResultVo.success();
} }
...@@ -61,9 +62,21 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo ...@@ -61,9 +62,21 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo
} }
public void add(CommonQuerySetting commonQuerySetting) { public void add(CommonQuerySetting commonQuerySetting) {
if (!save(commonQuerySetting)) { AssertUtils.isTrue(save(commonQuerySetting), "添加失败");
throw new BusinessException("添加失败"); }
@Transactional
public void updateDatasource(QueryDb queryDb){
queryDb.setUpdateTime(DateUtil.date());
AssertUtils.isTrue(queryDbService.updateById(queryDb), "操作失败!");
DatabaseHolder.remove(queryDb.getId());
DatabaseHolder.add(queryDb.getDbType(), queryDb.getDbIp(), queryDb.getDbPort(), queryDb.getDbName(), queryDb.getUsername(), queryDb.getPassword(), queryDb.getId());
} }
@Transactional
public void deleteDatasource(Integer id){
AssertUtils.isTrue(queryDbService.removeById(id), "操作失败!");
DatabaseHolder.remove(id);
} }
public List<Map<String, Object>> run(Map<String, Object> body) { public List<Map<String, Object>> run(Map<String, Object> body) {
...@@ -345,7 +358,8 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo ...@@ -345,7 +358,8 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo
// } // }
return list; return list;
} }
@Resource
private QueryDbService queryDbService;
@Transactional @Transactional
public Object sqlOutput(Map<String, Object> body) throws Exception { public Object sqlOutput(Map<String, Object> body) throws Exception {
......
...@@ -20,7 +20,6 @@ import org.apache.commons.lang3.StringUtils; ...@@ -20,7 +20,6 @@ import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import javax.annotation.Resource; import javax.annotation.Resource;
import java.math.BigDecimal;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
......
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>nnjcy-data-model</artifactId>
<groupId>com.zq</groupId>
<version>1.0.0</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>flow-component</artifactId>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>com.zq</groupId>
<artifactId>spider-flow-api</artifactId>
</dependency>
<dependency>
<groupId>com.zq</groupId>
<artifactId>common-client</artifactId>
<version>1.0.0</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<skip>true</skip>
</configuration>
</plugin>
</plugins>
</build>
</project>
\ No newline at end of file
package com.zq.spiderflow.datacollision.executor;
import cn.hutool.core.map.MapUtil;
import cn.hutool.core.util.StrUtil;
import com.zq.common.exception.BusinessException;
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 com.zq.spiderflow.model.SpiderOutput;
import org.springframework.stereotype.Component;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
@Component
public class DataCollisionExecutor implements ShapeExecutor {
public static final String TABLE1 = "table1";
public static final String FIELD1 = "field1";
public static final String TABLE2 = "table2";
public static final String FIELD2 = "field2";
public static final String RESERVE = "reserve";
@Override
public Shape shape() {
Shape shape = new Shape();
shape.setImage("");
shape.setLabel("数据碰撞");
shape.setName("DataCollision");
shape.setTitle("数据碰撞");
return shape;
}
@Override
public String supportShape() {
return "DataCollision";
}
@Override
public void execute(SpiderNode node, SpiderContext context, Map<String, Object> variables) throws Exception {
String table1 = null;
String table2 = null;
String field1 = null;
String field2 = null;
try {
table1 = node.getStringJsonValue(TABLE1);
table2 = node.getStringJsonValue(TABLE2);
field1 = node.getStringJsonValue(FIELD1);
field2 = node.getStringJsonValue(FIELD2);
}catch (Exception e){
throw new BusinessException("不是字符串");
}
if(StrUtil.isBlank(table1)){
throw new BusinessException("没有表1");
}
if(StrUtil.isBlank(table2)){
throw new BusinessException("没有表2");
}
if(StrUtil.isBlank(field1)){
throw new BusinessException("没有字段1");
}
if(StrUtil.isBlank(field2)){
throw new BusinessException("没有字段2");
}
List<Map<String, Object>> list1 = (List<Map<String, Object>>) variables.get(table1);
List<Map<String, Object>> list2 = (List<Map<String, Object>>) variables.get(table2);
if(list1==null){
throw new BusinessException("表1没有数据");
}
if(list2==null){
throw new BusinessException("表2没有数据");
}
List<Map<String, Object>> results = new ArrayList<>();
for (Map<String, Object> map1 : list1) {
String field1Str = map1.get(field1).toString();
for (Map<String, Object> map2 : list2) {
String field2Str = map2.get(field2).toString();
if(field1Str.equals(field2Str)){
map1.putAll(map2);
results.add(map1);
break;
}
}
}
variables.put(node.getNodeId() + "_" + node.getNodeName(), results);
SpiderOutput output = new SpiderOutput();
output.setNodeName(node.getNodeName());
output.setNodeId(node.getNodeId());
output.addOutput("result", results);
context.writeResult(output);
}
}
\ No newline at end of file
package com.zq.spiderflow.excelremoveduplicate.executor;
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.springframework.stereotype.Component;
import java.util.Map;
@Component
public class ExcelRemoveDuplicateExecutor implements ShapeExecutor {
public static final String TABLE1 = "table1";
public static final String FIELD1 = "field1";
public static final String TABLE2 = "table2";
public static final String FIELD2 = "field2";
public static final String RESERVE = "reserve";
@Override
public Shape shape() {
Shape shape = new Shape();
shape.setImage("");
shape.setLabel("表格去重");
shape.setName("ExcelRemoveDuplicate");
shape.setTitle("表格去重");
return shape;
}
@Override
public String supportShape() {
return "ExcelRemoveDuplicate";
}
@Override
public void execute(SpiderNode node, SpiderContext context, Map<String, Object> variables) throws Exception {
variables.put("test", "test");
}
}
\ No newline at end of file
package com.zq.spiderflow.flowcall.executor;
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.springframework.stereotype.Component;
import java.util.Map;
@Component
public class FlowCallExecutor implements ShapeExecutor {
public static final String FLOW_ID = "flowId";
@Override
public Shape shape() {
Shape shape = new Shape();
shape.setImage("");
shape.setLabel("流程调用");
shape.setName("FlowCall");
shape.setTitle("流程调用");
return shape;
}
@Override
public String supportShape() {
return "FlowCall";
}
@Override
public void execute(SpiderNode node, SpiderContext context, Map<String, Object> variables) throws Exception {
String flowId = node.getStringJsonValue(FLOW_ID);
}
}
\ No newline at end of file
package com.zq.spiderflow.readfile.executor;
import cn.hutool.core.io.FileUtil;
import com.alibaba.excel.EasyExcel;
import com.zq.common.utils.AssertUtils;
import com.zq.common.utils.EasyExcelUtil;
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.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import java.io.File;
import java.util.Map;
@Component
public class ReadFileExecutor implements ShapeExecutor {
@Value("${spider.workspace}")
private String workspace;
public static final String FILE_NAME = "fileName";
@Override
public Shape shape() {
Shape shape = new Shape();
shape.setImage("");
shape.setLabel("Excel文件");
shape.setName("Excel");
shape.setTitle("Excel文件");
return shape;
}
@Override
public String supportShape() {
return "Excel";
}
@Override
public void execute(SpiderNode node, SpiderContext context, Map<String, Object> variables) throws Exception {
String fileName = node.getStringJsonValue(FILE_NAME);
String suffix = FileUtil.extName(fileName);
AssertUtils.isTrue(suffix.equals("xls") || suffix.equals("xlsx") || suffix.equals("et"), "不支持的文件类型");
variables.put(node.getNodeId() + "_" + node.getNodeName(), EasyExcelUtil.readAll(new File(workspace, context.getFlowId() + File.separator + "file" + File.separator + fileName)));
}
}
\ No newline at end of file
...@@ -81,6 +81,12 @@ ...@@ -81,6 +81,12 @@
<artifactId>spider-flow-selenium</artifactId> <artifactId>spider-flow-selenium</artifactId>
<version>1.0.0</version> <version>1.0.0</version>
</dependency> </dependency>
<dependency>
<groupId>com.zq</groupId>
<artifactId>flow-component</artifactId>
<version>1.0.0</version>
</dependency>
</dependencies> </dependencies>
</dependencyManagement> </dependencyManagement>
...@@ -107,8 +113,9 @@ ...@@ -107,8 +113,9 @@
<module>spider-flow-core</module> <module>spider-flow-core</module>
<module>spider-flow-web</module> <module>spider-flow-web</module>
<module>spider-flow-selenium</module> <module>spider-flow-selenium</module>
<module>dataoperation-server</module>
<module>data-collect-server</module> <module>data-collect-server</module>
<module>dataoperation-server</module>
<module>flow-component</module>
</modules> </modules>
<profiles> <profiles>
......
...@@ -86,6 +86,10 @@ public class SpiderContext extends HashMap<String, Object>{ ...@@ -86,6 +86,10 @@ public class SpiderContext extends HashMap<String, Object>{
} }
public void writeResult(SpiderOutput output){
}
public SubThreadPoolExecutor getThreadPool() { public SubThreadPoolExecutor getThreadPool() {
return threadPool; return threadPool;
} }
......
package com.zq.spiderflow.executor; package com.zq.spiderflow.executor;
import java.sql.SQLException;
import java.util.Map; import java.util.Map;
import com.zq.spiderflow.context.SpiderContext; import com.zq.spiderflow.context.SpiderContext;
...@@ -36,7 +35,7 @@ public interface ShapeExecutor { ...@@ -36,7 +35,7 @@ public interface ShapeExecutor {
* @param context 爬虫上下文 * @param context 爬虫上下文
* @param variables 节点流程的全部变量的集合 * @param variables 节点流程的全部变量的集合
*/ */
void execute(SpiderNode node, SpiderContext context, Map<String, Object> variables) throws SQLException; void execute(SpiderNode node, SpiderContext context, Map<String, Object> variables) throws Exception;
default boolean allowExecuteNext(SpiderNode node, SpiderContext context, Map<String, Object> variables){ default boolean allowExecuteNext(SpiderNode node, SpiderContext context, Map<String, Object> variables){
return true; return true;
......
...@@ -66,10 +66,10 @@ public class SeleniumExecutor implements ShapeExecutor { ...@@ -66,10 +66,10 @@ public class SeleniumExecutor implements ShapeExecutor {
@Override @Override
public Shape shape() { public Shape shape() {
Shape shape = new Shape(); Shape shape = new Shape();
shape.setImage(""); shape.setImage("");
shape.setLabel("浏览器");
shape.setName("selenium"); shape.setName("selenium");
shape.setTitle("Selenium"); shape.setTitle("浏览器");
shape.setLabel("Selenium");
return shape; return shape;
} }
......
...@@ -99,6 +99,12 @@ ...@@ -99,6 +99,12 @@
<artifactId>springfox-swagger-ui</artifactId> <artifactId>springfox-swagger-ui</artifactId>
<version>${swagger.version}</version> <version>${swagger.version}</version>
</dependency> </dependency>
<dependency>
<groupId>com.zq</groupId>
<artifactId>flow-component</artifactId>
<version>1.0.0</version>
</dependency>
</dependencies> </dependencies>
<build> <build>
......
package com.zq.spiderflow.controller;
import cn.hutool.core.util.StrUtil;
import com.zq.common.vo.ResultVo;
import com.zq.spiderflow.service.ModelService;
import com.zq.spiderflow.util.AssertUtils;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import javax.annotation.Resource;
@RestController
@RequestMapping("/spiderflow/model")
public class ModelController {
@Resource
private ModelService modelService;
@PostMapping("/test/file")
public ResultVo uploadTestFile(@RequestParam("flowId") String flowId, MultipartFile file) throws Exception {
AssertUtils.isTrue(StrUtil.isNotBlank(flowId), "流程id不能为空");
return ResultVo.success(modelService.uploadTestFile(flowId, file));
}
}
\ No newline at end of file
...@@ -35,6 +35,10 @@ public class SpiderWebSocketContext extends SpiderContext { ...@@ -35,6 +35,10 @@ public class SpiderWebSocketContext extends SpiderContext {
this.debug = debug; this.debug = debug;
} }
public void writeResult(SpiderOutput output){
this.write(new WebSocketEvent<>("result", output));
}
@Override @Override
public void addOutput(SpiderOutput output) { public void addOutput(SpiderOutput output) {
this.write(new WebSocketEvent<>("output", output)); this.write(new WebSocketEvent<>("output", output));
......
package com.zq.spiderflow.service;
import org.springframework.web.multipart.MultipartFile;
import java.io.IOException;
import java.util.List;
import java.util.Map;
public interface ModelService {
Map<String, Object> uploadTestFile(String flowId, MultipartFile file) throws Exception;
}
\ No newline at end of file
package com.zq.spiderflow.service.impl;
import cn.hutool.core.io.FileUtil;
import com.zq.common.utils.EasyExcelUtil;
import com.zq.spiderflow.service.ModelService;
import com.zq.spiderflow.util.AssertUtils;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import org.springframework.web.multipart.MultipartFile;
import java.io.File;
import java.util.*;
@Service
public class ModelServiceImpl implements ModelService {
@Value("${spider.workspace}")
private String workspace;
@Override
public Map<String, Object> uploadTestFile(String flowId, MultipartFile multipartFile) throws Exception {
String suffix = FileUtil.extName(multipartFile.getOriginalFilename());
AssertUtils.isTrue(suffix.equals("xls") || suffix.equals("xlsx") || suffix.equals("et"), "不支持的文件类型");
File file = new File(workspace, flowId + File.separator + "file" + File.separator + multipartFile.getOriginalFilename());
if(file.exists()){
FileUtil.del(file);
}else {
file.mkdirs();
}
multipartFile.transferTo(file);
return EasyExcelUtil.preview100(file);
}
}
\ No newline at end of file
package com.zq.spiderflow.websocket; package com.zq.spiderflow.websocket;
import cn.hutool.core.util.StrUtil;
import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import com.zq.spiderflow.core.Spider; import com.zq.spiderflow.core.Spider;
import com.zq.spiderflow.core.utils.SpiderFlowUtils; import com.zq.spiderflow.core.utils.SpiderFlowUtils;
import com.zq.spiderflow.model.SpiderWebSocketContext; import com.zq.spiderflow.model.SpiderWebSocketContext;
import com.zq.spiderflow.model.WebSocketEvent; import com.zq.spiderflow.model.WebSocketEvent;
import com.zq.spiderflow.util.AssertUtils;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import javax.websocket.OnClose; import javax.websocket.OnClose;
...@@ -35,11 +37,15 @@ public class WebSocketEditorServer { ...@@ -35,11 +37,15 @@ public class WebSocketEditorServer {
context = new SpiderWebSocketContext(session); context = new SpiderWebSocketContext(session);
context.setDebug(isDebug); context.setDebug(isDebug);
context.setRunning(true); context.setRunning(true);
context.setFlowId(event.getString("flowId")); String flowId = event.getString("flowId");
if(StrUtil.isBlank(flowId)){
context.write(new WebSocketEvent<>("error", "flowId不能为空!"));
}
context.setFlowId(flowId);
// new Thread(() -> { // new Thread(() -> {
String xml = event.getString("message"); String xml = event.getString("message");
if (xml != null) { if (xml != null) {
spider.runWithTest(SpiderFlowUtils.loadXMLFromString(xml), context); spider. runWithTest(SpiderFlowUtils.loadXMLFromString(xml), context);
context.write(new WebSocketEvent<>("finish", null)); context.write(new WebSocketEvent<>("finish", null));
} else { } else {
context.write(new WebSocketEvent<>("error", "xml不正确!")); context.write(new WebSocketEvent<>("error", "xml不正确!"));
......
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