Commit 655eaa65 by wqc

新增导出组件

parent 2731cac6
...@@ -7,6 +7,7 @@ import io.swagger.annotations.ApiOperation; ...@@ -7,6 +7,7 @@ import io.swagger.annotations.ApiOperation;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource; import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import java.util.Map; import java.util.Map;
@Api(tags = "组件执行接口") @Api(tags = "组件执行接口")
...@@ -53,4 +54,10 @@ public class ComponentRunController { ...@@ -53,4 +54,10 @@ public class ComponentRunController {
return ResultVo.success(commonQueryService.validateNumber(body)); return ResultVo.success(commonQueryService.validateNumber(body));
} }
@ApiOperation("数据输出")
@PostMapping("/excelOutput")
public ResultVo excelOutput(HttpServletResponse response, @RequestBody Map<String, Object> body) throws Exception {
return ResultVo.success(commonQueryService.excelOutput(response,body));
}
} }
...@@ -15,6 +15,7 @@ import com.zq.dataoperation.entity.CommonQuerySetting; ...@@ -15,6 +15,7 @@ import com.zq.dataoperation.entity.CommonQuerySetting;
import com.zq.dataoperation.entity.MetaDataMapping; import com.zq.dataoperation.entity.MetaDataMapping;
import com.zq.dataoperation.entity.QueryDb; import com.zq.dataoperation.entity.QueryDb;
import com.zq.dataoperation.utils.ConnectionUtil; import com.zq.dataoperation.utils.ConnectionUtil;
import com.zq.dataoperation.utils.FileUtil;
import com.zq.dataoperation.utils.IdentityUtils; import com.zq.dataoperation.utils.IdentityUtils;
import com.zq.dataoperation.utils.SqlUtils; import com.zq.dataoperation.utils.SqlUtils;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
...@@ -25,6 +26,7 @@ import org.springframework.web.bind.annotation.RequestBody; ...@@ -25,6 +26,7 @@ import org.springframework.web.bind.annotation.RequestBody;
import java.sql.*; import java.sql.*;
import javax.annotation.Resource; import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import java.util.*; import java.util.*;
import java.util.regex.Matcher; import java.util.regex.Matcher;
import java.util.regex.Pattern; import java.util.regex.Pattern;
...@@ -140,7 +142,7 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo ...@@ -140,7 +142,7 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo
public List<Map> commonQuery(String sql, Integer queryId) throws Exception { public List<Map> commonQuery(String sql, Integer queryId) throws Exception {
ResultSet resultSet = null; ResultSet resultSet = null;
try { try {
Connection connection = ConnectionUtil.getConnection(queryId); Connection connection = ConnectionUtil.get(queryId);
connection.prepareStatement(sql).setQueryTimeout(5000); connection.prepareStatement(sql).setQueryTimeout(5000);
resultSet = connection.prepareStatement(sql).executeQuery(); resultSet = connection.prepareStatement(sql).executeQuery();
int columnCount = resultSet.getMetaData().getColumnCount(); int columnCount = resultSet.getMetaData().getColumnCount();
...@@ -245,6 +247,7 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo ...@@ -245,6 +247,7 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo
} }
} }
//记录排序
public Object SortRecord(Map<String, Object> body) throws Exception { public Object SortRecord(Map<String, Object> body) throws Exception {
JSONObject jsonObject = JSONUtil.parseObj(body); JSONObject jsonObject = JSONUtil.parseObj(body);
Integer datasourceId = Integer.valueOf(jsonObject.get("datasourceId").toString()); Integer datasourceId = Integer.valueOf(jsonObject.get("datasourceId").toString());
...@@ -260,6 +263,7 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo ...@@ -260,6 +263,7 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo
return commonQuery(sql,datasourceId); return commonQuery(sql,datasourceId);
} }
//剪切字符串
public Object CutString(Map<String, Object> body) throws Exception { public Object CutString(Map<String, Object> body) throws Exception {
JSONObject jsonObject = JSONUtil.parseObj(body); JSONObject jsonObject = JSONUtil.parseObj(body);
Integer datasourceId = Integer.valueOf(jsonObject.get("datasourceId").toString()); Integer datasourceId = Integer.valueOf(jsonObject.get("datasourceId").toString());
...@@ -275,6 +279,7 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo ...@@ -275,6 +279,7 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo
} }
} }
//验证电话
public Object validateNumber(Map<String, Object> body) throws Exception { public Object validateNumber(Map<String, Object> body) throws Exception {
JSONObject jsonObject = JSONUtil.parseObj(body); JSONObject jsonObject = JSONUtil.parseObj(body);
Integer datasourceId = Integer.valueOf(jsonObject.get("datasourceId").toString()); Integer datasourceId = Integer.valueOf(jsonObject.get("datasourceId").toString());
...@@ -302,4 +307,17 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo ...@@ -302,4 +307,17 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo
map.put("dirtyList",dirtyList); map.put("dirtyList",dirtyList);
return map; return map;
} }
public Object excelOutput(HttpServletResponse response, Map<String, Object> body) throws Exception {
JSONObject jsonObject = JSONUtil.parseObj(body);
Integer datasourceId = Integer.valueOf(jsonObject.get("datasourceId").toString());
String tableName = jsonObject.get("tableName").toString();
String filePath = jsonObject.get("filePath").toString();
String sql="SELECT * FROM "+tableName;
List<Map> list = commonQuery(sql, datasourceId);
FileUtil.outputExcel(list,response,filePath,tableName);
return list;
}
} }
...@@ -26,4 +26,8 @@ public class ConnectionUtil { ...@@ -26,4 +26,8 @@ public class ConnectionUtil {
public static JdbcTemplate getJdbcTemplate(Integer id){ public static JdbcTemplate getJdbcTemplate(Integer id){
return new JdbcTemplate(dataSourceMap.get(id)); return new JdbcTemplate(dataSourceMap.get(id));
} }
}
\ No newline at end of file public static Connection get(Integer id) throws SQLException {
return dataSourceMap.get(id).getConnection();
}
}
...@@ -158,6 +158,27 @@ public class FileUtil extends cn.hutool.core.io.FileUtil { ...@@ -158,6 +158,27 @@ public class FileUtil extends cn.hutool.core.io.FileUtil {
IoUtil.close(out); IoUtil.close(out);
} }
/**
* 导出excel
*/
public static void outputExcel(List<Map> list, HttpServletResponse response, String filePath,String fileName) throws IOException {
// String tempPath = fileName + ".xlsx";
File file = new File(fileName+"."+filePath);
BigExcelWriter writer = ExcelUtil.getBigWriter(file);
// 一次性写出内容,使用默认样式,强制输出标题
writer.write(list, true);
//response为HttpServletResponse对象
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8");
//test.xls是弹出下载对话框的文件名,不能为中文,中文请自行编码
response.setHeader("Content-Disposition", "attachment;filename=file.xlsx");
ServletOutputStream out = response.getOutputStream();
// 终止后删除临时文件
file.deleteOnExit();
writer.flush(out, true);
//此处记得关闭输出Servlet流
IoUtil.close(out);
}
public static String getFileType(String type) { public static String getFileType(String type) {
String documents = "txt doc pdf ppt pps xlsx xls docx"; String documents = "txt doc pdf ppt pps xlsx xls docx";
String music = "mp3 wav wma mpa ram ra aac aif m4a"; String music = "mp3 wav wma mpa ram ra aac aif m4a";
......
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;
@Component
public class ExcelOutExecutor 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("ExcelOut");
//模板文件名
shape.setName("ExcelOut");
//鼠标移动至图标上显示的名称
shape.setTitle("Excel输出");
return shape;
}
@Override
public String supportShape() {
return "ExcelOut";
}
@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;
}
}
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