Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
N
nnjcy-data-model
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
ljb
nnjcy-data-model
Commits
ca96da48
Commit
ca96da48
authored
Sep 28, 2023
by
wqc
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
新增组件跟组件接口
parent
ff4ffe7a
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
425 additions
and
3 deletions
+425
-3
dataoperation-server/src/main/java/com/zq/dataoperation/controller/ComponentRunController.java
+26
-2
dataoperation-server/src/main/java/com/zq/dataoperation/service/CommonQueryService.java
+79
-1
dataoperation-server/src/main/java/com/zq/dataoperation/utils/IdentityUtils.java
+88
-0
spider-flow-core/src/main/java/com/zq/spiderflow/core/executor/shape/CutStringExecutor.java
+58
-0
spider-flow-core/src/main/java/com/zq/spiderflow/core/executor/shape/DataEliminateExecutor.java
+58
-0
spider-flow-core/src/main/java/com/zq/spiderflow/core/executor/shape/GroupingMetaExecutor.java
+58
-0
spider-flow-core/src/main/java/com/zq/spiderflow/core/executor/shape/TableLeftJoinExecutor.java
+58
-0
No files found.
dataoperation-server/src/main/java/com/zq/dataoperation/controller/ComponentRunController.java
View file @
ca96da48
...
...
@@ -9,7 +9,7 @@ import org.springframework.web.bind.annotation.*;
import
javax.annotation.Resource
;
import
java.util.Map
;
@Api
(
tags
=
"
通用查询
"
)
@Api
(
tags
=
"
组件执行接口
"
)
@RestController
@RequestMapping
(
value
=
"/data/execute"
)
public
class
ComponentRunController
{
...
...
@@ -18,9 +18,33 @@ public class ComponentRunController {
private
CommonQueryService
commonQueryService
;
@ApiOperation
(
"去重执行"
)
@PostMapping
(
"/remove"
)
@PostMapping
(
"/remove
Repeat
"
)
public
ResultVo
removeRepeat
(
@RequestBody
Map
<
String
,
Object
>
body
)
throws
Exception
{
return
ResultVo
.
success
(
commonQueryService
.
removeRepeat
(
body
));
}
@ApiOperation
(
"身份证清洗"
)
@PostMapping
(
"/identityClean"
)
public
ResultVo
identityClean
(
@RequestBody
Map
<
String
,
Object
>
body
)
throws
Exception
{
return
ResultVo
.
success
(
commonQueryService
.
identityClean
(
body
));
}
@ApiOperation
(
"字符串替换"
)
@PostMapping
(
"/replaceString"
)
public
ResultVo
replaceString
(
@RequestBody
Map
<
String
,
Object
>
body
)
throws
Exception
{
return
ResultVo
.
success
(
commonQueryService
.
replaceString
(
body
));
}
@ApiOperation
(
"记录排序"
)
@PostMapping
(
"/SortRecord"
)
public
ResultVo
SortRecord
(
@RequestBody
Map
<
String
,
Object
>
body
)
throws
Exception
{
return
ResultVo
.
success
(
commonQueryService
.
SortRecord
(
body
));
}
@ApiOperation
(
"记录排序"
)
@PostMapping
(
"/cutString"
)
public
ResultVo
CutString
(
@RequestBody
Map
<
String
,
Object
>
body
)
throws
Exception
{
return
ResultVo
.
success
(
commonQueryService
.
CutString
(
body
));
}
}
dataoperation-server/src/main/java/com/zq/dataoperation/service/CommonQueryService.java
View file @
ca96da48
...
...
@@ -5,6 +5,7 @@ import cn.hutool.json.JSONUtil;
import
com.alibaba.druid.pool.DruidPooledConnection
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
com.baomidou.mybatisplus.extension.service.impl.ServiceImpl
;
import
com.jcraft.jsch.Logger
;
import
com.zq.common.exception.BusinessException
;
import
com.zq.common.vo.PageVo
;
import
com.zq.common.vo.ResultVo
;
...
...
@@ -15,7 +16,9 @@ import com.zq.dataoperation.entity.CommonQuerySetting;
import
com.zq.dataoperation.entity.MetaDataMapping
;
import
com.zq.dataoperation.entity.QueryDb
;
import
com.zq.dataoperation.utils.ConnectionUtil
;
import
com.zq.dataoperation.utils.IdentityUtils
;
import
com.zq.dataoperation.utils.SqlUtils
;
import
org.apache.commons.lang3.StringUtils
;
import
org.springframework.jdbc.core.JdbcTemplate
;
import
org.springframework.stereotype.Service
;
import
org.springframework.web.bind.annotation.RequestBody
;
...
...
@@ -180,12 +183,87 @@ public class CommonQueryService extends ServiceImpl<CommonQuerySettingDao, Commo
return
commonQuery
(
sql
,
id
);
}
//----------------------------------组件接口----------------------------------------------------------
//去重
public
Object
removeRepeat
(
Map
<
String
,
Object
>
body
)
throws
Exception
{
JSONObject
jsonObject
=
JSONUtil
.
parseObj
(
body
);
Long
datasourceId
=
Long
.
valueOf
(
jsonObject
.
get
(
"datasourceId"
).
toString
());
String
tableName
=
jsonObject
.
get
(
"tableName"
).
toString
();
String
metaData
=
jsonObject
.
get
(
"metaData"
).
toString
();
String
sql
=
"SELECT DISTINCT "
+
metaData
+
",m.* FROM "
+
tableName
+
" m"
;
String
sql1
=
"SELECT "
+
metaData
+
" FROM "
+
tableName
+
" GROUP BY "
+
metaData
+
" HAVING COUNT("
+
metaData
+
")>1;"
;
List
<
Map
>
mapList
=
commonQuery
(
sql1
,
datasourceId
);
if
(
mapList
==
null
){
return
"该字段没有重复值"
;
}
else
{
String
sql
=
"SELECT * FROM "
+
tableName
+
" WHERE id not in (SELECT MIN(id) FROM "
+
tableName
+
" GROUP BY "
+
metaData
+
" HAVING COUNT("
+
metaData
+
")>1);"
;
return
commonQuery
(
sql
,
datasourceId
);
}
}
//身份证清洗
public
Object
identityClean
(
Map
<
String
,
Object
>
body
)
throws
Exception
{
JSONObject
jsonObject
=
JSONUtil
.
parseObj
(
body
);
Long
datasourceId
=
Long
.
valueOf
(
jsonObject
.
get
(
"datasourceId"
).
toString
());
String
tableName
=
jsonObject
.
get
(
"tableName"
).
toString
();
String
metaData
=
jsonObject
.
get
(
"metaData"
).
toString
();
String
sql
=
"SELECT * FROM "
+
tableName
;
if
(
StringUtils
.
isNotBlank
(
metaData
))
{
return
"字段为身份证且不为空!"
;
}
if
(
IdentityUtils
.
isLegalIdCard
(
metaData
)!=
true
){
return
"身份证号不符"
;
}
else
if
(
IdentityUtils
.
is15BitLegalIdCard
(
metaData
)!=
true
){
return
"身份证不满15位!"
;
}
else
if
(
IdentityUtils
.
is18BitLegalIdCard
(
metaData
)!=
true
){
return
"身份证不满18位!"
;
}
else
{
return
commonQuery
(
sql
,
datasourceId
);
}
}
//字符串替换
public
Object
replaceString
(
Map
<
String
,
Object
>
body
)
throws
Exception
{
JSONObject
jsonObject
=
JSONUtil
.
parseObj
(
body
);
Long
datasourceId
=
Long
.
valueOf
(
jsonObject
.
get
(
"datasourceId"
).
toString
());
String
tableName
=
jsonObject
.
get
(
"tableName"
).
toString
();
String
metaData
=
jsonObject
.
get
(
"metaData"
).
toString
();
String
originStr
=
jsonObject
.
get
(
"originStr"
).
toString
();
String
replaceStr
=
jsonObject
.
get
(
"replaceStr"
).
toString
();
String
sql
=
"UPDATE "
+
tableName
+
" SET "
+
metaData
+
"=REPLACE("
+
metaData
+
",'"
+
originStr
+
"','"
+
replaceStr
+
"');"
;
if
(
StringUtils
.
isNotBlank
(
metaData
)&&
StringUtils
.
isNotBlank
(
tableName
)&&
StringUtils
.
isNotBlank
(
originStr
)&&
StringUtils
.
isNotBlank
(
replaceStr
))
{
return
"传入参数不能为空"
;
}
else
{
return
commonQuery
(
sql
,
datasourceId
);
}
}
public
Object
SortRecord
(
Map
<
String
,
Object
>
body
)
throws
Exception
{
JSONObject
jsonObject
=
JSONUtil
.
parseObj
(
body
);
Long
datasourceId
=
Long
.
valueOf
(
jsonObject
.
get
(
"datasourceId"
).
toString
());
String
tableName
=
jsonObject
.
get
(
"tableName"
).
toString
();
String
metaData
=
jsonObject
.
get
(
"metaData"
).
toString
();
String
sortStr
=
jsonObject
.
get
(
"sortStr"
).
toString
();
if
(
sortStr
.
equals
(
"1"
)){
sortStr
=
"ASC"
;
}
else
{
sortStr
=
"DESC"
;
}
String
sql
=
"SELECT * FROM "
+
tableName
+
" ORDER BY "
+
metaData
+
" "
+
sortStr
;
return
commonQuery
(
sql
,
datasourceId
);
}
public
Object
CutString
(
Map
<
String
,
Object
>
body
)
throws
Exception
{
JSONObject
jsonObject
=
JSONUtil
.
parseObj
(
body
);
Long
datasourceId
=
Long
.
valueOf
(
jsonObject
.
get
(
"datasourceId"
).
toString
());
String
tableName
=
jsonObject
.
get
(
"tableName"
).
toString
();
String
beginStr
=
jsonObject
.
get
(
"beginStr"
).
toString
();
String
indexStr
=
jsonObject
.
get
(
"indexStr"
).
toString
();
String
metaData
=
jsonObject
.
get
(
"metaData"
).
toString
();
String
sql
=
"SELECT *,"
+
" SUBSTR("
+
metaData
+
","
+
beginStr
+
","
+
indexStr
+
") AS "
+
metaData
+
"1 FROM "
+
tableName
;
if
(
StringUtils
.
isNotBlank
(
metaData
)&&
StringUtils
.
isNotBlank
(
tableName
)&&
StringUtils
.
isNotBlank
(
beginStr
)&&
StringUtils
.
isNotBlank
(
indexStr
))
{
return
"传入参数不能为空"
;
}
else
{
return
commonQuery
(
sql
,
datasourceId
);
}
}
}
dataoperation-server/src/main/java/com/zq/dataoperation/utils/IdentityUtils.java
0 → 100644
View file @
ca96da48
package
com
.
zq
.
dataoperation
.
utils
;
import
java.util.stream.IntStream
;
/**
* 身份证号码验证
* 1、号码的结构
* 公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。从左至右依次为:六位数字地址码,
* 八位数字出生日期码,三位数字顺序码和一位数字校验码。
* 2、地址码(前六位数)
* 表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按GB/T2260的规定执行。
* 3、出生日期码(第七位至十四位)
* 表示编码对象出生的年、月、日,按GB/T7408的规定执行,年、月、日代码之间不用分隔符。
* 4、顺序码(第十五位至十七位)
* 表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,
* 顺序码的奇数分配给男性,偶数分配给女性。
* 5、校验码(第十八位数)
* (1)十七位数字本体码加权求和公式 S = Sum(Ai Wi), i = 0, , 16 ,先对前17位数字的权求和 ;
* Ai:表示第i位置上的身份证号码数字值; Wi:表示第i位置上的加权因子 Wi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2
* (2)计算模 Y = mod(S, 11)
* (3)通过模( 0 1 2 3 4 5 6 7 8 9 10)得到对应的校验码 Y:1 0 X 9 8 7 6 5 4 3 2
*
*/
public
class
IdentityUtils
{
/**
* 身份证校验码
*/
private
static
final
int
[]
COEFFICIENT_ARRAY
=
{
7
,
9
,
10
,
5
,
8
,
4
,
2
,
1
,
6
,
3
,
7
,
9
,
10
,
5
,
8
,
4
,
2
};
/**
* 身份证号的尾数规则
*/
private
static
final
String
[]
IDENTITY_MANTISSA
=
{
"1"
,
"0"
,
"X"
,
"9"
,
"8"
,
"7"
,
"6"
,
"5"
,
"4"
,
"3"
,
"2"
};
private
static
final
String
IDENTITY_PATTERN_15
=
"^[1-9]\\d{7}((0\\d)|(1[0-2]))(([0-2]\\d)|3[0-1])\\d{3}$"
;
// 修改前未做X位的校验:"^[1-9]\\d{5}[1-9]\\d{3}((0\\d)|(1[0-2]))(([0-2]\\d)|3[0-1])\\d{4}$";
// 修改后:"^[1-9]\\d{5}[1-9]\\d{3}((0\\d)|(1[0-2]))(([0-2]\\d)|3[0-1])\\d{3}[0-9Xx]$";
private
static
final
String
IDENTITY_PATTERN_18
=
"^[1-9]\\d{5}[1-9]\\d{3}((0\\d)|(1[0-2]))(([0-2]\\d)|3[0-1])\\d{3}[0-9Xx]$"
;
/**
* 身份证号校验
*/
public
static
boolean
isLegalIdCard
(
String
identity
)
{
if
(
identity
==
null
)
{
return
false
;
}
if
(
identity
.
length
()
==
15
)
{
return
is15BitLegalIdCard
(
identity
);
}
if
(
identity
.
length
()
==
18
)
{
return
is18BitLegalIdCard
(
identity
);
}
return
false
;
}
public
static
boolean
is15BitLegalIdCard
(
String
identity
)
{
return
identity
.
matches
(
IDENTITY_PATTERN_15
);
}
public
static
boolean
is18BitLegalIdCard
(
String
identity
)
{
if
(
identity
.
length
()
!=
18
)
{
return
false
;
}
if
(!
identity
.
matches
(
IDENTITY_PATTERN_18
))
{
return
false
;
}
// 将字符串对象中的字符转换为一个字符数组
char
[]
chars
=
identity
.
toCharArray
();
long
sum
=
IntStream
.
range
(
0
,
17
).
map
(
index
->
{
char
ch
=
chars
[
index
];
// 通俗理解:digit()是个边界值判断,不过边界返回字符数字本身数值,超过边界即返回 -1.
int
digit
=
Character
.
digit
(
ch
,
10
);
int
coefficient
=
COEFFICIENT_ARRAY
[
index
];
return
digit
*
coefficient
;
}).
summaryStatistics
().
getSum
();
// 计算出的尾数索引
int
mantissaIndex
=
(
int
)
(
sum
%
11
);
String
mantissa
=
IDENTITY_MANTISSA
[
mantissaIndex
];
String
lastChar
=
identity
.
substring
(
17
);
return
lastChar
.
equalsIgnoreCase
(
mantissa
);
}
}
spider-flow-core/src/main/java/com/zq/spiderflow/core/executor/shape/CutStringExecutor.java
0 → 100644
View file @
ca96da48
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
CutStringExecutor
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
(
"CutString"
);
//模板文件名
shape
.
setName
(
"CutString"
);
//鼠标移动至图标上显示的名称
shape
.
setTitle
(
"剪切字符串"
);
return
shape
;
}
@Override
public
String
supportShape
()
{
return
"CutString"
;
}
@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
;
}
}
spider-flow-core/src/main/java/com/zq/spiderflow/core/executor/shape/DataEliminateExecutor.java
0 → 100644
View file @
ca96da48
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
DataEliminateExecutor
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
(
"DataEliminate"
);
//模板文件名
shape
.
setName
(
"DataEliminate"
);
//鼠标移动至图标上显示的名称
shape
.
setTitle
(
"数据剔除"
);
return
shape
;
}
@Override
public
String
supportShape
()
{
return
"DataEliminate"
;
}
@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
;
}
}
spider-flow-core/src/main/java/com/zq/spiderflow/core/executor/shape/GroupingMetaExecutor.java
0 → 100644
View file @
ca96da48
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
GroupingMetaExecutor
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
(
"GroupingMeta"
);
//模板文件名
shape
.
setName
(
"GroupingMeta"
);
//鼠标移动至图标上显示的名称
shape
.
setTitle
(
"字段分组"
);
return
shape
;
}
@Override
public
String
supportShape
()
{
return
"GroupingMeta"
;
}
@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
;
}
}
spider-flow-core/src/main/java/com/zq/spiderflow/core/executor/shape/TableLeftJoinExecutor.java
0 → 100644
View file @
ca96da48
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
TableLeftJoinExecutor
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
(
"TableLeftJoin"
);
//模板文件名
shape
.
setName
(
"TableLeftJoin"
);
//鼠标移动至图标上显示的名称
shape
.
setTitle
(
"表关联"
);
return
shape
;
}
@Override
public
String
supportShape
()
{
return
"TableLeftJoin"
;
}
@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
;
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment