Compare commits
No commits in common. "65c1809e95ce373a9de94e0c800200ced7eeb66a" and "624aa3ff808ffe767a90931207d8e45e25412730" have entirely different histories.
65c1809e95
...
624aa3ff80
|
|
@ -5,8 +5,3 @@ target/**
|
||||||
logs/**
|
logs/**
|
||||||
.DS_Store
|
.DS_Store
|
||||||
**/.DS_Store
|
**/.DS_Store
|
||||||
|
|
||||||
get_univ2/**
|
|
||||||
get_univ/**
|
|
||||||
|
|
||||||
.idea
|
|
||||||
|
|
|
||||||
|
|
@ -8,8 +8,9 @@ spring.boot.admin.client:
|
||||||
metadata:
|
metadata:
|
||||||
username: ${spring.boot.admin.client.username}
|
username: ${spring.boot.admin.client.username}
|
||||||
userpassword: ${spring.boot.admin.client.password}
|
userpassword: ${spring.boot.admin.client.password}
|
||||||
username: ruoyi
|
username: @monitor.username@
|
||||||
password: 123456
|
password: @monitor.password@
|
||||||
|
|
||||||
--- # snail-job 配置
|
--- # snail-job 配置
|
||||||
snail-job:
|
snail-job:
|
||||||
enabled: ${SNAIL_JOB_ENABLED:false}
|
enabled: ${SNAIL_JOB_ENABLED:false}
|
||||||
|
|
@ -26,6 +27,7 @@ snail-job:
|
||||||
port: 2${server.port}
|
port: 2${server.port}
|
||||||
# 客户端ip指定
|
# 客户端ip指定
|
||||||
host:
|
host:
|
||||||
|
|
||||||
--- # 数据源配置
|
--- # 数据源配置
|
||||||
spring:
|
spring:
|
||||||
datasource:
|
datasource:
|
||||||
|
|
@ -40,40 +42,40 @@ spring:
|
||||||
strict: true
|
strict: true
|
||||||
datasource:
|
datasource:
|
||||||
# 主库数据源
|
# 主库数据源
|
||||||
# master:
|
# master:
|
||||||
# type: ${spring.datasource.type}
|
# type: ${spring.datasource.type}
|
||||||
# driverClassName: com.mysql.cj.jdbc.Driver
|
# driverClassName: com.mysql.cj.jdbc.Driver
|
||||||
# # jdbc 所有参数配置参考 https://lionli.blog.csdn.net/article/details/122018562
|
# # jdbc 所有参数配置参考 https://lionli.blog.csdn.net/article/details/122018562
|
||||||
# # rewriteBatchedStatements=true 批处理优化 大幅提升批量插入更新删除性能(对数据库有性能损耗 使用批量操作应考虑性能问题)
|
# # rewriteBatchedStatements=true 批处理优化 大幅提升批量插入更新删除性能(对数据库有性能损耗 使用批量操作应考虑性能问题)
|
||||||
# url: jdbc:mysql://10.13.13.1:3306/yitisheng_ry_vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true
|
# url: jdbc:mysql://10.13.13.1:3306/yitisheng_ry_vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true
|
||||||
# username: root
|
# username: root
|
||||||
# password: Db$7Hn#4Jm9Pq2!Xz
|
# password: Db$7Hn#4Jm9Pq2!Xz
|
||||||
# # 从库数据源
|
# # 从库数据源
|
||||||
# slave:
|
# slave:
|
||||||
# lazy: true
|
# lazy: true
|
||||||
# type: ${spring.datasource.type}
|
# type: ${spring.datasource.type}
|
||||||
# driverClassName: com.mysql.cj.jdbc.Driver
|
# driverClassName: com.mysql.cj.jdbc.Driver
|
||||||
# url: jdbc:mysql://localhost:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true
|
# url: jdbc:mysql://localhost:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true
|
||||||
# username:
|
# username:
|
||||||
# password:
|
# password:
|
||||||
# oracle:
|
# oracle:
|
||||||
# type: ${spring.datasource.type}
|
# type: ${spring.datasource.type}
|
||||||
# driverClassName: oracle.jdbc.OracleDriver
|
# driverClassName: oracle.jdbc.OracleDriver
|
||||||
# url: jdbc:oracle:thin:@//localhost:1521/XE
|
# url: jdbc:oracle:thin:@//localhost:1521/XE
|
||||||
# username: ROOT
|
# username: ROOT
|
||||||
# password: root
|
# password: root
|
||||||
postgres:
|
postgres:
|
||||||
type: ${spring.datasource.type}
|
type: ${spring.datasource.type}
|
||||||
driverClassName: org.postgresql.Driver
|
driverClassName: org.postgresql.Driver
|
||||||
url: jdbc:postgresql://10.13.13.1:5432/art_sports_volunteer?useUnicode=true&characterEncoding=utf8&useSSL=true&autoReconnect=true&reWriteBatchedInserts=true
|
url: jdbc:postgresql://10.13.13.1:5432/art_sports_volunteer?useUnicode=true&characterEncoding=utf8&useSSL=true&autoReconnect=true&reWriteBatchedInserts=true
|
||||||
username: art_sports_volunteer
|
username: art_sports_volunteer
|
||||||
password: t56kX86WMQ8eNjRz
|
password: t56kX86WMQ8eNjRz
|
||||||
# sqlserver:
|
# sqlserver:
|
||||||
# type: ${spring.datasource.type}
|
# type: ${spring.datasource.type}
|
||||||
# driverClassName: com.microsoft.sqlserver.jdbc.SQLServerDriver
|
# driverClassName: com.microsoft.sqlserver.jdbc.SQLServerDriver
|
||||||
# url: jdbc:sqlserver://localhost:1433;DatabaseName=tempdb;SelectMethod=cursor;encrypt=false;rewriteBatchedStatements=true
|
# url: jdbc:sqlserver://localhost:1433;DatabaseName=tempdb;SelectMethod=cursor;encrypt=false;rewriteBatchedStatements=true
|
||||||
# username: SA
|
# username: SA
|
||||||
# password: root
|
# password: root
|
||||||
hikari:
|
hikari:
|
||||||
# 最大连接池数量
|
# 最大连接池数量
|
||||||
maxPoolSize: 20
|
maxPoolSize: 20
|
||||||
|
|
@ -89,6 +91,7 @@ spring:
|
||||||
maxLifetime: 1800000
|
maxLifetime: 1800000
|
||||||
# 多久检查一次连接的活性
|
# 多久检查一次连接的活性
|
||||||
keepaliveTime: 30000
|
keepaliveTime: 30000
|
||||||
|
|
||||||
--- # redis 单机配置(单机与集群只能开启一个另一个需要注释掉)
|
--- # redis 单机配置(单机与集群只能开启一个另一个需要注释掉)
|
||||||
spring.data:
|
spring.data:
|
||||||
redis:
|
redis:
|
||||||
|
|
@ -135,11 +138,6 @@ mail:
|
||||||
port: 465
|
port: 465
|
||||||
# 是否需要用户名密码验证
|
# 是否需要用户名密码验证
|
||||||
auth: true
|
auth: true
|
||||||
--- # 艺术院校导入配置
|
|
||||||
art:
|
|
||||||
import:
|
|
||||||
# 学校JSON数据目录(为空则默认使用 {user.dir}/get_univ)
|
|
||||||
schoolJsonDir: /Users/zhouwentao/Workspaces/Yitisheng/art-management-backend/get_univ
|
|
||||||
# 发送方,遵循RFC-822标准
|
# 发送方,遵循RFC-822标准
|
||||||
from: xxx@163.com
|
from: xxx@163.com
|
||||||
# 用户名(注意:如果使用foxmail邮箱,此处user为qq号)
|
# 用户名(注意:如果使用foxmail邮箱,此处user为qq号)
|
||||||
|
|
@ -154,6 +152,7 @@ art:
|
||||||
timeout: 0
|
timeout: 0
|
||||||
# Socket连接超时值,单位毫秒,缺省值不超时
|
# Socket连接超时值,单位毫秒,缺省值不超时
|
||||||
connectionTimeout: 0
|
connectionTimeout: 0
|
||||||
|
|
||||||
--- # sms 短信 支持 阿里云 腾讯云 云片 等等各式各样的短信服务商
|
--- # sms 短信 支持 阿里云 腾讯云 云片 等等各式各样的短信服务商
|
||||||
# https://sms4j.com/doc3/ 差异配置文档地址 支持单厂商多配置,可以配置多个同时使用
|
# https://sms4j.com/doc3/ 差异配置文档地址 支持单厂商多配置,可以配置多个同时使用
|
||||||
sms:
|
sms:
|
||||||
|
|
@ -186,6 +185,7 @@ sms:
|
||||||
signature: 您的短信签名
|
signature: 您的短信签名
|
||||||
sdk-app-id: 您的sdkAppId
|
sdk-app-id: 您的sdkAppId
|
||||||
|
|
||||||
|
|
||||||
--- # 三方授权
|
--- # 三方授权
|
||||||
justauth:
|
justauth:
|
||||||
# 前端外网访问地址
|
# 前端外网访问地址
|
||||||
|
|
|
||||||
|
|
@ -1,270 +0,0 @@
|
||||||
--- # 监控中心配置
|
|
||||||
spring.boot.admin.client:
|
|
||||||
# 增加客户端开关
|
|
||||||
enabled: ${SPRING_BOOT_ADMIN_CLIENT_ENABLED:false}
|
|
||||||
url: http://localhost:9090/admin
|
|
||||||
instance:
|
|
||||||
service-host-type: IP
|
|
||||||
metadata:
|
|
||||||
username: ${spring.boot.admin.client.username}
|
|
||||||
userpassword: ${spring.boot.admin.client.password}
|
|
||||||
username: ruoyi
|
|
||||||
password: 123456
|
|
||||||
--- # snail-job 配置
|
|
||||||
snail-job:
|
|
||||||
enabled: ${SNAIL_JOB_ENABLED:false}
|
|
||||||
# 需要在 SnailJob 后台组管理创建对应名称的组,然后创建任务的时候选择对应的组,才能正确分派任务
|
|
||||||
group: "ruoyi_group"
|
|
||||||
# SnailJob 接入验证令牌 详见 script/sql/ry_job.sql `sj_group_config` 表
|
|
||||||
token: "SJ_cKqBTPzCsWA3VyuCfFoccmuIEGXjr5KT"
|
|
||||||
server:
|
|
||||||
host: 127.0.0.1
|
|
||||||
port: 17888
|
|
||||||
# 命名空间UUID 详见 script/sql/ry_job.sql `sj_namespace`表`unique_id`字段
|
|
||||||
namespace: ${spring.profiles.active}
|
|
||||||
# 随主应用端口漂移
|
|
||||||
port: 2${server.port}
|
|
||||||
# 客户端ip指定
|
|
||||||
host:
|
|
||||||
--- # 数据源配置
|
|
||||||
spring:
|
|
||||||
datasource:
|
|
||||||
type: com.zaxxer.hikari.HikariDataSource
|
|
||||||
# 动态数据源文档 https://www.kancloud.cn/tracy5546/dynamic-datasource/content
|
|
||||||
dynamic:
|
|
||||||
# 性能分析插件(有性能损耗 不建议生产环境使用)
|
|
||||||
p6spy: true
|
|
||||||
# 设置默认的数据源或者数据源组,默认值即为 master
|
|
||||||
primary: postgres
|
|
||||||
# 严格模式 匹配不到数据源则报错
|
|
||||||
strict: true
|
|
||||||
datasource:
|
|
||||||
# 主库数据源
|
|
||||||
# master:
|
|
||||||
# type: ${spring.datasource.type}
|
|
||||||
# driverClassName: com.mysql.cj.jdbc.Driver
|
|
||||||
# # jdbc 所有参数配置参考 https://lionli.blog.csdn.net/article/details/122018562
|
|
||||||
# # rewriteBatchedStatements=true 批处理优化 大幅提升批量插入更新删除性能(对数据库有性能损耗 使用批量操作应考虑性能问题)
|
|
||||||
# url: jdbc:mysql://10.13.13.1:3306/yitisheng_ry_vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true
|
|
||||||
# username: root
|
|
||||||
# password: Db$7Hn#4Jm9Pq2!Xz
|
|
||||||
# # 从库数据源
|
|
||||||
# slave:
|
|
||||||
# lazy: true
|
|
||||||
# type: ${spring.datasource.type}
|
|
||||||
# driverClassName: com.mysql.cj.jdbc.Driver
|
|
||||||
# url: jdbc:mysql://localhost:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true
|
|
||||||
# username:
|
|
||||||
# password:
|
|
||||||
# oracle:
|
|
||||||
# type: ${spring.datasource.type}
|
|
||||||
# driverClassName: oracle.jdbc.OracleDriver
|
|
||||||
# url: jdbc:oracle:thin:@//localhost:1521/XE
|
|
||||||
# username: ROOT
|
|
||||||
# password: root
|
|
||||||
postgres:
|
|
||||||
type: ${spring.datasource.type}
|
|
||||||
driverClassName: org.postgresql.Driver
|
|
||||||
url: jdbc:postgresql://10.13.13.1:5432/art_sports_volunteer?useUnicode=true&characterEncoding=utf8&useSSL=true&autoReconnect=true&reWriteBatchedInserts=true
|
|
||||||
username: art_sports_volunteer
|
|
||||||
password: t56kX86WMQ8eNjRz
|
|
||||||
# sqlserver:
|
|
||||||
# type: ${spring.datasource.type}
|
|
||||||
# driverClassName: com.microsoft.sqlserver.jdbc.SQLServerDriver
|
|
||||||
# url: jdbc:sqlserver://localhost:1433;DatabaseName=tempdb;SelectMethod=cursor;encrypt=false;rewriteBatchedStatements=true
|
|
||||||
# username: SA
|
|
||||||
# password: root
|
|
||||||
hikari:
|
|
||||||
# 最大连接池数量
|
|
||||||
maxPoolSize: 20
|
|
||||||
# 最小空闲线程数量
|
|
||||||
minIdle: 10
|
|
||||||
# 配置获取连接等待超时的时间
|
|
||||||
connectionTimeout: 30000
|
|
||||||
# 校验超时时间
|
|
||||||
validationTimeout: 5000
|
|
||||||
# 空闲连接存活最大时间,默认10分钟
|
|
||||||
idleTimeout: 600000
|
|
||||||
# 此属性控制池中连接的最长生命周期,值0表示无限生命周期,默认30分钟
|
|
||||||
maxLifetime: 1800000
|
|
||||||
# 多久检查一次连接的活性
|
|
||||||
keepaliveTime: 30000
|
|
||||||
--- # redis 单机配置(单机与集群只能开启一个另一个需要注释掉)
|
|
||||||
spring.data:
|
|
||||||
redis:
|
|
||||||
# 地址
|
|
||||||
host: 10.13.13.1
|
|
||||||
# 端口,默认为6379
|
|
||||||
port: 56379
|
|
||||||
# 数据库索引
|
|
||||||
database: 2
|
|
||||||
# redis 密码必须配置
|
|
||||||
password: Rd@5Wk8#Nv3Yt6$Bm
|
|
||||||
# 连接超时时间
|
|
||||||
timeout: 10s
|
|
||||||
# 是否开启ssl
|
|
||||||
ssl.enabled: false
|
|
||||||
|
|
||||||
# redisson 配置
|
|
||||||
redisson:
|
|
||||||
# redis key前缀
|
|
||||||
keyPrefix:
|
|
||||||
# 线程池数量
|
|
||||||
threads: 4
|
|
||||||
# Netty线程池数量
|
|
||||||
nettyThreads: 8
|
|
||||||
# 单节点配置
|
|
||||||
singleServerConfig:
|
|
||||||
# 客户端名称 不能用中文
|
|
||||||
clientName: RuoYi-Vue-Plus
|
|
||||||
# 最小空闲连接数
|
|
||||||
connectionMinimumIdleSize: 8
|
|
||||||
# 连接池大小
|
|
||||||
connectionPoolSize: 32
|
|
||||||
# 连接空闲超时,单位:毫秒
|
|
||||||
idleConnectionTimeout: 10000
|
|
||||||
# 命令等待超时,单位:毫秒
|
|
||||||
timeout: 3000
|
|
||||||
# 发布和订阅连接池大小
|
|
||||||
subscriptionConnectionPoolSize: 50
|
|
||||||
|
|
||||||
--- # mail 邮件发送
|
|
||||||
mail:
|
|
||||||
enabled: false
|
|
||||||
host: smtp.163.com
|
|
||||||
port: 465
|
|
||||||
# 是否需要用户名密码验证
|
|
||||||
auth: true
|
|
||||||
--- # 艺术院校导入配置
|
|
||||||
art:
|
|
||||||
import:
|
|
||||||
# 学校JSON数据目录(为空则默认使用 {user.dir}/get_univ)
|
|
||||||
schoolJsonDir: /Users/zhouwentao/Workspaces/Yitisheng/art-management-backend/get_univ
|
|
||||||
# 发送方,遵循RFC-822标准
|
|
||||||
from: xxx@163.com
|
|
||||||
# 用户名(注意:如果使用foxmail邮箱,此处user为qq号)
|
|
||||||
user: xxx@163.com
|
|
||||||
# 密码(注意,某些邮箱需要为SMTP服务单独设置密码,详情查看相关帮助)
|
|
||||||
pass: xxxxxxxxxx
|
|
||||||
# 使用 STARTTLS安全连接,STARTTLS是对纯文本通信协议的扩展。
|
|
||||||
starttlsEnable: true
|
|
||||||
# 使用SSL安全连接
|
|
||||||
sslEnable: true
|
|
||||||
# SMTP超时时长,单位毫秒,缺省值不超时
|
|
||||||
timeout: 0
|
|
||||||
# Socket连接超时值,单位毫秒,缺省值不超时
|
|
||||||
connectionTimeout: 0
|
|
||||||
--- # sms 短信 支持 阿里云 腾讯云 云片 等等各式各样的短信服务商
|
|
||||||
# https://sms4j.com/doc3/ 差异配置文档地址 支持单厂商多配置,可以配置多个同时使用
|
|
||||||
sms:
|
|
||||||
# 配置源类型用于标定配置来源(interface,yaml)
|
|
||||||
config-type: yaml
|
|
||||||
# 用于标定yml中的配置是否开启短信拦截,接口配置不受此限制
|
|
||||||
restricted: true
|
|
||||||
# 短信拦截限制单手机号每分钟最大发送,只对开启了拦截的配置有效
|
|
||||||
minute-max: 1
|
|
||||||
# 短信拦截限制单手机号每日最大发送量,只对开启了拦截的配置有效
|
|
||||||
account-max: 30
|
|
||||||
# 以下配置来自于 org.dromara.sms4j.provider.config.BaseConfig类中
|
|
||||||
blends:
|
|
||||||
# 唯一ID 用于发送短信寻找具体配置 随便定义别用中文即可
|
|
||||||
# 可以同时存在两个相同厂商 例如: ali1 ali2 两个不同的阿里短信账号 也可用于区分租户
|
|
||||||
config1:
|
|
||||||
# 框架定义的厂商名称标识,标定此配置是哪个厂商,详细请看厂商标识介绍部分
|
|
||||||
supplier: alibaba
|
|
||||||
# 有些称为accessKey有些称之为apiKey,也有称为sdkKey或者appId。
|
|
||||||
access-key-id: 您的accessKey
|
|
||||||
# 称为accessSecret有些称之为apiSecret
|
|
||||||
access-key-secret: 您的accessKeySecret
|
|
||||||
signature: 您的短信签名
|
|
||||||
sdk-app-id: 您的sdkAppId
|
|
||||||
config2:
|
|
||||||
# 厂商标识,标定此配置是哪个厂商,详细请看厂商标识介绍部分
|
|
||||||
supplier: tencent
|
|
||||||
access-key-id: 您的accessKey
|
|
||||||
access-key-secret: 您的accessKeySecret
|
|
||||||
signature: 您的短信签名
|
|
||||||
sdk-app-id: 您的sdkAppId
|
|
||||||
|
|
||||||
--- # 三方授权
|
|
||||||
justauth:
|
|
||||||
# 前端外网访问地址
|
|
||||||
address: http://localhost:80
|
|
||||||
type:
|
|
||||||
maxkey:
|
|
||||||
# maxkey 服务器地址
|
|
||||||
# 注意 如下均配置均不需要修改 maxkey 已经内置好了数据
|
|
||||||
server-url: http://sso.maxkey.top
|
|
||||||
client-id: 876892492581044224
|
|
||||||
client-secret: x1Y5MTMwNzIwMjMxNTM4NDc3Mzche8
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=maxkey
|
|
||||||
topiam:
|
|
||||||
# topiam 服务器地址
|
|
||||||
server-url: http://127.0.0.1:1898/api/v1/authorize/y0q************spq***********8ol
|
|
||||||
client-id: 449c4*********937************759
|
|
||||||
client-secret: ac7***********1e0************28d
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=topiam
|
|
||||||
scopes: [openid, email, phone, profile]
|
|
||||||
qq:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=qq
|
|
||||||
union-id: false
|
|
||||||
weibo:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=weibo
|
|
||||||
gitee:
|
|
||||||
client-id: 91436b7940090d09c72c7daf85b959cfd5f215d67eea73acbf61b6b590751a98
|
|
||||||
client-secret: 02c6fcfd70342980cd8dd2f2c06c1a350645d76c754d7a264c4e125f9ba915ac
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=gitee
|
|
||||||
dingtalk:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=dingtalk
|
|
||||||
baidu:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=baidu
|
|
||||||
csdn:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=csdn
|
|
||||||
coding:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=coding
|
|
||||||
coding-group-name: xx
|
|
||||||
oschina:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=oschina
|
|
||||||
alipay_wallet:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=alipay_wallet
|
|
||||||
alipay-public-key: MIIB**************DAQAB
|
|
||||||
wechat_open:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=wechat_open
|
|
||||||
wechat_mp:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=wechat_mp
|
|
||||||
wechat_enterprise:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=wechat_enterprise
|
|
||||||
agent-id: 1000002
|
|
||||||
gitlab:
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=gitlab
|
|
||||||
gitea:
|
|
||||||
# 前端改动 https://gitee.com/JavaLionLi/plus-ui/pulls/204
|
|
||||||
# gitea 服务器地址
|
|
||||||
server-url: https://demo.gitea.com
|
|
||||||
client-id: 10**********6
|
|
||||||
client-secret: 1f7d08**********5b7**********29e
|
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=gitea
|
|
||||||
|
|
@ -33,7 +33,7 @@ captcha:
|
||||||
# 日志配置
|
# 日志配置
|
||||||
logging:
|
logging:
|
||||||
level:
|
level:
|
||||||
org.dromara: info
|
org.dromara: @logging.level@
|
||||||
org.springframework: warn
|
org.springframework: warn
|
||||||
org.mybatis.spring.mapper: error
|
org.mybatis.spring.mapper: error
|
||||||
org.apache.fury: warn
|
org.apache.fury: warn
|
||||||
|
|
@ -67,7 +67,7 @@ spring:
|
||||||
# 国际化资源文件路径
|
# 国际化资源文件路径
|
||||||
basename: i18n/messages
|
basename: i18n/messages
|
||||||
profiles:
|
profiles:
|
||||||
active: dev
|
active: @profiles.active@
|
||||||
# 文件上传
|
# 文件上传
|
||||||
servlet:
|
servlet:
|
||||||
multipart:
|
multipart:
|
||||||
|
|
|
||||||
|
|
@ -103,11 +103,6 @@
|
||||||
<artifactId>ruoyi-common-websocket</artifactId>
|
<artifactId>ruoyi-common-websocket</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.postgresql</groupId>
|
|
||||||
<artifactId>postgresql</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
</project>
|
</project>
|
||||||
|
|
|
||||||
|
|
@ -1,13 +1,11 @@
|
||||||
package org.dromara.art.controller;
|
package org.dromara.art.controller;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import jakarta.servlet.http.HttpServletResponse;
|
import jakarta.servlet.http.HttpServletResponse;
|
||||||
import jakarta.validation.constraints.*;
|
import jakarta.validation.constraints.*;
|
||||||
import cn.dev33.satoken.annotation.SaCheckPermission;
|
import cn.dev33.satoken.annotation.SaCheckPermission;
|
||||||
import com.fasterxml.jackson.databind.JsonNode;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
import org.springframework.web.bind.annotation.*;
|
||||||
import org.springframework.validation.annotation.Validated;
|
import org.springframework.validation.annotation.Validated;
|
||||||
import org.dromara.common.idempotent.annotation.RepeatSubmit;
|
import org.dromara.common.idempotent.annotation.RepeatSubmit;
|
||||||
|
|
@ -21,10 +19,8 @@ import org.dromara.common.log.enums.BusinessType;
|
||||||
import org.dromara.common.excel.utils.ExcelUtil;
|
import org.dromara.common.excel.utils.ExcelUtil;
|
||||||
import org.dromara.art.domain.vo.ArtSchoolDetailVo;
|
import org.dromara.art.domain.vo.ArtSchoolDetailVo;
|
||||||
import org.dromara.art.domain.bo.ArtSchoolDetailBo;
|
import org.dromara.art.domain.bo.ArtSchoolDetailBo;
|
||||||
import org.dromara.art.domain.ArtSchoolDetail;
|
|
||||||
import org.dromara.art.service.IArtSchoolDetailService;
|
import org.dromara.art.service.IArtSchoolDetailService;
|
||||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||||
import org.dromara.common.json.utils.JsonUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 学校详细信息
|
* 学校详细信息
|
||||||
|
|
@ -104,501 +100,6 @@ public class ArtSchoolDetailController extends BaseController {
|
||||||
@DeleteMapping("/{detailIds}")
|
@DeleteMapping("/{detailIds}")
|
||||||
public R<Void> remove(@NotEmpty(message = "主键不能为空")
|
public R<Void> remove(@NotEmpty(message = "主键不能为空")
|
||||||
@PathVariable Long[] detailIds) {
|
@PathVariable Long[] detailIds) {
|
||||||
return toAjax(artSchoolDetailService.deleteWithValidByIds(List.of(detailIds), Boolean.TRUE));
|
return toAjax(artSchoolDetailService.deleteWithValidByIds(List.of(detailIds), true));
|
||||||
}
|
|
||||||
|
|
||||||
// ------------------------ JSONB 独立接口 ------------------------
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:query")
|
|
||||||
@GetMapping("/json/satisfaction")
|
|
||||||
public R<Map<String, Object>> getSatisfactionJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return R.ok(Map.of("satisfactionJson", parseJson(getDetailValue(schoolId, DetailField.SATISFACTION))));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:edit")
|
|
||||||
@PutMapping("/json/satisfaction")
|
|
||||||
public R<Void> saveSatisfactionJson(@Validated @RequestBody SatisfactionJsonRequest request) {
|
|
||||||
return toAjax(saveDetailValue(request.getSchoolId(), DetailField.SATISFACTION, toJsonString(request.getSatisfactionJson())));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:remove")
|
|
||||||
@DeleteMapping("/json/satisfaction")
|
|
||||||
public R<Void> deleteSatisfactionJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return toAjax(saveDetailValue(schoolId, DetailField.SATISFACTION, null));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:query")
|
|
||||||
@GetMapping("/json/scholarship")
|
|
||||||
public R<Map<String, Object>> getScholarshipJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return R.ok(Map.of("scholarshipJson", parseJson(getDetailValue(schoolId, DetailField.SCHOLARSHIP))));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:edit")
|
|
||||||
@PutMapping("/json/scholarship")
|
|
||||||
public R<Void> saveScholarshipJson(@Validated @RequestBody ScholarshipJsonRequest request) {
|
|
||||||
return toAjax(saveDetailValue(request.getSchoolId(), DetailField.SCHOLARSHIP, toJsonString(request.getScholarshipJson())));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:remove")
|
|
||||||
@DeleteMapping("/json/scholarship")
|
|
||||||
public R<Void> deleteScholarshipJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return toAjax(saveDetailValue(schoolId, DetailField.SCHOLARSHIP, null));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:query")
|
|
||||||
@GetMapping("/json/specialMajor")
|
|
||||||
public R<Map<String, Object>> getSpecialMajorJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return R.ok(Map.of("specialMajorJson", parseJson(getDetailValue(schoolId, DetailField.SPECIAL_MAJOR))));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:edit")
|
|
||||||
@PutMapping("/json/specialMajor")
|
|
||||||
public R<Void> saveSpecialMajorJson(@Validated @RequestBody SpecialMajorJsonRequest request) {
|
|
||||||
return toAjax(saveDetailValue(request.getSchoolId(), DetailField.SPECIAL_MAJOR, toJsonString(request.getSpecialMajorJson())));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:remove")
|
|
||||||
@DeleteMapping("/json/specialMajor")
|
|
||||||
public R<Void> deleteSpecialMajorJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return toAjax(saveDetailValue(schoolId, DetailField.SPECIAL_MAJOR, null));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:query")
|
|
||||||
@GetMapping("/json/employmentReport")
|
|
||||||
public R<Map<String, Object>> getEmploymentReportJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return R.ok(Map.of("employmentReportJson", parseJson(getDetailValue(schoolId, DetailField.EMPLOYMENT_REPORT))));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:edit")
|
|
||||||
@PutMapping("/json/employmentReport")
|
|
||||||
public R<Void> saveEmploymentReportJson(@Validated @RequestBody EmploymentReportJsonRequest request) {
|
|
||||||
return toAjax(saveDetailValue(request.getSchoolId(), DetailField.EMPLOYMENT_REPORT, toJsonString(request.getEmploymentReportJson())));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:remove")
|
|
||||||
@DeleteMapping("/json/employmentReport")
|
|
||||||
public R<Void> deleteEmploymentReportJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return toAjax(saveDetailValue(schoolId, DetailField.EMPLOYMENT_REPORT, null));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:query")
|
|
||||||
@GetMapping("/json/photo")
|
|
||||||
public R<Map<String, Object>> getPhotoJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return R.ok(Map.of("photoJson", parseJson(getDetailValue(schoolId, DetailField.PHOTO))));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:edit")
|
|
||||||
@PutMapping("/json/photo")
|
|
||||||
public R<Void> savePhotoJson(@Validated @RequestBody PhotoJsonRequest request) {
|
|
||||||
return toAjax(saveDetailValue(request.getSchoolId(), DetailField.PHOTO, toJsonString(request.getPhotoJson())));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:remove")
|
|
||||||
@DeleteMapping("/json/photo")
|
|
||||||
public R<Void> deletePhotoJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return toAjax(saveDetailValue(schoolId, DetailField.PHOTO, null));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:query")
|
|
||||||
@GetMapping("/json/accommodation")
|
|
||||||
public R<Map<String, Object>> getAccommodationJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return R.ok(Map.of("accommodationJson", parseJson(getDetailValue(schoolId, DetailField.ACCOMMODATION))));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:edit")
|
|
||||||
@PutMapping("/json/accommodation")
|
|
||||||
public R<Void> saveAccommodationJson(@Validated @RequestBody AccommodationJsonRequest request) {
|
|
||||||
return toAjax(saveDetailValue(request.getSchoolId(), DetailField.ACCOMMODATION, toJsonString(request.getAccommodationJson())));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:remove")
|
|
||||||
@DeleteMapping("/json/accommodation")
|
|
||||||
public R<Void> deleteAccommodationJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return toAjax(saveDetailValue(schoolId, DetailField.ACCOMMODATION, null));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:query")
|
|
||||||
@GetMapping("/json/subjectReviews")
|
|
||||||
public R<Map<String, Object>> getSubjectReviewsJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return R.ok(Map.of("subjectReviewsJson", parseJson(getDetailValue(schoolId, DetailField.SUBJECT_REVIEWS))));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:edit")
|
|
||||||
@PutMapping("/json/subjectReviews")
|
|
||||||
public R<Void> saveSubjectReviewsJson(@Validated @RequestBody SubjectReviewsJsonRequest request) {
|
|
||||||
return toAjax(saveDetailValue(request.getSchoolId(), DetailField.SUBJECT_REVIEWS, toJsonString(request.getSubjectReviewsJson())));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:remove")
|
|
||||||
@DeleteMapping("/json/subjectReviews")
|
|
||||||
public R<Void> deleteSubjectReviewsJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return toAjax(saveDetailValue(schoolId, DetailField.SUBJECT_REVIEWS, null));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:query")
|
|
||||||
@GetMapping("/json/research")
|
|
||||||
public R<Map<String, Object>> getResearchJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return R.ok(Map.of("researchJson", parseJson(getDetailValue(schoolId, DetailField.RESEARCH))));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:edit")
|
|
||||||
@PutMapping("/json/research")
|
|
||||||
public R<Void> saveResearchJson(@Validated @RequestBody ResearchJsonRequest request) {
|
|
||||||
return toAjax(saveDetailValue(request.getSchoolId(), DetailField.RESEARCH, toJsonString(request.getResearchJson())));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:remove")
|
|
||||||
@DeleteMapping("/json/research")
|
|
||||||
public R<Void> deleteResearchJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return toAjax(saveDetailValue(schoolId, DetailField.RESEARCH, null));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:query")
|
|
||||||
@GetMapping("/json/univMajors")
|
|
||||||
public R<Map<String, Object>> getUnivMajorsJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return R.ok(Map.of("univMajorsJson", parseJson(getDetailValue(schoolId, DetailField.UNIV_MAJORS))));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:edit")
|
|
||||||
@PutMapping("/json/univMajors")
|
|
||||||
public R<Void> saveUnivMajorsJson(@Validated @RequestBody UnivMajorsJsonRequest request) {
|
|
||||||
return toAjax(saveDetailValue(request.getSchoolId(), DetailField.UNIV_MAJORS, toJsonString(request.getUnivMajorsJson())));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:remove")
|
|
||||||
@DeleteMapping("/json/univMajors")
|
|
||||||
public R<Void> deleteUnivMajorsJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return toAjax(saveDetailValue(schoolId, DetailField.UNIV_MAJORS, null));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:query")
|
|
||||||
@GetMapping("/json/univPostgraduate")
|
|
||||||
public R<Map<String, Object>> getUnivPostgraduateJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
Object o = parseJson(getDetailValue(schoolId, DetailField.UNIV_POSTGRADUATE));
|
|
||||||
return R.ok(Map.of("univPostgraduateJson", o));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:edit")
|
|
||||||
@PutMapping("/json/univPostgraduate")
|
|
||||||
public R<Void> saveUnivPostgraduateJson(@Validated @RequestBody UnivPostgraduateJsonRequest request) {
|
|
||||||
return toAjax(saveDetailValue(request.getSchoolId(), DetailField.UNIV_POSTGRADUATE, toJsonString(request.getUnivPostgraduateJson())));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:remove")
|
|
||||||
@DeleteMapping("/json/univPostgraduate")
|
|
||||||
public R<Void> deleteUnivPostgraduateJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
return toAjax(saveDetailValue(schoolId, DetailField.UNIV_POSTGRADUATE, null));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SaCheckPermission("art:schoolDetail:query")
|
|
||||||
@GetMapping("/json/all")
|
|
||||||
public R<Map<String, Object>> getAllJson(@NotNull(message = "学校ID不能为空") @RequestParam Long schoolId) {
|
|
||||||
ArtSchoolDetail detail = artSchoolDetailService.queryEntityBySchoolId(schoolId);
|
|
||||||
if (detail == null) {
|
|
||||||
return R.ok(Map.of());
|
|
||||||
}
|
|
||||||
return R.ok(Map.of(
|
|
||||||
"satisfactionJson", parseJson(detail.getSatisfactionJson()),
|
|
||||||
"scholarshipJson", parseJson(detail.getScholarshipJson()),
|
|
||||||
"specialMajorJson", parseJson(detail.getSpecialMajorJson()),
|
|
||||||
"employmentReportJson", parseJson(detail.getEmploymentReportJson()),
|
|
||||||
"photoJson", parseJson(detail.getPhotoJson()),
|
|
||||||
"accommodationJson", parseJson(detail.getAccommodationJson()),
|
|
||||||
"subjectReviewsJson", parseJson(detail.getSubjectReviewsJson()),
|
|
||||||
"researchJson", parseJson(detail.getResearchJson()),
|
|
||||||
"univMajorsJson", parseJson(detail.getUnivMajorsJson()),
|
|
||||||
"univPostgraduateJson", parseJson(detail.getUnivPostgraduateJson())
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
private String getDetailValue(Long schoolId, DetailField field) {
|
|
||||||
ArtSchoolDetail detail = artSchoolDetailService.queryEntityBySchoolId(schoolId);
|
|
||||||
if (detail == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
return switch (field) {
|
|
||||||
case SATISFACTION -> detail.getSatisfactionJson();
|
|
||||||
case SCHOLARSHIP -> detail.getScholarshipJson();
|
|
||||||
case SPECIAL_MAJOR -> detail.getSpecialMajorJson();
|
|
||||||
case EMPLOYMENT_REPORT -> detail.getEmploymentReportJson();
|
|
||||||
case PHOTO -> detail.getPhotoJson();
|
|
||||||
case ACCOMMODATION -> detail.getAccommodationJson();
|
|
||||||
case SUBJECT_REVIEWS -> detail.getSubjectReviewsJson();
|
|
||||||
case RESEARCH -> detail.getResearchJson();
|
|
||||||
case UNIV_MAJORS -> detail.getUnivMajorsJson();
|
|
||||||
case UNIV_POSTGRADUATE -> detail.getUnivPostgraduateJson();
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean saveDetailValue(Long schoolId, DetailField field, String json) {
|
|
||||||
ArtSchoolDetail detail = artSchoolDetailService.queryEntityBySchoolId(schoolId);
|
|
||||||
if (detail == null) {
|
|
||||||
detail = new ArtSchoolDetail();
|
|
||||||
detail.setSchoolId(schoolId);
|
|
||||||
}
|
|
||||||
switch (field) {
|
|
||||||
case SATISFACTION -> detail.setSatisfactionJson(json);
|
|
||||||
case SCHOLARSHIP -> detail.setScholarshipJson(json);
|
|
||||||
case SPECIAL_MAJOR -> detail.setSpecialMajorJson(json);
|
|
||||||
case EMPLOYMENT_REPORT -> detail.setEmploymentReportJson(json);
|
|
||||||
case PHOTO -> detail.setPhotoJson(json);
|
|
||||||
case ACCOMMODATION -> detail.setAccommodationJson(json);
|
|
||||||
case SUBJECT_REVIEWS -> detail.setSubjectReviewsJson(json);
|
|
||||||
case RESEARCH -> detail.setResearchJson(json);
|
|
||||||
case UNIV_MAJORS -> detail.setUnivMajorsJson(json);
|
|
||||||
case UNIV_POSTGRADUATE -> detail.setUnivPostgraduateJson(json);
|
|
||||||
}
|
|
||||||
return artSchoolDetailService.saveOrUpdateBySchoolId(detail);
|
|
||||||
}
|
|
||||||
|
|
||||||
private Object parseJson(String json) {
|
|
||||||
if (json == null || json.isBlank()) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
return JsonUtils.getObjectMapper().readTree(json);
|
|
||||||
} catch (Exception e) {
|
|
||||||
return json;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private String toJsonString(JsonNode node) {
|
|
||||||
if (node == null || node.isNull()) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
return JsonUtils.toJsonString(node);
|
|
||||||
}
|
|
||||||
|
|
||||||
private enum DetailField {
|
|
||||||
SATISFACTION,
|
|
||||||
SCHOLARSHIP,
|
|
||||||
SPECIAL_MAJOR,
|
|
||||||
EMPLOYMENT_REPORT,
|
|
||||||
PHOTO,
|
|
||||||
ACCOMMODATION,
|
|
||||||
SUBJECT_REVIEWS,
|
|
||||||
RESEARCH,
|
|
||||||
UNIV_MAJORS,
|
|
||||||
UNIV_POSTGRADUATE
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class SatisfactionJsonRequest {
|
|
||||||
@NotNull(message = "学校ID不能为空")
|
|
||||||
private Long schoolId;
|
|
||||||
private JsonNode satisfactionJson;
|
|
||||||
|
|
||||||
public Long getSchoolId() {
|
|
||||||
return schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSchoolId(Long schoolId) {
|
|
||||||
this.schoolId = schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public JsonNode getSatisfactionJson() {
|
|
||||||
return satisfactionJson;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSatisfactionJson(JsonNode satisfactionJson) {
|
|
||||||
this.satisfactionJson = satisfactionJson;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class ScholarshipJsonRequest {
|
|
||||||
@NotNull(message = "学校ID不能为空")
|
|
||||||
private Long schoolId;
|
|
||||||
private JsonNode scholarshipJson;
|
|
||||||
|
|
||||||
public Long getSchoolId() {
|
|
||||||
return schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSchoolId(Long schoolId) {
|
|
||||||
this.schoolId = schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public JsonNode getScholarshipJson() {
|
|
||||||
return scholarshipJson;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setScholarshipJson(JsonNode scholarshipJson) {
|
|
||||||
this.scholarshipJson = scholarshipJson;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class SpecialMajorJsonRequest {
|
|
||||||
@NotNull(message = "学校ID不能为空")
|
|
||||||
private Long schoolId;
|
|
||||||
private JsonNode specialMajorJson;
|
|
||||||
|
|
||||||
public Long getSchoolId() {
|
|
||||||
return schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSchoolId(Long schoolId) {
|
|
||||||
this.schoolId = schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public JsonNode getSpecialMajorJson() {
|
|
||||||
return specialMajorJson;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSpecialMajorJson(JsonNode specialMajorJson) {
|
|
||||||
this.specialMajorJson = specialMajorJson;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class EmploymentReportJsonRequest {
|
|
||||||
@NotNull(message = "学校ID不能为空")
|
|
||||||
private Long schoolId;
|
|
||||||
private JsonNode employmentReportJson;
|
|
||||||
|
|
||||||
public Long getSchoolId() {
|
|
||||||
return schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSchoolId(Long schoolId) {
|
|
||||||
this.schoolId = schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public JsonNode getEmploymentReportJson() {
|
|
||||||
return employmentReportJson;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setEmploymentReportJson(JsonNode employmentReportJson) {
|
|
||||||
this.employmentReportJson = employmentReportJson;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class PhotoJsonRequest {
|
|
||||||
@NotNull(message = "学校ID不能为空")
|
|
||||||
private Long schoolId;
|
|
||||||
private JsonNode photoJson;
|
|
||||||
|
|
||||||
public Long getSchoolId() {
|
|
||||||
return schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSchoolId(Long schoolId) {
|
|
||||||
this.schoolId = schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public JsonNode getPhotoJson() {
|
|
||||||
return photoJson;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setPhotoJson(JsonNode photoJson) {
|
|
||||||
this.photoJson = photoJson;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class AccommodationJsonRequest {
|
|
||||||
@NotNull(message = "学校ID不能为空")
|
|
||||||
private Long schoolId;
|
|
||||||
private JsonNode accommodationJson;
|
|
||||||
|
|
||||||
public Long getSchoolId() {
|
|
||||||
return schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSchoolId(Long schoolId) {
|
|
||||||
this.schoolId = schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public JsonNode getAccommodationJson() {
|
|
||||||
return accommodationJson;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setAccommodationJson(JsonNode accommodationJson) {
|
|
||||||
this.accommodationJson = accommodationJson;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class SubjectReviewsJsonRequest {
|
|
||||||
@NotNull(message = "学校ID不能为空")
|
|
||||||
private Long schoolId;
|
|
||||||
private JsonNode subjectReviewsJson;
|
|
||||||
|
|
||||||
public Long getSchoolId() {
|
|
||||||
return schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSchoolId(Long schoolId) {
|
|
||||||
this.schoolId = schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public JsonNode getSubjectReviewsJson() {
|
|
||||||
return subjectReviewsJson;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSubjectReviewsJson(JsonNode subjectReviewsJson) {
|
|
||||||
this.subjectReviewsJson = subjectReviewsJson;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class ResearchJsonRequest {
|
|
||||||
@NotNull(message = "学校ID不能为空")
|
|
||||||
private Long schoolId;
|
|
||||||
private JsonNode researchJson;
|
|
||||||
|
|
||||||
public Long getSchoolId() {
|
|
||||||
return schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSchoolId(Long schoolId) {
|
|
||||||
this.schoolId = schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public JsonNode getResearchJson() {
|
|
||||||
return researchJson;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setResearchJson(JsonNode researchJson) {
|
|
||||||
this.researchJson = researchJson;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class UnivMajorsJsonRequest {
|
|
||||||
@NotNull(message = "学校ID不能为空")
|
|
||||||
private Long schoolId;
|
|
||||||
private JsonNode univMajorsJson;
|
|
||||||
|
|
||||||
public Long getSchoolId() {
|
|
||||||
return schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSchoolId(Long schoolId) {
|
|
||||||
this.schoolId = schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public JsonNode getUnivMajorsJson() {
|
|
||||||
return univMajorsJson;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setUnivMajorsJson(JsonNode univMajorsJson) {
|
|
||||||
this.univMajorsJson = univMajorsJson;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class UnivPostgraduateJsonRequest {
|
|
||||||
@NotNull(message = "学校ID不能为空")
|
|
||||||
private Long schoolId;
|
|
||||||
private JsonNode univPostgraduateJson;
|
|
||||||
|
|
||||||
public Long getSchoolId() {
|
|
||||||
return schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSchoolId(Long schoolId) {
|
|
||||||
this.schoolId = schoolId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public JsonNode getUnivPostgraduateJson() {
|
|
||||||
return univPostgraduateJson;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setUnivPostgraduateJson(JsonNode univPostgraduateJson) {
|
|
||||||
this.univPostgraduateJson = univPostgraduateJson;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,23 @@ package org.dromara.art.controller;
|
||||||
|
|
||||||
import cn.hutool.core.collection.CollUtil;
|
import cn.hutool.core.collection.CollUtil;
|
||||||
import com.fasterxml.jackson.databind.JsonNode;
|
import com.fasterxml.jackson.databind.JsonNode;
|
||||||
|
import lombok.RequiredArgsConstructor;
|
||||||
|
import org.dromara.art.domain.bo.*;
|
||||||
|
import org.dromara.art.domain.vo.ArtSchoolImportDetailVo;
|
||||||
|
import org.dromara.art.domain.vo.ArtSchoolJsonImportPreviewVo;
|
||||||
|
import org.dromara.art.domain.vo.ArtSchoolVo;
|
||||||
|
import org.dromara.art.service.IArtSchoolDetailService;
|
||||||
|
import org.dromara.art.service.IArtSchoolService;
|
||||||
|
import org.dromara.common.core.utils.StringUtils;
|
||||||
|
import org.dromara.common.json.utils.JsonUtils;
|
||||||
|
import org.dromara.common.core.domain.R;
|
||||||
|
import org.dromara.common.web.core.BaseController;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
import java.math.BigDecimal;
|
import java.math.BigDecimal;
|
||||||
import java.math.RoundingMode;
|
import java.math.RoundingMode;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
|
|
@ -11,23 +28,6 @@ import java.util.LinkedHashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
import lombok.RequiredArgsConstructor;
|
|
||||||
import org.dromara.art.domain.bo.*;
|
|
||||||
import org.dromara.art.domain.vo.ArtSchoolImportDetailVo;
|
|
||||||
import org.dromara.art.domain.vo.ArtSchoolJsonImportPreviewVo;
|
|
||||||
import org.dromara.art.domain.vo.ArtSchoolVo;
|
|
||||||
import org.dromara.art.service.IArtSchoolDetailService;
|
|
||||||
import org.dromara.art.service.IArtSchoolService;
|
|
||||||
import org.dromara.common.core.domain.R;
|
|
||||||
import org.dromara.common.core.utils.StringUtils;
|
|
||||||
import org.dromara.common.json.utils.JsonUtils;
|
|
||||||
import org.dromara.common.web.core.BaseController;
|
|
||||||
import org.springframework.beans.factory.annotation.Value;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
@Validated
|
@Validated
|
||||||
@RequiredArgsConstructor
|
@RequiredArgsConstructor
|
||||||
|
|
@ -38,21 +38,10 @@ public class ArtTestController extends BaseController {
|
||||||
private final IArtSchoolService artSchoolService;
|
private final IArtSchoolService artSchoolService;
|
||||||
private final IArtSchoolDetailService artSchoolDetailService;
|
private final IArtSchoolDetailService artSchoolDetailService;
|
||||||
|
|
||||||
@Value("${art.import.schoolJsonDir:}")
|
|
||||||
private String schoolJsonDir;
|
|
||||||
|
|
||||||
@GetMapping("/importSchoolByJson")
|
@GetMapping("/importSchoolByJson")
|
||||||
public R<ArtSchoolJsonImportPreviewVo> importSchoolByJson(
|
public R<ArtSchoolJsonImportPreviewVo> importSchoolByJson(@RequestParam(defaultValue = "20") Integer previewSize) {
|
||||||
@RequestParam(defaultValue = "20") Integer previewSize
|
int safePreviewSize = previewSize == null ? 20 : Math.min(Math.max(previewSize, 1), 200);
|
||||||
) {
|
Path sourceDir = Path.of(System.getProperty("user.dir"), "get_univ");
|
||||||
int safePreviewSize =
|
|
||||||
previewSize == null ? 20 : Math.min(Math.max(previewSize, 1), 200);
|
|
||||||
Path sourceDir;
|
|
||||||
if (StringUtils.isNotBlank(schoolJsonDir)) {
|
|
||||||
sourceDir = Path.of(schoolJsonDir.trim());
|
|
||||||
} else {
|
|
||||||
sourceDir = Path.of(System.getProperty("user.dir"), "get_univ");
|
|
||||||
}
|
|
||||||
if (!Files.exists(sourceDir) || !Files.isDirectory(sourceDir)) {
|
if (!Files.exists(sourceDir) || !Files.isDirectory(sourceDir)) {
|
||||||
return R.fail("目录不存在: " + sourceDir);
|
return R.fail("目录不存在: " + sourceDir);
|
||||||
}
|
}
|
||||||
|
|
@ -80,68 +69,38 @@ public class ArtTestController extends BaseController {
|
||||||
|
|
||||||
for (Path file : fileList) {
|
for (Path file : fileList) {
|
||||||
String fileName = file.getFileName().toString();
|
String fileName = file.getFileName().toString();
|
||||||
System.out.println("处理文件:" + fileName);
|
|
||||||
JsonNode root;
|
JsonNode root;
|
||||||
try {
|
try {
|
||||||
root = JsonUtils.getObjectMapper().readTree(file.toFile());
|
root = JsonUtils.getObjectMapper().readTree(file.toFile());
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
readFailCount++;
|
readFailCount++;
|
||||||
appendDetail(
|
appendDetail(details, safePreviewSize, null, null, "FAILED", fileName + " 读取失败: " + e.getMessage());
|
||||||
details,
|
|
||||||
safePreviewSize,
|
|
||||||
null,
|
|
||||||
null,
|
|
||||||
"FAILED",
|
|
||||||
fileName + " 读取失败: " + e.getMessage()
|
|
||||||
);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
List<JsonNode> schoolNodes = extractSchoolNodes(root);
|
List<JsonNode> schoolNodes = extractSchoolNodes(root);
|
||||||
if (CollUtil.isEmpty(schoolNodes)) {
|
if (CollUtil.isEmpty(schoolNodes)) {
|
||||||
invalidCount++;
|
invalidCount++;
|
||||||
appendDetail(
|
appendDetail(details, safePreviewSize, null, null, "INVALID", fileName + " 缺少有效学校对象");
|
||||||
details,
|
|
||||||
safePreviewSize,
|
|
||||||
null,
|
|
||||||
null,
|
|
||||||
"INVALID",
|
|
||||||
fileName + " 缺少有效学校对象"
|
|
||||||
);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < schoolNodes.size(); i++) {
|
for (int i = 0; i < schoolNodes.size(); i++) {
|
||||||
JsonNode schoolNode = schoolNodes.get(i);
|
JsonNode schoolNode = schoolNodes.get(i);
|
||||||
String sourceTag =
|
String sourceTag = schoolNodes.size() == 1 ? fileName : (fileName + "#" + i);
|
||||||
schoolNodes.size() == 1 ? fileName : (fileName + "#" + i);
|
|
||||||
|
|
||||||
Integer univId = asInteger(schoolNode.get("univId"));
|
Integer univId = asInteger(schoolNode.get("univId"));
|
||||||
String mainName = asText(schoolNode.get("univName"));
|
String mainName = asText(schoolNode.get("univName"));
|
||||||
if (univId == null || StringUtils.isBlank(mainName)) {
|
if (univId == null || StringUtils.isBlank(mainName)) {
|
||||||
invalidCount++;
|
invalidCount++;
|
||||||
appendDetail(
|
appendDetail(details, safePreviewSize, null, mainName, "INVALID", sourceTag + " 缺少必填字段: univId/univName");
|
||||||
details,
|
|
||||||
safePreviewSize,
|
|
||||||
null,
|
|
||||||
mainName,
|
|
||||||
"INVALID",
|
|
||||||
sourceTag + " 缺少必填字段: univId/univName"
|
|
||||||
);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
String mainCode = String.valueOf(univId);
|
String mainCode = String.valueOf(univId);
|
||||||
if (!fileUnivIdSet.add(univId) || !fileMainCodeSet.add(mainCode)) {
|
if (!fileUnivIdSet.add(univId) || !fileMainCodeSet.add(mainCode)) {
|
||||||
duplicateInFileCount++;
|
duplicateInFileCount++;
|
||||||
appendDetail(
|
appendDetail(details, safePreviewSize, mainCode, mainName, "DUPLICATE_FILE", sourceTag + " 文件内重复(univId/mainCode)");
|
||||||
details,
|
|
||||||
safePreviewSize,
|
|
||||||
mainCode,
|
|
||||||
mainName,
|
|
||||||
"DUPLICATE_FILE",
|
|
||||||
sourceTag + " 文件内重复(univId/mainCode)"
|
|
||||||
);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -151,22 +110,9 @@ public class ArtTestController extends BaseController {
|
||||||
continue;
|
continue;
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
ArtSchoolSubmitBo submitBo = buildSubmitBo(
|
ArtSchoolSubmitBo submitBo = buildSubmitBo(schoolNode, sourceTag, univId, mainCode, mainName);
|
||||||
schoolNode,
|
|
||||||
sourceTag,
|
|
||||||
univId,
|
|
||||||
mainCode,
|
|
||||||
mainName
|
|
||||||
);
|
|
||||||
readyCount++;
|
readyCount++;
|
||||||
appendDetail(
|
appendDetail(details, safePreviewSize, mainCode, mainName, "READY", sourceTag + " 已完成结构映射,待入库");
|
||||||
details,
|
|
||||||
safePreviewSize,
|
|
||||||
mainCode,
|
|
||||||
mainName,
|
|
||||||
"READY",
|
|
||||||
sourceTag + " 已完成结构映射,待入库"
|
|
||||||
);
|
|
||||||
|
|
||||||
if (submitPreviewList.size() < safePreviewSize) {
|
if (submitPreviewList.size() < safePreviewSize) {
|
||||||
submitPreviewList.add(toPreviewSubmitBo(submitBo));
|
submitPreviewList.add(toPreviewSubmitBo(submitBo));
|
||||||
|
|
@ -183,11 +129,9 @@ public class ArtTestController extends BaseController {
|
||||||
List<ArtSchoolVo> artSchoolVos = artSchoolService.queryList(artSchoolBo);
|
List<ArtSchoolVo> artSchoolVos = artSchoolService.queryList(artSchoolBo);
|
||||||
if (!artSchoolVos.isEmpty()) {
|
if (!artSchoolVos.isEmpty()) {
|
||||||
// 修改
|
// 修改
|
||||||
artSchoolSubmitBo
|
artSchoolSubmitBo.getSchool().setSchoolId(artSchoolVos.get(0).getSchoolId());
|
||||||
.getSchool()
|
|
||||||
.setSchoolId(artSchoolVos.get(0).getSchoolId());
|
|
||||||
artSchoolService.updateWithDetailByBo(artSchoolSubmitBo);
|
artSchoolService.updateWithDetailByBo(artSchoolSubmitBo);
|
||||||
} else {
|
}else{
|
||||||
artSchoolService.insertWithDetailByBo(artSchoolSubmitBo);
|
artSchoolService.insertWithDetailByBo(artSchoolSubmitBo);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -198,9 +142,7 @@ public class ArtTestController extends BaseController {
|
||||||
previewVo.setReadFailCount(readFailCount);
|
previewVo.setReadFailCount(readFailCount);
|
||||||
previewVo.setDetails(details);
|
previewVo.setDetails(details);
|
||||||
previewVo.setSubmitPreviewList(submitPreviewList);
|
previewVo.setSubmitPreviewList(submitPreviewList);
|
||||||
previewVo.setServiceCallHint(
|
previewVo.setServiceCallHint("已预留调用: artSchoolService.insertWithDetailByBo(submitBo)");
|
||||||
"已预留调用: artSchoolService.insertWithDetailByBo(submitBo)"
|
|
||||||
);
|
|
||||||
return R.ok(previewVo);
|
return R.ok(previewVo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -246,13 +188,7 @@ public class ArtTestController extends BaseController {
|
||||||
return CollUtil.isNotEmpty(artSchoolDetailService.queryList(detailBo));
|
return CollUtil.isNotEmpty(artSchoolDetailService.queryList(detailBo));
|
||||||
}
|
}
|
||||||
|
|
||||||
private ArtSchoolSubmitBo buildSubmitBo(
|
private ArtSchoolSubmitBo buildSubmitBo(JsonNode node, String sourceTag, Integer univId, String mainCode, String mainName) {
|
||||||
JsonNode node,
|
|
||||||
String sourceTag,
|
|
||||||
Integer univId,
|
|
||||||
String mainCode,
|
|
||||||
String mainName
|
|
||||||
) {
|
|
||||||
ArtSchoolBo school = new ArtSchoolBo();
|
ArtSchoolBo school = new ArtSchoolBo();
|
||||||
school.setMainCode(mainCode);
|
school.setMainCode(mainCode);
|
||||||
school.setMainName(mainName);
|
school.setMainName(mainName);
|
||||||
|
|
@ -283,12 +219,8 @@ public class ArtTestController extends BaseController {
|
||||||
|
|
||||||
detail.setIs985(normalizeFlag(asInteger(node.get("is985"))));
|
detail.setIs985(normalizeFlag(asInteger(node.get("is985"))));
|
||||||
detail.setIs211(normalizeFlag(asInteger(node.get("is211"))));
|
detail.setIs211(normalizeFlag(asInteger(node.get("is211"))));
|
||||||
detail.setIsDoubleFirstClass(
|
detail.setIsDoubleFirstClass(normalizeFlag(asInteger(node.get("isFirstClass"))));
|
||||||
normalizeFlag(asInteger(node.get("isFirstClass")))
|
detail.setIsKeyUniversity(normalizeFlag(asInteger(node.get("isFirstLevel"))));
|
||||||
);
|
|
||||||
detail.setIsKeyUniversity(
|
|
||||||
normalizeFlag(asInteger(node.get("isFirstLevel")))
|
|
||||||
);
|
|
||||||
detail.setIsPublic(normalizeFlag(asInteger(node.get("isPublic"))));
|
detail.setIsPublic(normalizeFlag(asInteger(node.get("isPublic"))));
|
||||||
|
|
||||||
detail.setMasterProportionRate(asDecimal(node.get("masterProportion"))); // 考研率
|
detail.setMasterProportionRate(asDecimal(node.get("masterProportion"))); // 考研率
|
||||||
|
|
@ -298,9 +230,7 @@ public class ArtTestController extends BaseController {
|
||||||
detail.setHasJunior(normalizeFlag(asInteger(node.get("hasJunior")))); // 是否有专科
|
detail.setHasJunior(normalizeFlag(asInteger(node.get("hasJunior")))); // 是否有专科
|
||||||
detail.setHasMaster(normalizeFlag(asInteger(node.get("hasMaster")))); // 是否有研究生
|
detail.setHasMaster(normalizeFlag(asInteger(node.get("hasMaster")))); // 是否有研究生
|
||||||
|
|
||||||
detail.setIsDoubleHighPlan(
|
detail.setIsDoubleHighPlan(normalizeFlag(asInteger(node.get("isDoubleHighPlan")))); // 是否双高计划(专科用)
|
||||||
normalizeFlag(asInteger(node.get("isDoubleHighPlan")))
|
|
||||||
); // 是否双高计划(专科用)
|
|
||||||
detail.setIsStrongPlan(normalizeFlag(asInteger(node.get("isStrongPlan")))); // 是否强基计划
|
detail.setIsStrongPlan(normalizeFlag(asInteger(node.get("isStrongPlan")))); // 是否强基计划
|
||||||
detail.setTwsdlRank(normalizeFlag(asInteger(node.get("twsdl"))));
|
detail.setTwsdlRank(normalizeFlag(asInteger(node.get("twsdl"))));
|
||||||
detail.setXyhRank(normalizeFlag(asInteger(node.get("xyh"))));
|
detail.setXyhRank(normalizeFlag(asInteger(node.get("xyh"))));
|
||||||
|
|
@ -316,35 +246,6 @@ public class ArtTestController extends BaseController {
|
||||||
detail.setKeyMajorCount(resolveKeyMajorCount(node));
|
detail.setKeyMajorCount(resolveKeyMajorCount(node));
|
||||||
detail.setEmploymentRate(resolveEmploymentRate(node));
|
detail.setEmploymentRate(resolveEmploymentRate(node));
|
||||||
detail.setSatisfactionRate(resolveSatisfactionRate(node));
|
detail.setSatisfactionRate(resolveSatisfactionRate(node));
|
||||||
// 评分/满意度相关原始数据与明细保留,便于后续展示或二次计算
|
|
||||||
detail.setCombinedScore(asDecimal(node.get("combinedScore")));
|
|
||||||
detail.setOverallRank(asInteger(node.get("rank")));
|
|
||||||
detail.setEnvSatisfaction(asDecimal(node.get("envSatisfaction")));
|
|
||||||
detail.setEnvVote(asInteger(node.get("envVote")));
|
|
||||||
detail.setLiveSatisfaction(asDecimal(node.get("liveSatisfaction")));
|
|
||||||
detail.setLiveVote(asInteger(node.get("liveVote")));
|
|
||||||
detail.setCombinedSatisfaction(asDecimal(node.get("combinedSatisfaction")));
|
|
||||||
detail.setCombinedVote(asInteger(node.get("combinedVote")));
|
|
||||||
detail.setSatisfactionJson(toJsonString(node.get("satisfactionJson")));
|
|
||||||
detail.setTeachers(asText(node.get("teachers")));
|
|
||||||
detail.setScholarship(asText(node.get("scholarship")));
|
|
||||||
detail.setScholarshipJson(toJsonString(node.get("scholarshipArray")));
|
|
||||||
detail.setGrantDesc(asText(node.get("grant")));
|
|
||||||
detail.setCanteen(asText(node.get("canteen")));
|
|
||||||
detail.setDormitory(asText(node.get("dormitory")));
|
|
||||||
detail.setMasterExplain(asText(node.get("masterExplain")));
|
|
||||||
detail.setDoctorExplain(asText(node.get("doctorExplain")));
|
|
||||||
// 结构化内容以 JSON 文本落库,避免一次性拆表
|
|
||||||
detail.setSpecialMajorJson(toJsonString(node.get("specialMajor")));
|
|
||||||
detail.setEmploymentReportJson(toJsonString(node.get("employmentReport")));
|
|
||||||
detail.setPhotoJson(toJsonString(node.get("photoJson")));
|
|
||||||
detail.setAccommodationJson(toJsonString(node.get("accommodationArray")));
|
|
||||||
detail.setSubjectReviewsJson(toJsonString(node.get("subjectReviews")));
|
|
||||||
detail.setResearchJson(toJsonString(node.get("researchJson")));
|
|
||||||
detail.setUnivMajorsJson(toJsonString(node.get("univMajors")));
|
|
||||||
detail.setUnivPostgraduateJson(
|
|
||||||
toJsonString(node.get("univPostgraduateList"))
|
|
||||||
);
|
|
||||||
detail.setUnivId(univId);
|
detail.setUnivId(univId);
|
||||||
//detail.setRemark("source=" + sourceTag);
|
//detail.setRemark("source=" + sourceTag);
|
||||||
|
|
||||||
|
|
@ -364,9 +265,7 @@ public class ArtTestController extends BaseController {
|
||||||
if (college.has("majorList")) {
|
if (college.has("majorList")) {
|
||||||
for (JsonNode major : college.get("majorList")) {
|
for (JsonNode major : college.get("majorList")) {
|
||||||
artSchoolMajorBo = new ArtSchoolMajorBo();
|
artSchoolMajorBo = new ArtSchoolMajorBo();
|
||||||
artSchoolMajorBo.setEducationLevel(
|
artSchoolMajorBo.setEducationLevel("(本)".equals(asText(major.get("majorLevel"))) ? "1" : "0");
|
||||||
"(本)".equals(asText(major.get("majorLevel"))) ? "1" : "0"
|
|
||||||
);
|
|
||||||
artSchoolMajorBo.setMajorName(asText(major.get("majorName")));
|
artSchoolMajorBo.setMajorName(asText(major.get("majorName")));
|
||||||
artSchoolMajorBo.setMajor51sdxId(asText(major.get("majorId")));
|
artSchoolMajorBo.setMajor51sdxId(asText(major.get("majorId")));
|
||||||
schoolMajorBoList.add(artSchoolMajorBo);
|
schoolMajorBoList.add(artSchoolMajorBo);
|
||||||
|
|
@ -376,7 +275,20 @@ public class ArtTestController extends BaseController {
|
||||||
schoolCollegeBoList.add(schoolCollegeBo);
|
schoolCollegeBoList.add(schoolCollegeBo);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 其余结构化内容已映射到详情 JSON 字段
|
// 特色专业
|
||||||
|
node.get("specialMajor");
|
||||||
|
|
||||||
|
// 就业报告
|
||||||
|
node.get("employmentReport");
|
||||||
|
|
||||||
|
// 图片
|
||||||
|
node.get("photoJson");
|
||||||
|
|
||||||
|
// 建筑
|
||||||
|
node.get("accommodationArray");
|
||||||
|
|
||||||
|
// 学科评估
|
||||||
|
node.get("subjectReviews");
|
||||||
|
|
||||||
ArtSchoolSubmitBo submitBo = new ArtSchoolSubmitBo();
|
ArtSchoolSubmitBo submitBo = new ArtSchoolSubmitBo();
|
||||||
submitBo.setSchool(school);
|
submitBo.setSchool(school);
|
||||||
|
|
@ -473,16 +385,12 @@ public class ArtTestController extends BaseController {
|
||||||
if (guojiatese != null) {
|
if (guojiatese != null) {
|
||||||
return guojiatese;
|
return guojiatese;
|
||||||
}
|
}
|
||||||
return asInteger(
|
return asInteger(node.path("researchJson").path("base").get("重点专业数量"));
|
||||||
node.path("researchJson").path("base").get("重点专业数量")
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private BigDecimal resolveEmploymentRate(JsonNode node) {
|
private BigDecimal resolveEmploymentRate(JsonNode node) {
|
||||||
BigDecimal employmentRate = asDecimal(node.get("jiuyelu"));
|
BigDecimal employmentRate = asDecimal(node.get("jiuyelu"));
|
||||||
return employmentRate == null
|
return employmentRate == null ? null : employmentRate.setScale(2, RoundingMode.HALF_UP);
|
||||||
? null
|
|
||||||
: employmentRate.setScale(2, RoundingMode.HALF_UP);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private BigDecimal resolveSatisfactionRate(JsonNode node) {
|
private BigDecimal resolveSatisfactionRate(JsonNode node) {
|
||||||
|
|
@ -491,9 +399,7 @@ public class ArtTestController extends BaseController {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
if (score.compareTo(new BigDecimal("5")) <= 0) {
|
if (score.compareTo(new BigDecimal("5")) <= 0) {
|
||||||
return score
|
return score.multiply(new BigDecimal("20")).setScale(2, RoundingMode.HALF_UP);
|
||||||
.multiply(new BigDecimal("20"))
|
|
||||||
.setScale(2, RoundingMode.HALF_UP);
|
|
||||||
}
|
}
|
||||||
return score.setScale(2, RoundingMode.HALF_UP);
|
return score.setScale(2, RoundingMode.HALF_UP);
|
||||||
}
|
}
|
||||||
|
|
@ -502,9 +408,7 @@ public class ArtTestController extends BaseController {
|
||||||
if (femaleRatio == null) {
|
if (femaleRatio == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return new BigDecimal("100")
|
return new BigDecimal("100").subtract(femaleRatio).setScale(2, RoundingMode.HALF_UP);
|
||||||
.subtract(femaleRatio)
|
|
||||||
.setScale(2, RoundingMode.HALF_UP);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private String resolveEducationLevel(JsonNode node) {
|
private String resolveEducationLevel(JsonNode node) {
|
||||||
|
|
@ -582,9 +486,7 @@ public class ArtTestController extends BaseController {
|
||||||
if (node == null || node.isNull()) {
|
if (node == null || node.isNull()) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
String text = node.isNumber()
|
String text = node.isNumber() ? node.numberValue().toString() : asText(node);
|
||||||
? node.numberValue().toString()
|
|
||||||
: asText(node);
|
|
||||||
if (StringUtils.isBlank(text)) {
|
if (StringUtils.isBlank(text)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
@ -595,22 +497,7 @@ public class ArtTestController extends BaseController {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private String toJsonString(JsonNode node) {
|
private void appendDetail(List<ArtSchoolImportDetailVo> details, int maxSize, String mainCode, String mainName, String status, String message) {
|
||||||
if (node == null || node.isNull()) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
// 统一走 ObjectMapper 序列化,保持 JSON 原始结构
|
|
||||||
return JsonUtils.toJsonString(node);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void appendDetail(
|
|
||||||
List<ArtSchoolImportDetailVo> details,
|
|
||||||
int maxSize,
|
|
||||||
String mainCode,
|
|
||||||
String mainName,
|
|
||||||
String status,
|
|
||||||
String message
|
|
||||||
) {
|
|
||||||
if (details.size() >= maxSize) {
|
if (details.size() >= maxSize) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -621,4 +508,5 @@ public class ArtTestController extends BaseController {
|
||||||
detailVo.setMessage(message);
|
detailVo.setMessage(message);
|
||||||
details.add(detailVo);
|
details.add(detailVo);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,6 @@ import com.baomidou.mybatisplus.annotation.*;
|
||||||
import org.apache.ibatis.type.ArrayTypeHandler;
|
import org.apache.ibatis.type.ArrayTypeHandler;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
import org.dromara.art.handler.JsonbTypeHandler;
|
|
||||||
|
|
||||||
import java.io.Serial;
|
import java.io.Serial;
|
||||||
import java.math.BigDecimal;
|
import java.math.BigDecimal;
|
||||||
|
|
@ -246,139 +245,4 @@ public class ArtSchoolDetail extends TenantEntity {
|
||||||
* QS排名
|
* QS排名
|
||||||
*/
|
*/
|
||||||
private Integer qsdaluRank;
|
private Integer qsdaluRank;
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合评分
|
|
||||||
*/
|
|
||||||
private BigDecimal combinedScore;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合排名
|
|
||||||
*/
|
|
||||||
private Integer overallRank;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 环境满意度
|
|
||||||
*/
|
|
||||||
private BigDecimal envSatisfaction;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 环境满意度投票数
|
|
||||||
*/
|
|
||||||
private Integer envVote;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生活满意度
|
|
||||||
*/
|
|
||||||
private BigDecimal liveSatisfaction;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生活满意度投票数
|
|
||||||
*/
|
|
||||||
private Integer liveVote;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合满意度(原始分)
|
|
||||||
*/
|
|
||||||
private BigDecimal combinedSatisfaction;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合满意度投票数
|
|
||||||
*/
|
|
||||||
private Integer combinedVote;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 满意度明细JSON
|
|
||||||
*/
|
|
||||||
@TableField(typeHandler = JsonbTypeHandler.class)
|
|
||||||
private String satisfactionJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 师资力量描述
|
|
||||||
*/
|
|
||||||
private String teachers;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 奖学金说明
|
|
||||||
*/
|
|
||||||
private String scholarship;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 奖学金数组JSON
|
|
||||||
*/
|
|
||||||
@TableField(typeHandler = JsonbTypeHandler.class)
|
|
||||||
private String scholarshipJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 助学金说明
|
|
||||||
*/
|
|
||||||
private String grantDesc;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 食堂说明
|
|
||||||
*/
|
|
||||||
private String canteen;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 宿舍说明
|
|
||||||
*/
|
|
||||||
private String dormitory;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 硕士点说明
|
|
||||||
*/
|
|
||||||
private String masterExplain;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 博士点说明
|
|
||||||
*/
|
|
||||||
private String doctorExplain;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 特色专业JSON
|
|
||||||
*/
|
|
||||||
@TableField(typeHandler = JsonbTypeHandler.class)
|
|
||||||
private String specialMajorJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 就业报告JSON
|
|
||||||
*/
|
|
||||||
@TableField(typeHandler = JsonbTypeHandler.class)
|
|
||||||
private String employmentReportJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 图片JSON
|
|
||||||
*/
|
|
||||||
@TableField(typeHandler = JsonbTypeHandler.class)
|
|
||||||
private String photoJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 建筑/配套JSON
|
|
||||||
*/
|
|
||||||
@TableField(typeHandler = JsonbTypeHandler.class)
|
|
||||||
private String accommodationJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 学科评估JSON
|
|
||||||
*/
|
|
||||||
@TableField(typeHandler = JsonbTypeHandler.class)
|
|
||||||
private String subjectReviewsJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 科研信息JSON
|
|
||||||
*/
|
|
||||||
@TableField(typeHandler = JsonbTypeHandler.class)
|
|
||||||
private String researchJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 专业标签JSON
|
|
||||||
*/
|
|
||||||
@TableField(typeHandler = JsonbTypeHandler.class)
|
|
||||||
private String univMajorsJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 保研信息JSON
|
|
||||||
*/
|
|
||||||
@TableField(typeHandler = JsonbTypeHandler.class)
|
|
||||||
private String univPostgraduateJson;
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -233,129 +233,4 @@ public class ArtSchoolDetailBo extends BaseEntity {
|
||||||
* QS排名
|
* QS排名
|
||||||
*/
|
*/
|
||||||
private Integer qsdaluRank;
|
private Integer qsdaluRank;
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合评分
|
|
||||||
*/
|
|
||||||
private BigDecimal combinedScore;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合排名
|
|
||||||
*/
|
|
||||||
private Integer overallRank;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 环境满意度
|
|
||||||
*/
|
|
||||||
private BigDecimal envSatisfaction;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 环境满意度投票数
|
|
||||||
*/
|
|
||||||
private Integer envVote;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生活满意度
|
|
||||||
*/
|
|
||||||
private BigDecimal liveSatisfaction;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生活满意度投票数
|
|
||||||
*/
|
|
||||||
private Integer liveVote;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合满意度(原始分)
|
|
||||||
*/
|
|
||||||
private BigDecimal combinedSatisfaction;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合满意度投票数
|
|
||||||
*/
|
|
||||||
private Integer combinedVote;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 满意度明细JSON
|
|
||||||
*/
|
|
||||||
private String satisfactionJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 师资力量描述
|
|
||||||
*/
|
|
||||||
private String teachers;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 奖学金说明
|
|
||||||
*/
|
|
||||||
private String scholarship;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 奖学金数组JSON
|
|
||||||
*/
|
|
||||||
private String scholarshipJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 助学金说明
|
|
||||||
*/
|
|
||||||
private String grantDesc;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 食堂说明
|
|
||||||
*/
|
|
||||||
private String canteen;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 宿舍说明
|
|
||||||
*/
|
|
||||||
private String dormitory;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 硕士点说明
|
|
||||||
*/
|
|
||||||
private String masterExplain;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 博士点说明
|
|
||||||
*/
|
|
||||||
private String doctorExplain;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 特色专业JSON
|
|
||||||
*/
|
|
||||||
private String specialMajorJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 就业报告JSON
|
|
||||||
*/
|
|
||||||
private String employmentReportJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 图片JSON
|
|
||||||
*/
|
|
||||||
private String photoJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 建筑/配套JSON
|
|
||||||
*/
|
|
||||||
private String accommodationJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 学科评估JSON
|
|
||||||
*/
|
|
||||||
private String subjectReviewsJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 科研信息JSON
|
|
||||||
*/
|
|
||||||
private String researchJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 专业标签JSON
|
|
||||||
*/
|
|
||||||
private String univMajorsJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 保研信息JSON
|
|
||||||
*/
|
|
||||||
private String univPostgraduateJson;
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -194,239 +194,5 @@ public class ArtSchoolDetailVo implements Serializable {
|
||||||
@ExcelProperty(value = "备注")
|
@ExcelProperty(value = "备注")
|
||||||
private String remark;
|
private String remark;
|
||||||
|
|
||||||
/**
|
|
||||||
* 背景图
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "背景图")
|
|
||||||
private String backGround;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 是否公办:0否1是
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "是否公办")
|
|
||||||
private Integer isPublic;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 考研率
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "考研率")
|
|
||||||
private BigDecimal masterProportionRate;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 出国率
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "出国率")
|
|
||||||
private BigDecimal abroadProportionRate;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 是否有普通本科:0否1是
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "是否有普通本科")
|
|
||||||
private Integer hasRegular;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 是否有专科:0否1是
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "是否有专科")
|
|
||||||
private Integer hasJunior;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 是否有硕士点:0否1是
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "是否有硕士点")
|
|
||||||
private Integer hasMaster;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 是否双高计划:0否1是
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "是否双高计划")
|
|
||||||
private Integer isDoubleHighPlan;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 是否强基计划:0否1是
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "是否强基计划")
|
|
||||||
private Integer isStrongPlan;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 泰晤士中国排名
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "泰晤士中国排名")
|
|
||||||
private Integer twsdlRank;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 校友会排名
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "校友会排名")
|
|
||||||
private Integer xyhRank;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 武书连排名
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "武书连排名")
|
|
||||||
private Integer wslRank;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* US中国排名
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "US中国排名")
|
|
||||||
private Integer usdaluRank;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* QS排名
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "QS排名")
|
|
||||||
private Integer qsdaluRank;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合评分
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "综合评分")
|
|
||||||
private BigDecimal combinedScore;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合排名
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "综合排名")
|
|
||||||
private Integer overallRank;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 环境满意度
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "环境满意度")
|
|
||||||
private BigDecimal envSatisfaction;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 环境满意度投票数
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "环境满意度投票数")
|
|
||||||
private Integer envVote;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生活满意度
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "生活满意度")
|
|
||||||
private BigDecimal liveSatisfaction;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 生活满意度投票数
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "生活满意度投票数")
|
|
||||||
private Integer liveVote;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合满意度(原始分)
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "综合满意度(原始分)")
|
|
||||||
private BigDecimal combinedSatisfaction;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 综合满意度投票数
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "综合满意度投票数")
|
|
||||||
private Integer combinedVote;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 满意度明细JSON
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "满意度明细JSON")
|
|
||||||
private String satisfactionJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 师资力量描述
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "师资力量描述")
|
|
||||||
private String teachers;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 奖学金说明
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "奖学金说明")
|
|
||||||
private String scholarship;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 奖学金数组JSON
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "奖学金数组JSON")
|
|
||||||
private String scholarshipJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 助学金说明
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "助学金说明")
|
|
||||||
private String grantDesc;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 食堂说明
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "食堂说明")
|
|
||||||
private String canteen;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 宿舍说明
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "宿舍说明")
|
|
||||||
private String dormitory;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 硕士点说明
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "硕士点说明")
|
|
||||||
private String masterExplain;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 博士点说明
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "博士点说明")
|
|
||||||
private String doctorExplain;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 特色专业JSON
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "特色专业JSON")
|
|
||||||
private String specialMajorJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 就业报告JSON
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "就业报告JSON")
|
|
||||||
private String employmentReportJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 图片JSON
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "图片JSON")
|
|
||||||
private String photoJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 建筑/配套JSON
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "建筑/配套JSON")
|
|
||||||
private String accommodationJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 学科评估JSON
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "学科评估JSON")
|
|
||||||
private String subjectReviewsJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 科研信息JSON
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "科研信息JSON")
|
|
||||||
private String researchJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 专业标签JSON
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "专业标签JSON")
|
|
||||||
private String univMajorsJson;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 保研信息JSON
|
|
||||||
*/
|
|
||||||
@ExcelProperty(value = "保研信息JSON")
|
|
||||||
private String univPostgraduateJson;
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,7 +2,6 @@ package org.dromara.art.service;
|
||||||
|
|
||||||
import org.dromara.art.domain.vo.ArtSchoolDetailVo;
|
import org.dromara.art.domain.vo.ArtSchoolDetailVo;
|
||||||
import org.dromara.art.domain.bo.ArtSchoolDetailBo;
|
import org.dromara.art.domain.bo.ArtSchoolDetailBo;
|
||||||
import org.dromara.art.domain.ArtSchoolDetail;
|
|
||||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||||
|
|
||||||
|
|
@ -58,22 +57,6 @@ public interface IArtSchoolDetailService {
|
||||||
*/
|
*/
|
||||||
Boolean updateByBo(ArtSchoolDetailBo bo);
|
Boolean updateByBo(ArtSchoolDetailBo bo);
|
||||||
|
|
||||||
/**
|
|
||||||
* 按学校ID查询详情实体
|
|
||||||
*
|
|
||||||
* @param schoolId 学校ID
|
|
||||||
* @return 详情实体
|
|
||||||
*/
|
|
||||||
ArtSchoolDetail queryEntityBySchoolId(Long schoolId);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 按学校ID保存或更新详情实体(仅更新非空字段)
|
|
||||||
*
|
|
||||||
* @param detail 详情实体
|
|
||||||
* @return 是否成功
|
|
||||||
*/
|
|
||||||
Boolean saveOrUpdateBySchoolId(ArtSchoolDetail detail);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 校验并批量删除学校详细信息信息
|
* 校验并批量删除学校详细信息信息
|
||||||
*
|
*
|
||||||
|
|
|
||||||
|
|
@ -41,7 +41,7 @@ public class ArtSchoolDetailServiceImpl implements IArtSchoolDetailService {
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public ArtSchoolDetailVo queryById(Long detailId){
|
public ArtSchoolDetailVo queryById(Long detailId){
|
||||||
return stripJsonb(baseMapper.selectVoById(detailId));
|
return baseMapper.selectVoById(detailId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -55,9 +55,6 @@ public class ArtSchoolDetailServiceImpl implements IArtSchoolDetailService {
|
||||||
public TableDataInfo<ArtSchoolDetailVo> queryPageList(ArtSchoolDetailBo bo, PageQuery pageQuery) {
|
public TableDataInfo<ArtSchoolDetailVo> queryPageList(ArtSchoolDetailBo bo, PageQuery pageQuery) {
|
||||||
LambdaQueryWrapper<ArtSchoolDetail> lqw = buildQueryWrapper(bo);
|
LambdaQueryWrapper<ArtSchoolDetail> lqw = buildQueryWrapper(bo);
|
||||||
Page<ArtSchoolDetailVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
Page<ArtSchoolDetailVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||||
if (result.getRecords() != null) {
|
|
||||||
result.getRecords().forEach(this::stripJsonb);
|
|
||||||
}
|
|
||||||
return TableDataInfo.build(result);
|
return TableDataInfo.build(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -70,11 +67,7 @@ public class ArtSchoolDetailServiceImpl implements IArtSchoolDetailService {
|
||||||
@Override
|
@Override
|
||||||
public List<ArtSchoolDetailVo> queryList(ArtSchoolDetailBo bo) {
|
public List<ArtSchoolDetailVo> queryList(ArtSchoolDetailBo bo) {
|
||||||
LambdaQueryWrapper<ArtSchoolDetail> lqw = buildQueryWrapper(bo);
|
LambdaQueryWrapper<ArtSchoolDetail> lqw = buildQueryWrapper(bo);
|
||||||
List<ArtSchoolDetailVo> list = baseMapper.selectVoList(lqw);
|
return baseMapper.selectVoList(lqw);
|
||||||
if (list != null) {
|
|
||||||
list.forEach(this::stripJsonb);
|
|
||||||
}
|
|
||||||
return list;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private LambdaQueryWrapper<ArtSchoolDetail> buildQueryWrapper(ArtSchoolDetailBo bo) {
|
private LambdaQueryWrapper<ArtSchoolDetail> buildQueryWrapper(ArtSchoolDetailBo bo) {
|
||||||
|
|
@ -139,48 +132,6 @@ public class ArtSchoolDetailServiceImpl implements IArtSchoolDetailService {
|
||||||
return baseMapper.updateById(update) > 0;
|
return baseMapper.updateById(update) > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public ArtSchoolDetail queryEntityBySchoolId(Long schoolId) {
|
|
||||||
if (schoolId == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
return baseMapper.selectOne(Wrappers.<ArtSchoolDetail>lambdaQuery()
|
|
||||||
.eq(ArtSchoolDetail::getSchoolId, schoolId), false);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Boolean saveOrUpdateBySchoolId(ArtSchoolDetail detail) {
|
|
||||||
if (detail == null || detail.getSchoolId() == null) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (detail.getDetailId() != null) {
|
|
||||||
return baseMapper.updateById(detail) > 0;
|
|
||||||
}
|
|
||||||
ArtSchoolDetail exist = queryEntityBySchoolId(detail.getSchoolId());
|
|
||||||
if (exist == null) {
|
|
||||||
return baseMapper.insert(detail) > 0;
|
|
||||||
}
|
|
||||||
detail.setDetailId(exist.getDetailId());
|
|
||||||
return baseMapper.updateById(detail) > 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
private ArtSchoolDetailVo stripJsonb(ArtSchoolDetailVo vo) {
|
|
||||||
if (vo == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
vo.setSatisfactionJson(null);
|
|
||||||
vo.setScholarshipJson(null);
|
|
||||||
vo.setSpecialMajorJson(null);
|
|
||||||
vo.setEmploymentReportJson(null);
|
|
||||||
vo.setPhotoJson(null);
|
|
||||||
vo.setAccommodationJson(null);
|
|
||||||
vo.setSubjectReviewsJson(null);
|
|
||||||
vo.setResearchJson(null);
|
|
||||||
vo.setUnivMajorsJson(null);
|
|
||||||
vo.setUnivPostgraduateJson(null);
|
|
||||||
return vo;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 保存前的数据校验
|
* 保存前的数据校验
|
||||||
*/
|
*/
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue