Compare commits
495 Commits
8fbca1a898
...
test
| Author | SHA1 | Date | |
|---|---|---|---|
| 700e353b79 | |||
| 0b2c19d2c5 | |||
| 47394de43c | |||
| f0f1dde6b6 | |||
| 1ab1165697 | |||
| a8f1b1fdfa | |||
| 3b94d19199 | |||
| db1139a14f | |||
|
|
bea74aeac2 | ||
|
|
634a1f45f9 | ||
| 8f1ad3307c | |||
| d8080fa22d | |||
|
|
e8783d9f8f | ||
| d8c4348341 | |||
|
|
8e61490005 | ||
| f5f4e3c48e | |||
| 0f013715b8 | |||
| fb9722d328 | |||
| 6f9192d30d | |||
| f2b5b90f34 | |||
| a2cbd5e583 | |||
| d3df46858b | |||
| 47a7a945bc | |||
| 0a56c0dcf0 | |||
| 15d32134e2 | |||
| eff98ea5eb | |||
| a47306825a | |||
|
|
9b35fec931 | ||
| e20e2b637f | |||
| ebd2e8aa75 | |||
| cb268fe26d | |||
| 23bd49d940 | |||
| 32adb984e2 | |||
| c1d453600b | |||
| 02eab2d932 | |||
| d5c8b7a1ad | |||
|
|
4053064a22 | ||
|
|
089e28f913 | ||
| cf9ab03b17 | |||
| d332650bfa | |||
| 840983ac94 | |||
|
|
86673d7be3 | ||
|
|
3753a916f5 | ||
|
|
0556f77870 | ||
|
|
b185c156ca | ||
|
|
a48308dcbf | ||
| e37f6a70f9 | |||
|
|
28629ccd35 | ||
|
|
fbd7f0be78 | ||
|
|
763f05da84 | ||
|
|
8c74d45332 | ||
| 8d62c0461b | |||
| 58936c957d | |||
| 062c4a92b8 | |||
| fb9f85e967 | |||
| 38ef377cbd | |||
| 240d5dc3f7 | |||
| 82702f16e0 | |||
| 0b4b63dfbe | |||
| b4422a0dca | |||
| d8627df2dd | |||
| 09ca077559 | |||
| 3091fc7337 | |||
| b0850257c8 | |||
| fa2884b320 | |||
| 941054734f | |||
| 8d69dc3c00 | |||
| 2157806ba5 | |||
| 2236cbea36 | |||
| 2128e717e7 | |||
| 1311e87e13 | |||
| ddf1553846 | |||
| 5d82800976 | |||
| 0c35044231 | |||
| 61f4020487 | |||
| aeb6b95970 | |||
| b5ce854eb6 | |||
| 4d4828ea71 | |||
| 10e738edd9 | |||
| 88a4e58130 | |||
| 76c324b0df | |||
| a65e8dd2cc | |||
| 1ac9b5ae0b | |||
| 8f77fe8bc9 | |||
| b567747901 | |||
| ed7004ae85 | |||
| d1670b79a0 | |||
| 54cde91aac | |||
| 7974bdc51c | |||
| 91cb465962 | |||
| 1b2c248fa2 | |||
| 1c16d6ba0f | |||
| 49b8a975a8 | |||
| d17a502da1 | |||
| 430adc2112 | |||
| 5f5c47f528 | |||
| 92d74c47ce | |||
| 5d8e7b667f | |||
| 58449fc2f9 | |||
| 4c541f43b9 | |||
| 9a037ae446 | |||
| bb0eb60eae | |||
| cf5dbc6133 | |||
| 5f6fa50000 | |||
| 08b2e76d47 | |||
| 5ffeab8999 | |||
| fc6640b846 | |||
| 8e11dde7c0 | |||
| e8f24ee290 | |||
| a1e07a204b | |||
| a080b4294c | |||
| 0827ce2908 | |||
| 5f600209b8 | |||
| 79ea4ed4f7 | |||
| cbd3e7f981 | |||
| 3c497417dc | |||
| 088861f66e | |||
| 8914c8b143 | |||
| 8c607c8749 | |||
| 3115e38cc4 | |||
| ae6c486114 | |||
| a41ffa4cfc | |||
| b1f74161f8 | |||
| 3bab56a19b | |||
| abc0674531 | |||
| 85fcb7c2e2 | |||
| fc6a7437a3 | |||
| 999a0992e7 | |||
| 55b3dfc077 | |||
|
|
32d1673667 | ||
| 17c7cc70ed | |||
| 44be570ffa | |||
| c6f4996ba7 | |||
| 6c20b15339 | |||
| c297072b36 | |||
| 4c6886be6a | |||
| 8beb7f3d3d | |||
| 91968530b4 | |||
| 0833f82fb4 | |||
| cce71f324b | |||
| ee6efafde4 | |||
| 2051807ecf | |||
| 0a4de15599 | |||
| 25b3c26ec2 | |||
| 91d673de77 | |||
| 0bfa7183f9 | |||
| 79d451931d | |||
| ae5f1c795b | |||
| c1074fc4fb | |||
| e832b6d38e | |||
| 5043466e84 | |||
| fcaeedb543 | |||
| 8cf434a46f | |||
| bfbc061b0b | |||
| f92cd830e9 | |||
| a7a1a18445 | |||
| d1331cd4e1 | |||
| 37d08b8545 | |||
| e69f499ac0 | |||
| 3baf7161f1 | |||
| 85188651ca | |||
| d6fbfb1427 | |||
| 966847499a | |||
| 1e91171001 | |||
| 51f495f81e | |||
| 1e6a5972b9 | |||
| 515f03a5cd | |||
| b27542ba6d | |||
| 4790855079 | |||
| 72cf9c6f2d | |||
| 19ecb65183 | |||
| d85a8684a6 | |||
| 574a9267bf | |||
| 27a7396c78 | |||
| 633cf2c17f | |||
| 3188ca5752 | |||
| c79e4c2623 | |||
| f3c451d0a1 | |||
| a077bd57d4 | |||
| cf16c497bd | |||
| fd1ab239a9 | |||
| caf65e3113 | |||
| c18c21ff4c | |||
| ab6849c9eb | |||
| 6b555f2563 | |||
| 7645405c5b | |||
| 5bfadb9174 | |||
| e1b9d36153 | |||
| fdb8d6c934 | |||
| 22a1ac57b2 | |||
| 4d243815a6 | |||
| 882e8c9199 | |||
| a0c87f6335 | |||
| 538dde55f7 | |||
| f33e3c6f15 | |||
| 0794782505 | |||
| d37fa46b5f | |||
| 8fcc229ad8 | |||
| 39aa710fd3 | |||
| 49f95b40ea | |||
| eb2d7302b7 | |||
| eb26f9db34 | |||
| bd6f3ca587 | |||
| a58e02f2cb | |||
| 8c8ef13021 | |||
| d9a0a98f52 | |||
| 8c84b6eb46 | |||
| 3d797cc0e0 | |||
| df7281a2d4 | |||
| f83d7ae520 | |||
| d9c8525b94 | |||
| bcc5cbb2fb | |||
| 67a8351d70 | |||
| 391506e423 | |||
| b1117b4157 | |||
| b0eb9861b9 | |||
| b863c14f2b | |||
| 18f6a845e6 | |||
| e1385cb3e6 | |||
| c8ca56c3f5 | |||
| b149f7d687 | |||
| 19702c25e5 | |||
|
|
eaa681c9ff | ||
| 205c58782b | |||
| 00e1c62de0 | |||
| 46c9787216 | |||
| e0a768de2e | |||
| fc7f931728 | |||
|
|
3ccb970a09 | ||
|
|
8a9a622aeb | ||
|
|
29e7f0937b | ||
| 029d534b3c | |||
|
|
213723b220 | ||
|
|
c636e77fd0 | ||
|
|
7407562ec5 | ||
|
|
b3c27ec789 | ||
|
|
601ae40666 | ||
| 3dda5ce72d | |||
|
|
99d4c28b95 | ||
|
|
0e70de6de7 | ||
| 72eb1088df | |||
| a853c16854 | |||
| 73a349f98a | |||
| 5fb7a3f488 | |||
| a8eb7d5697 | |||
| eb3b142ce4 | |||
| 9f6a39ba30 | |||
| f7f2f98bbe | |||
| 79e68ee14e | |||
| bc8987c463 | |||
| 3f7174fcd1 | |||
| 080008f447 | |||
| 5c3d935615 | |||
| a0845127c6 | |||
| ba65ab303b | |||
|
|
6fbdddf0ee | ||
| 173cbc7f87 | |||
|
|
2e341a123e | ||
|
|
8beff2ee14 | ||
| 1b939ba5b7 | |||
| 577daabe1c | |||
| 327e88e6d4 | |||
|
|
548fabcffe | ||
| 263e21e157 | |||
| d7955aa628 | |||
|
|
d197f7555f | ||
| a0e52da437 | |||
|
|
88d79729fe | ||
| 6dc6480e64 | |||
| 98c263a72b | |||
| 50a2ef9e00 | |||
| 065f7052c6 | |||
| e23d42404d | |||
| 4120d4e001 | |||
| 1bd2089047 | |||
| 6d9ff7dc10 | |||
| ae7ca984f8 | |||
| 69b7a4d865 | |||
| 864bf55025 | |||
| 249ef5f87e | |||
|
|
df3fb6c66c | ||
|
|
10ec9f4c1b | ||
| 0b98763c05 | |||
|
|
3d3b21a775 | ||
|
|
4ba4f80946 | ||
|
|
ed7cb2dab5 | ||
| 50ef9e6743 | |||
| 250d7dde34 | |||
| 69f3e066db | |||
|
|
afb0c3933c | ||
|
|
45ac07e57c | ||
|
|
262ea97824 | ||
|
|
dcfa13f239 | ||
|
|
27c3c850d6 | ||
| 122a15a73d | |||
| 61749aee4d | |||
| 97a29a31c5 | |||
| c3734f921c | |||
| c561586cfa | |||
|
|
60593233bc | ||
| 992b03f9c2 | |||
| 36628342dc | |||
|
|
3783e4a872 | ||
| 584f79294b | |||
| a5884ec069 | |||
| cc2f7db754 | |||
| fcccfc1959 | |||
| c5ec91e7d3 | |||
| 6b67e25d94 | |||
| 6da3b63012 | |||
|
|
ea0f0e2294 | ||
|
|
980f0aeb9c | ||
|
|
17b40118ce | ||
|
|
d10a78e5e8 | ||
|
|
f7ad010b2a | ||
|
|
1a7ff0a686 | ||
|
|
3ad3f21362 | ||
|
|
c84fc3c236 | ||
|
|
a6561e2ca6 | ||
|
|
dfe35bb7f0 | ||
| 18c96e006f | |||
| f5db504363 | |||
| deb31c969a | |||
| e7dac9762d | |||
|
|
89862878b5 | ||
|
|
e105919dab | ||
|
|
e83fc94334 | ||
| 5bf7ab481f | |||
| afa904bd83 | |||
| a343464d8d | |||
| 4a2485e434 | |||
|
|
4e2d4d85ec | ||
| 7ddf6211ee | |||
| d44600b641 | |||
| a68c4402de | |||
| 93103f7f40 | |||
| 7202151a41 | |||
| 491d8f8930 | |||
| b886726ecc | |||
|
|
9d0dde6794 | ||
|
|
f3578b3202 | ||
|
|
0610ba7cb5 | ||
|
|
8b848f787a | ||
| a794cd0ce3 | |||
|
|
d97fd0bed1 | ||
|
|
c0e67722d9 | ||
|
|
aca7fea69f | ||
| ce9344f9ce | |||
| 991ad61655 | |||
|
|
e4ac857461 | ||
|
|
24ab98ae89 | ||
| e79ab9ac4f | |||
| b66c2027d1 | |||
| 09bf895711 | |||
|
|
825cdd58ae | ||
| 0977eb8145 | |||
|
|
73efeecfc1 | ||
| fe8fb3d321 | |||
|
|
618fb1e340 | ||
|
|
215fe8b889 | ||
|
|
3e32458b7f | ||
| a8e170ea45 | |||
| 1856ae50fd | |||
| 1711e6c115 | |||
|
|
b3f226feab | ||
| c086dc8c77 | |||
| 6762341fbd | |||
| d5f8b0f23b | |||
|
|
38233110f2 | ||
| 6ebb59bc5e | |||
| 69aefab280 | |||
| 3d3ff82e24 | |||
| 69780d204f | |||
|
|
ef52f290fe | ||
| e9d1119777 | |||
|
|
cf182f0e34 | ||
|
|
626ae1a459 | ||
| 3d6977328f | |||
| 2dcd7ba1d5 | |||
|
|
16a4d38113 | ||
| 57c98ea39d | |||
| 08f7e35042 | |||
| 43f3d1ba94 | |||
| 2e45c6c029 | |||
| 945182c6f8 | |||
|
|
f7de87860b | ||
| 67e4de0d68 | |||
|
|
602d521424 | ||
|
|
01e14ee084 | ||
|
|
4a5572de26 | ||
| 88a516d1be | |||
| 9ce967002a | |||
| fd536a035e | |||
| df84a7eefa | |||
| 2804703eaa | |||
| e14a0e3d13 | |||
| 5a99fe8234 | |||
| 3ad5c5533f | |||
|
|
9997f4f7c9 | ||
|
|
3d4e4a8119 | ||
|
|
3deac74898 | ||
| 7bbc50ef47 | |||
| 4ae6765a15 | |||
| 1292853c5d | |||
|
|
41791c9ccc | ||
|
|
0674215b53 | ||
| e42d990304 | |||
| 0dbe9a57c8 | |||
| 85ea831a1c | |||
| 7ac26cf781 | |||
| b7412648b4 | |||
|
|
97571652e5 | ||
| b5d4da97f9 | |||
|
|
e5edb6bda2 | ||
|
|
0e1ae53194 | ||
| a1efd3f91b | |||
| 3211553d0d | |||
| a57a326b83 | |||
| f77d0a2567 | |||
| 72581466aa | |||
|
|
4b3471df06 | ||
|
|
68c65ae8bd | ||
| 1b879addc7 | |||
|
|
3888859b2b | ||
|
|
f03d2e1633 | ||
| bc91eb7cdc | |||
|
|
93120e973a | ||
| c6a27f6276 | |||
| 778704c9dc | |||
| ff227b40c1 | |||
| c7d8ab5b48 | |||
| 9c27b2a134 | |||
|
|
3f919188d2 | ||
| 8942058972 | |||
|
|
6c2dbf0418 | ||
|
|
85e185bab8 | ||
|
|
88aa1517ef | ||
|
|
c05118c427 | ||
|
|
2a7f1326b9 | ||
|
|
c07255fe5b | ||
|
|
749bfc89dd | ||
| 52cc5e3aae | |||
| 642c4a0941 | |||
| 30953d5771 | |||
| 83e0c663c9 | |||
| b19337e76a | |||
| ba607346bd | |||
|
|
433c452a40 | ||
|
|
a1be7fdbfd | ||
|
|
87409d0c93 | ||
| d5c8ae8d45 | |||
| bc45e9c8c6 | |||
|
|
42992382c0 | ||
|
|
22d7eba510 | ||
| 9728c8a6dd | |||
| c951144ac6 | |||
|
|
0b179fffd6 | ||
|
|
75374ac5d3 | ||
|
|
2a83719b87 | ||
|
|
e58f2d807b | ||
|
|
b2884def17 | ||
|
|
064840dd42 | ||
| 1aa814c766 | |||
|
|
b9719a51d1 | ||
|
|
03b83aaf7c | ||
|
|
d93976483b | ||
| dd0a3a915c | |||
| 2f3994c575 | |||
| daa78e128f | |||
| 2ca594cb39 | |||
|
|
7805c26f4a | ||
|
|
b7d34537c2 | ||
| c1213fcf59 | |||
| a64edace55 | |||
| 4afe0d107c | |||
|
|
d8af11412f | ||
|
|
00816c9834 | ||
|
|
4fb7bea80a | ||
|
|
0fc72cb270 | ||
|
|
eadf521903 | ||
| f786fdbc3f | |||
| 92c4c938a3 | |||
|
|
a94a1b7b69 | ||
|
|
48755c2d9e | ||
|
|
f99f8eb560 | ||
|
|
ddc7ce2fe7 | ||
|
|
c9899c62d2 | ||
| 8b9837d7dc | |||
| 2cba41331a | |||
| 4da5ca427b | |||
| f4605b1af7 | |||
|
|
d2babdc9ed | ||
| 4d0599eac1 | |||
|
|
35d99df274 | ||
|
|
ce76b2f98d |
76
.github/copilot-instructions.md
vendored
Normal file
76
.github/copilot-instructions.md
vendored
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
# OpenHIS — AI 编码助手 指南
|
||||||
|
|
||||||
|
目的:帮助自动化/AI 编码代理快速上手本仓库,包含架构要点、关键文件、常用构建/运行命令以及项目约定。请只按照仓库内真实可见的内容提出修改建议或补充说明。
|
||||||
|
|
||||||
|
- **代码组织**: 本项目是一个 Java 后端(多模块 Maven)+ Vue3 前端(Vite)的大型应用。
|
||||||
|
- 后端主模块目录:`openhis-server-new/`(顶层为 `pom`,包含多个子模块)。关键子模块示例:`openhis-application`, `openhis-domain`, `openhis-common`, `core-*` 系列。
|
||||||
|
- 前端目录:`openhis-ui-vue3/`(Vite + Vue 3,使用 Pinia、Element Plus 等)。
|
||||||
|
|
||||||
|
- **大局观(Big Picture)**: 后端以 Spring Boot(Java 17)实现,使用多模块 Maven 管理公共库与业务模块;前端由单独仓库目录通过 Vite 构建并以环境变量(`VITE_APP_BASE_API`)与后端交互。后端扫描 `com.core` 与 `com.openhis` 包(见 `OpenHisApplication.java`),启动类位于:`openhis-server-new/openhis-application/src/main/java/com/openhis/OpenHisApplication.java`。
|
||||||
|
|
||||||
|
- **运行/构建(Windows PowerShell 示例)**:
|
||||||
|
- 构建后端(从仓库根执行):
|
||||||
|
|
||||||
|
```powershell
|
||||||
|
cd openhis-server-new
|
||||||
|
mvn clean package -DskipTests
|
||||||
|
```
|
||||||
|
|
||||||
|
- 仅运行后端模块(开发时常用):
|
||||||
|
|
||||||
|
```powershell
|
||||||
|
cd openhis-server-new/openhis-application
|
||||||
|
mvn spring-boot:run
|
||||||
|
# 或在 IDE 中运行 `com.openhis.OpenHisApplication` 的 main()
|
||||||
|
```
|
||||||
|
|
||||||
|
- 前端启动与构建(需要 Node.js v16.x,仓库 README 建议 v16.15):
|
||||||
|
|
||||||
|
```powershell
|
||||||
|
cd openhis-ui-vue3
|
||||||
|
npm install
|
||||||
|
npm run dev # 本地开发(热重载)
|
||||||
|
npm run build:prod # 生产构建
|
||||||
|
```
|
||||||
|
|
||||||
|
- **环境与配置**:
|
||||||
|
- 后端配置:`openhis-server-new/openhis-application/src/main/resources/application.yml`(数据库、端口、profile 等)。README 还提及 `application-druid.yml`(若存在请优先查看)。
|
||||||
|
- 前端配置:多个 `.env.*` 文件(例如 `.env.development`, `.env.staging`, `.env.production`),关键变量:`VITE_APP_BASE_API`(例如 `/dev-api`),前端通过 `import.meta.env.VITE_APP_BASE_API` 拼接后端 URL(见 `src/utils/request.js`、多个视图与组件)。
|
||||||
|
|
||||||
|
- **重要约定 / 模式**:
|
||||||
|
- 后端采用 Java 17、Spring Boot 2.5.x 家族,父 POM在 `openhis-server-new/pom.xml` 定义。常用依赖版本在该 POM 的 `<properties>` 中集中维护。
|
||||||
|
- 模块间以 Maven 模块依赖与 `com.core` / `com.openhis` 包名分层(见 `pom.xml` 的 `<modules>` 与 `dependencyManagement`)。
|
||||||
|
- 前端通过 Vite 插件配置(`openhis-ui-vue3/vite/plugins`)管理 svg、自动导入等。UI 框架为 Element Plus,状态管理为 Pinia。
|
||||||
|
|
||||||
|
- **集成点 & 外部依赖**:
|
||||||
|
- 数据库:PostgreSQL(README 建议 v16.2),仓库根含一个大型初始化 SQL:`数据库初始话脚本(请使用navicat16版本导入).sql`,用于初始化表与演示数据。
|
||||||
|
- 缓存/会话:Redis(需自行配置)。
|
||||||
|
- 其他:Flowable(工作流),Druid(连接池监控),第三方服务通过特定配置类(例如 `YbServiceConfig` 在 `OpenHisApplication` 中启用)。
|
||||||
|
|
||||||
|
- **调试与常见位置**:
|
||||||
|
- 启动类:`openhis-server-new/openhis-application/src/main/java/com/openhis/OpenHisApplication.java`。
|
||||||
|
- 全局配置:`openhis-server-new/openhis-application/src/main/resources/`(`application.yml`、profile 文件等)。
|
||||||
|
- 前端入口:`openhis-ui-vue3/src/main.js`、路由在 `openhis-ui-vue3/src/router/index.js`。
|
||||||
|
- API 文档与监控路径(通常由后端暴露并被前端访问):
|
||||||
|
- Swagger UI: `<VITE_APP_BASE_API>/swagger-ui/index.html`(前端视图在 `src/views/tool/swagger/index.vue`)。
|
||||||
|
- Druid: `<VITE_APP_BASE_API>/druid/login.html`(见前端相关视图引用)。
|
||||||
|
|
||||||
|
- **为 AI 代理的具体建议(如何安全、有效地修改代码)**:
|
||||||
|
- 修改后端时:优先在子模块(例如 `openhis-application`)本地运行 `mvn spring-boot:run` 验证启动与基础 API;大量改动前先执行 `mvn -T1C -DskipTests clean package` 在 CI 环境上验证构建(本地机器也可用)。
|
||||||
|
- 修改前端时:检查/调整对应 `.env.*` 文件中的 `VITE_APP_BASE_API`,使用 `npm run dev` 本地联调后端接口(可通过代理或将 `VITE_APP_BASE_API` 指向后端地址)。
|
||||||
|
- 修改数据库结构或 seed:请参考仓库根的 SQL 初始化脚本,任何 DDL/数据变更需同步该脚本并通知数据库管理员/运维。
|
||||||
|
|
||||||
|
- **举例(常见任务示例)**:
|
||||||
|
- 本地联调前端 + 后端(PowerShell):
|
||||||
|
|
||||||
|
```powershell
|
||||||
|
# 启动后端
|
||||||
|
cd openhis-server-new/openhis-application
|
||||||
|
mvn spring-boot:run
|
||||||
|
|
||||||
|
# 启动前端(另开终端)
|
||||||
|
cd openhis-ui-vue3
|
||||||
|
npm run dev
|
||||||
|
```
|
||||||
|
|
||||||
|
如需我把这些内容合并为更短或更详细的版本,或把其中某部分(例如后端模块依赖关系图、关键 Java 包说明)展开,请告诉我要增强哪一节。
|
||||||
5
.gitignore
vendored
5
.gitignore
vendored
@@ -58,3 +58,8 @@
|
|||||||
PostgreSQL/openHis_DB设计书.xlsx
|
PostgreSQL/openHis_DB设计书.xlsx
|
||||||
|
|
||||||
public.sql
|
public.sql
|
||||||
|
发版记录/2025-11-12/~$发版日志.docx
|
||||||
|
发版记录/2025-11-12/~$S-管理系统-调价管理.docx
|
||||||
|
发版记录/2025-11-12/发版日志.docx
|
||||||
|
.gitignore
|
||||||
|
openhis-server-new/openhis-application/src/main/resources/application-dev.yml
|
||||||
|
|||||||
26
.trae/documents/plan_20251231_062502.md
Normal file
26
.trae/documents/plan_20251231_062502.md
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
# 修复门诊预约界面专家号查询结果显示问题
|
||||||
|
|
||||||
|
## 问题分析
|
||||||
|
1. 前端传递的参数正确:`type=expert`,后端正确转换为`ticketType=专家`
|
||||||
|
2. 实际查询返回了5条记录,但COUNT查询只返回了1条记录
|
||||||
|
3. 这导致前端只显示了1条记录,而不是全部5条
|
||||||
|
4. 原因:MyBatis-Plus自动生成的COUNT查询和实际查询使用了不同的条件,特别是逻辑删除条件
|
||||||
|
|
||||||
|
## 解决方案
|
||||||
|
1. 修改TicketMapper.xml中的自定义COUNT查询,显式添加`delete_flag = '0'`条件
|
||||||
|
2. 在selectTicketPage和selectTicketPage_mpCount查询中都添加逻辑删除条件
|
||||||
|
3. 确保两个查询使用完全相同的WHERE条件
|
||||||
|
|
||||||
|
## 修复步骤
|
||||||
|
1. 修改`selectTicketPage`查询,添加逻辑删除条件`and delete_flag = '0'`
|
||||||
|
2. 修改`selectTicketPage_mpCount`查询,添加逻辑删除条件`and delete_flag = '0'`
|
||||||
|
3. 确保两个查询的WHERE条件完全一致
|
||||||
|
4. 测试修复后的功能,确保专家号能正确显示全部5条记录
|
||||||
|
|
||||||
|
## 代码修改点
|
||||||
|
- 文件:`d:/work/openhis-server-new/openhis-domain/src/main/resources/mapper/clinical/TicketMapper.xml`
|
||||||
|
- 查询:`selectTicketPage` 和 `selectTicketPage_mpCount`
|
||||||
|
- 修改内容:添加逻辑删除条件`and delete_flag = '0'`
|
||||||
|
|
||||||
|
## 预期效果
|
||||||
|
修复后,COUNT查询和实际查询将使用完全相同的条件,包括逻辑删除条件,从而确保COUNT查询返回正确的总记录数,前端能显示所有5条专家号记录。
|
||||||
30
.trae/documents/plan_20251231_063300.md
Normal file
30
.trae/documents/plan_20251231_063300.md
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
# 修复门诊预约界面专家号查询COUNT结果不正确问题
|
||||||
|
|
||||||
|
## 问题分析
|
||||||
|
1. 前端传递的参数正确:`type=expert`,后端正确转换为`ticketType=专家`
|
||||||
|
2. COUNT查询和实际查询的WHERE条件完全相同:`WHERE delete_flag = '0' AND ticket_type = '专家'`
|
||||||
|
3. 但COUNT查询只返回1条记录,而实际查询返回5条记录
|
||||||
|
4. 原因:MyBatis-Plus的分页插件在处理自定义COUNT查询时,存在bug,导致COUNT查询结果不正确
|
||||||
|
|
||||||
|
## 解决方案
|
||||||
|
修改`TicketAppServiceImpl.java`中的`listTicket`方法,不使用MyBatis-Plus的自动分页功能,而是手动实现分页查询:
|
||||||
|
1. 直接调用`ticketService.countTickets`方法获取总记录数
|
||||||
|
2. 手动构建查询条件
|
||||||
|
3. 确保COUNT查询和实际查询使用完全相同的条件
|
||||||
|
|
||||||
|
## 修复步骤
|
||||||
|
1. 修改`TicketAppServiceImpl.java`中的`listTicket`方法
|
||||||
|
2. 手动实现分页查询,包括:
|
||||||
|
- 构建查询条件
|
||||||
|
- 调用`countTickets`获取总记录数
|
||||||
|
- 调用`selectTicketList`获取分页数据
|
||||||
|
- 手动组装分页结果
|
||||||
|
3. 测试修复后的功能,确保专家号能正确显示全部5条记录
|
||||||
|
|
||||||
|
## 代码修改点
|
||||||
|
- 文件:`d:/work/openhis-server-new/openhis-application/src/main/java/com/openhis/web/appointmentmanage/appservice/impl/TicketAppServiceImpl.java`
|
||||||
|
- 方法:`listTicket`
|
||||||
|
- 修改内容:替换MyBatis-Plus的自动分页,改为手动分页实现
|
||||||
|
|
||||||
|
## 预期效果
|
||||||
|
修复后,COUNT查询和实际查询将使用完全相同的条件,COUNT查询将返回正确的总记录数(5条),前端能显示所有5条专家号记录。
|
||||||
32
.trae/documents/修复号源列表显示问题.md
Normal file
32
.trae/documents/修复号源列表显示问题.md
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
## 问题分析
|
||||||
|
根据日志和代码分析,发现号源列表显示"没有更多数据了"的问题原因:
|
||||||
|
|
||||||
|
1. **后端查询正常**:成功查询到5条符合条件的专家号源记录
|
||||||
|
2. **数据转换失败**:在`convertToDto`方法中,`fee`字段类型转换错误
|
||||||
|
3. **响应返回空列表**:由于转换异常,最终返回给前端的号源列表为空
|
||||||
|
|
||||||
|
## 问题根源
|
||||||
|
- `Ticket`实体类的`fee`字段为**BigDecimal类型**(数据库存储)
|
||||||
|
- `TicketDto`类的`fee`字段为**String类型**(前端展示)
|
||||||
|
- 在`convertToDto`方法中,直接将BigDecimal类型的`fee`赋值给String类型的`fee`,导致**ClassCastException**
|
||||||
|
|
||||||
|
## 修复方案
|
||||||
|
修改`TicketAppServiceImpl.java`文件中的`convertToDto`方法,将BigDecimal类型的`fee`转换为String类型:
|
||||||
|
|
||||||
|
```java
|
||||||
|
// 原代码
|
||||||
|
dto.setFee(ticket.getFee());
|
||||||
|
|
||||||
|
// 修复后代码
|
||||||
|
dto.setFee(ticket.getFee().toString());
|
||||||
|
```
|
||||||
|
|
||||||
|
## 预期效果
|
||||||
|
1. 修复后,后端能成功将`Ticket`实体转换为`TicketDto`
|
||||||
|
2. 前端能接收到包含5条专家号源的完整列表
|
||||||
|
3. 页面显示正常,不再出现"没有更多数据了"的提示
|
||||||
|
|
||||||
|
## 验证方法
|
||||||
|
1. 重新启动项目,访问号源管理页面
|
||||||
|
2. 选择"专家号"类型,查看是否能正确显示5条号源记录
|
||||||
|
3. 检查日志,确认没有类型转换异常
|
||||||
23
.trae/documents/修复门诊预约界面专家号查询问题.md
Normal file
23
.trae/documents/修复门诊预约界面专家号查询问题.md
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
# 修复门诊预约界面专家号查询问题
|
||||||
|
|
||||||
|
## 问题分析
|
||||||
|
从日志中发现关键问题:
|
||||||
|
- 前端传递的ticket_type值是英文:`general` (普通号) 和 `expert` (专家号)
|
||||||
|
- 数据库中存储的ticket_type值是中文:`普通` 和 `专家`
|
||||||
|
- 导致查询条件不匹配,无法查询到数据
|
||||||
|
|
||||||
|
## 解决方案
|
||||||
|
需要在后端添加类型映射转换,将前端传递的英文类型转换为数据库中存储的中文类型。
|
||||||
|
|
||||||
|
## 修复步骤
|
||||||
|
1. 修改 `TicketAppServiceImpl.java` 文件,在处理type参数时添加映射转换逻辑
|
||||||
|
2. 添加从英文类型到中文类型的映射关系
|
||||||
|
3. 测试修复后的功能,确保普通号和专家号都能正确查询
|
||||||
|
|
||||||
|
## 代码修改点
|
||||||
|
- 文件:`d:/work/openhis-server-new/openhis-application/src/main/java/com/openhis/web/appointmentmanage/appservice/impl/TicketAppServiceImpl.java`
|
||||||
|
- 方法:`listTicket` 中的type参数处理部分
|
||||||
|
- 修改内容:添加类型映射转换,将 "general" 转换为 "普通","expert" 转换为 "专家"
|
||||||
|
|
||||||
|
## 预期效果
|
||||||
|
修复后,前端选择"普通号"或"专家号"时,系统能正确查询到对应的号源数据,不再出现"没有更多数据了"的提示。
|
||||||
23
.trae/documents/修复门诊预约界面只显示1条数据的问题.md
Normal file
23
.trae/documents/修复门诊预约界面只显示1条数据的问题.md
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
**问题分析**:
|
||||||
|
后端返回的响应格式是`{code: 200, msg: "操作成功", data: {total: 5, limit: 20, page: 1, list: [5条记录]}}`,而前端可能期望直接访问`list`属性,导致只能显示1条数据。
|
||||||
|
|
||||||
|
**修复方案**:
|
||||||
|
|
||||||
|
1. 修改`TicketAppServiceImpl.java`的`listTicket`方法,确保返回的分页数据格式正确
|
||||||
|
2. 调整响应结构,使其更符合前端期望
|
||||||
|
3. 保持与现有代码的兼容性
|
||||||
|
|
||||||
|
**修改点**:
|
||||||
|
|
||||||
|
* `TicketAppServiceImpl.java`:优化`listTicket`方法的响应格式
|
||||||
|
|
||||||
|
* 确保分页信息和列表数据都能正确返回给前端
|
||||||
|
|
||||||
|
**预期效果**:
|
||||||
|
|
||||||
|
* 后端返回正确格式的响应数据
|
||||||
|
|
||||||
|
* 前端能够正确显示所有5条专家号数据
|
||||||
|
|
||||||
|
* 保持与现有代码的兼容性
|
||||||
|
|
||||||
68
README.md
68
README.md
@@ -1,68 +0,0 @@
|
|||||||
# 平台介绍
|
|
||||||
|
|
||||||
## 🏠【关于我们】
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
天天开源致⼒于打造中国应⽤管理 软件开源⽣态,⾯向医疗、企业、教育三⼤⾏业信息化需求,提供优质的开源软件产品与解决⽅案。平台现已发布OpenHIS、OpenCOM、OpenEDU系列开源产品,并持续招募⽣态合作伙伴,期待共同构建开源创新的⾏业协作模式,加速⾏业的数字化进程。
|
|
||||||
|
|
||||||
天天开源的前⾝是新致开源,最早于2022年6⽉发布开源医疗软件平台OpenHIS.org.cn,于2023年6⽉发布开源企业软件平台OpenCOM.com.cn。2025年7⽉,新致开源品牌更新为天天开源,我们始终秉持开源、专业、协作的理念,致⼒于为医疗、教育、中⼩企业等⾏业提供优质的开源解决⽅案。
|
|
||||||
|
|
||||||
了解我们:https://open.tntlinking.com/about?site=gitee
|
|
||||||
|
|
||||||
## 💾【部署包下载】
|
|
||||||
|
|
||||||
请访问官网产品中心下载部署包:https://open.tntlinking.com/resource/productCenter?site=gitee
|
|
||||||
|
|
||||||
## 📚【支持文档】
|
|
||||||
|
|
||||||
技术支持资源:https://open.tntlinking.com/resource/technicalSupport?site=gitee
|
|
||||||
(含演示环境、操作手册、部署手册、开发手册、常见问题等)
|
|
||||||
|
|
||||||
产品介绍:https://open.tntlinking.com/resource/industryKnowledge?site=gitee
|
|
||||||
|
|
||||||
操作教程:https://open.tntlinking.com/resource/operationTutorial?site=gitee
|
|
||||||
|
|
||||||
沙龙回顾:https://open.tntlinking.com/resource/openSourceSalon#23?site=gitee
|
|
||||||
|
|
||||||
## 🤝【合作方式】
|
|
||||||
|
|
||||||
产品服务价格:https://open.tntlinking.com/cost?site=gitee
|
|
||||||
|
|
||||||
加入生态伙伴:https://open.tntlinking.com/ecology/becomePartner?site=gitee
|
|
||||||
|
|
||||||
## 🤗【技术社区】
|
|
||||||
|
|
||||||
请访问官网扫码加入技术社区交流:https://open.tntlinking.com/ecology/joinCommunity?site=gitee
|
|
||||||
|
|
||||||
请关注公众号【天天开源软件】以便获得最新产品更新信息。
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# 项目介绍
|
|
||||||
|
|
||||||
OpenHIS医院系统(信创版)集十大核心模块于一体,涵盖目录管理、基础数据配置、个性化设置、门诊/住院全流程管理、药房药库智能管控、精细化耗材管理、财务核算体系、医保合规对接及多维报表分析等功能模块,共计372项标准化功能。
|
|
||||||
|
|
||||||
系统深度适配民营及公立一二级医院业务场景,支持单体医院、集团化运营及区域医疗协同等多种部署模式,并通过国家信创认证体系,确保全栈技术自主可控。如有项目需求,可联系官方平台合作。
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## 运行环境
|
|
||||||
|
|
||||||
jdk17 (必须)
|
|
||||||
node.js-v16.15 (推荐)
|
|
||||||
PostgreSQL-v16.2 (必须)
|
|
||||||
redis (常用稳定版本即可)
|
|
||||||
|
|
||||||
## 开发提示
|
|
||||||
|
|
||||||
需要修改数据库和redis的连接信息,详见:
|
|
||||||
application.yml
|
|
||||||
application-druid.yml
|
|
||||||
|
|
||||||
## 目录解释
|
|
||||||
|
|
||||||
前端: openhis-ui-vue3
|
|
||||||
后端: openhis-server
|
|
||||||
启动类: OpenHisApplication
|
|
||||||
|
|
||||||
104
check_display_order.sql
Normal file
104
check_display_order.sql
Normal file
@@ -0,0 +1,104 @@
|
|||||||
|
-- 检查流水号(display_order)是否按“科室+医生+当天”正确递增
|
||||||
|
--
|
||||||
|
-- 说明:
|
||||||
|
-- 1. display_order 存的是纯数字(1, 2, 3...),不带时间戳前缀
|
||||||
|
-- 2. 时间戳前缀(如 20260109)是在前端显示时加上的
|
||||||
|
-- 3. 后端用 Redis key "ORG-{科室ID}-DOC-{医生ID}" 按天自增
|
||||||
|
--
|
||||||
|
-- 如何判断逻辑是否正确:
|
||||||
|
-- 同一科室、同一医生、同一天的记录,display_order 应该递增(1, 2, 3...)
|
||||||
|
-- 不同科室、不同医生、不同天的记录,可能都是 1(这是正常的)
|
||||||
|
|
||||||
|
-- ========================================
|
||||||
|
-- 查询1:按“科室+医生+日期”分组,看每组内的 display_order 是否递增
|
||||||
|
-- ========================================
|
||||||
|
SELECT
|
||||||
|
DATE(start_time) AS 日期,
|
||||||
|
organization_id AS 科室ID,
|
||||||
|
registrar_id AS 医生ID,
|
||||||
|
COUNT(*) AS 该组记录数,
|
||||||
|
MIN(display_order) AS 最小序号,
|
||||||
|
MAX(display_order) AS 最大序号,
|
||||||
|
STRING_AGG(display_order::text, ', ' ORDER BY start_time) AS 序号列表,
|
||||||
|
STRING_AGG(id::text, ', ' ORDER BY start_time) AS 记录ID列表
|
||||||
|
FROM adm_encounter
|
||||||
|
WHERE delete_flag = '0'
|
||||||
|
AND start_time >= CURRENT_DATE - INTERVAL '7 days' -- 只看最近7天
|
||||||
|
AND display_order IS NOT NULL
|
||||||
|
GROUP BY DATE(start_time), organization_id, registrar_id
|
||||||
|
ORDER BY 日期 DESC, 科室ID, 医生ID;
|
||||||
|
|
||||||
|
-- ========================================
|
||||||
|
-- 查询2:详细查看每条记录,看同组内的序号是否连续
|
||||||
|
-- ========================================
|
||||||
|
SELECT
|
||||||
|
id AS 记录ID,
|
||||||
|
DATE(start_time) AS 日期,
|
||||||
|
organization_id AS 科室ID,
|
||||||
|
registrar_id AS 医生ID,
|
||||||
|
start_time AS 挂号时间,
|
||||||
|
display_order AS 流水号,
|
||||||
|
-- 计算:同组内的序号应该是 1, 2, 3...,看是否有重复或跳号
|
||||||
|
ROW_NUMBER() OVER (
|
||||||
|
PARTITION BY DATE(start_time), organization_id, registrar_id
|
||||||
|
ORDER BY start_time
|
||||||
|
) AS 应该是第几个,
|
||||||
|
CASE
|
||||||
|
WHEN display_order = ROW_NUMBER() OVER (
|
||||||
|
PARTITION BY DATE(start_time), organization_id, registrar_id
|
||||||
|
ORDER BY start_time
|
||||||
|
) THEN '✓ 正常'
|
||||||
|
ELSE '✗ 异常'
|
||||||
|
END AS 是否正常
|
||||||
|
FROM adm_encounter
|
||||||
|
WHERE delete_flag = '0'
|
||||||
|
AND start_time >= CURRENT_DATE - INTERVAL '7 days'
|
||||||
|
AND display_order IS NOT NULL
|
||||||
|
ORDER BY DATE(start_time) DESC, organization_id, registrar_id, start_time;
|
||||||
|
|
||||||
|
-- ========================================
|
||||||
|
-- 查询3:只看今天的数据(最直观)
|
||||||
|
-- ========================================
|
||||||
|
SELECT
|
||||||
|
id AS 记录ID,
|
||||||
|
organization_id AS 科室ID,
|
||||||
|
registrar_id AS 医生ID,
|
||||||
|
start_time AS 挂号时间,
|
||||||
|
display_order AS 流水号
|
||||||
|
FROM adm_encounter
|
||||||
|
WHERE delete_flag = '0'
|
||||||
|
AND DATE(start_time) = CURRENT_DATE
|
||||||
|
AND display_order IS NOT NULL
|
||||||
|
ORDER BY organization_id, registrar_id, start_time;
|
||||||
|
|
||||||
|
-- ========================================
|
||||||
|
-- 查询4:发现问题 - 找出同组内 display_order 重复的记录
|
||||||
|
-- ========================================
|
||||||
|
WITH ranked AS (
|
||||||
|
SELECT
|
||||||
|
id,
|
||||||
|
DATE(start_time) AS reg_date,
|
||||||
|
organization_id,
|
||||||
|
registrar_id,
|
||||||
|
start_time,
|
||||||
|
display_order,
|
||||||
|
ROW_NUMBER() OVER (
|
||||||
|
PARTITION BY DATE(start_time), organization_id, registrar_id
|
||||||
|
ORDER BY start_time
|
||||||
|
) AS should_be_order
|
||||||
|
FROM adm_encounter
|
||||||
|
WHERE delete_flag = '0'
|
||||||
|
AND start_time >= CURRENT_DATE - INTERVAL '7 days'
|
||||||
|
AND display_order IS NOT NULL
|
||||||
|
)
|
||||||
|
SELECT
|
||||||
|
reg_date AS 日期,
|
||||||
|
organization_id AS 科室ID,
|
||||||
|
registrar_id AS 医生ID,
|
||||||
|
COUNT(*) AS 重复数量,
|
||||||
|
STRING_AGG(id::text || '->' || display_order::text, ', ') AS 问题记录
|
||||||
|
FROM ranked
|
||||||
|
WHERE display_order != should_be_order
|
||||||
|
GROUP BY reg_date, organization_id, registrar_id
|
||||||
|
ORDER BY reg_date DESC;
|
||||||
|
|
||||||
10
md/test.html
Normal file
10
md/test.html
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<title>测试合并11111</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
332
md/前端UI规范文档.md
Normal file
332
md/前端UI规范文档.md
Normal file
@@ -0,0 +1,332 @@
|
|||||||
|
# OpenHIS UI 风格规范文档
|
||||||
|
|
||||||
|
## 1. 整体布局
|
||||||
|
|
||||||
|
### 1.1 容器结构
|
||||||
|
```
|
||||||
|
<div class="app-container [page-name]-container">
|
||||||
|
<div class="components-container">
|
||||||
|
<!-- 查询表单 -->
|
||||||
|
<el-form class="query-form">...</el-form>
|
||||||
|
|
||||||
|
<!-- 操作按钮 -->
|
||||||
|
<el-row class="button-group">...</el-row>
|
||||||
|
|
||||||
|
<!-- 数据表格 -->
|
||||||
|
<el-table border>...</el-table>
|
||||||
|
|
||||||
|
<!-- 分页 -->
|
||||||
|
<div class="pagination-container">...</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
### 1.2 样式说明
|
||||||
|
- `app-container`: 最外层容器,全屏背景
|
||||||
|
- `components-container`: 白色卡片容器,带阴影
|
||||||
|
- `query-form`: 查询表单,底部无间距
|
||||||
|
- `button-group`: 按钮组,间距 8px
|
||||||
|
- `pagination-container`: 分页容器,顶部间距 16px
|
||||||
|
|
||||||
|
## 2. 统一样式规范
|
||||||
|
|
||||||
|
### 2.1 颜色规范
|
||||||
|
```scss
|
||||||
|
// 主色调
|
||||||
|
--color-primary: #409EFF;
|
||||||
|
--color-success: #67C23A;
|
||||||
|
--color-warning: #E6A23C;
|
||||||
|
--color-danger: #F56C6C;
|
||||||
|
--color-info: #909399;
|
||||||
|
|
||||||
|
// 文字颜色
|
||||||
|
--text-regular: #606266; // 常规文字
|
||||||
|
--text-secondary: #909399; // 次要文字
|
||||||
|
--text-placeholder: #A8ABB2; // 占位符
|
||||||
|
```
|
||||||
|
|
||||||
|
### 2.2 间距规范
|
||||||
|
```scss
|
||||||
|
// 容器内边距
|
||||||
|
$spacing-xs: 4px;
|
||||||
|
$spacing-sm: 8px;
|
||||||
|
$spacing-md: 16px;
|
||||||
|
$spacing-lg: 20px;
|
||||||
|
$spacing-xl: 24px;
|
||||||
|
|
||||||
|
// 表单项间距
|
||||||
|
$form-item-margin-bottom: 18px;
|
||||||
|
```
|
||||||
|
|
||||||
|
### 2.3 圆角规范
|
||||||
|
```scss
|
||||||
|
$border-radius-sm: 4px; // 小圆角 - 按钮、输入框
|
||||||
|
$border-radius-md: 8px; // 中圆角 - 卡片、对话框
|
||||||
|
$border-radius-lg: 12px; // 大圆角 - 特殊组件
|
||||||
|
```
|
||||||
|
|
||||||
|
### 2.4 阴影规范
|
||||||
|
```scss
|
||||||
|
// 卡片阴影
|
||||||
|
$box-shadow-card: 0 2px 8px rgba(0, 0, 0, 0.08);
|
||||||
|
|
||||||
|
// 表格阴影
|
||||||
|
$box-shadow-table: 0 1px 4px rgba(0, 0, 0, 0.05);
|
||||||
|
|
||||||
|
// 浮动元素阴影
|
||||||
|
$box-shadow-float: 0 2px 12px rgba(0, 0, 0, 0.1);
|
||||||
|
```
|
||||||
|
|
||||||
|
### 2.5 字体规范
|
||||||
|
```scss
|
||||||
|
$font-size-base: 14px; // 基础字号
|
||||||
|
$font-size-sm: 12px; // 小字号
|
||||||
|
$font-size-lg: 16px; // 大字号
|
||||||
|
$font-size-xl: 18px; // 特大字号
|
||||||
|
|
||||||
|
$font-weight-regular: 400; // 常规
|
||||||
|
$font-weight-medium: 500; // 中等
|
||||||
|
$font-weight-bold: 600; // 加粗
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3. 组件规范
|
||||||
|
|
||||||
|
### 3.1 表单组件
|
||||||
|
|
||||||
|
#### 输入框
|
||||||
|
```vue
|
||||||
|
<el-input
|
||||||
|
v-model="value"
|
||||||
|
placeholder="请输入xxx"
|
||||||
|
clearable
|
||||||
|
style="width: 200px"
|
||||||
|
@keyup.enter="handleQuery"
|
||||||
|
/>
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 下拉框
|
||||||
|
```vue
|
||||||
|
<el-select
|
||||||
|
v-model="value"
|
||||||
|
placeholder="请选择xxx"
|
||||||
|
clearable
|
||||||
|
style="width: 200px"
|
||||||
|
>
|
||||||
|
<el-option
|
||||||
|
v-for="dict in dictList"
|
||||||
|
:key="dict.value"
|
||||||
|
:label="dict.label"
|
||||||
|
:value="dict.value"
|
||||||
|
/>
|
||||||
|
</el-select>
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 按钮规范
|
||||||
|
```vue
|
||||||
|
<!-- 主按钮 -->
|
||||||
|
<el-button type="primary" icon="IconName">按钮文字</el-button>
|
||||||
|
|
||||||
|
<!-- 次要按钮 -->
|
||||||
|
<el-button type="success">按钮文字</el-button>
|
||||||
|
<el-button type="warning">按钮文字</el-button>
|
||||||
|
<el-button type="danger">按钮文字</el-button>
|
||||||
|
|
||||||
|
<!-- 次要按钮(plain) -->
|
||||||
|
<el-button type="primary" plain icon="IconName">按钮文字</el-button>
|
||||||
|
|
||||||
|
<!-- 链接按钮(table内) -->
|
||||||
|
<el-button link type="primary" class="action-button">文字</el-button>
|
||||||
|
```
|
||||||
|
|
||||||
|
### 3.2 表格组件
|
||||||
|
|
||||||
|
```vue
|
||||||
|
<el-table
|
||||||
|
v-loading="loading"
|
||||||
|
:data="tableData"
|
||||||
|
@selection-change="handleSelectionChange"
|
||||||
|
border
|
||||||
|
>
|
||||||
|
<!-- 复选列 -->
|
||||||
|
<el-table-column type="selection" width="55" align="center" />
|
||||||
|
|
||||||
|
<!-- 序号列 -->
|
||||||
|
<el-table-column label="序号" align="center" prop="id" width="80" />
|
||||||
|
|
||||||
|
<!-- 普通列 -->
|
||||||
|
<el-table-column
|
||||||
|
label="列名"
|
||||||
|
align="center"
|
||||||
|
prop="fieldName"
|
||||||
|
min-width="200"
|
||||||
|
:show-overflow-tooltip="true"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<!-- 带标签列 -->
|
||||||
|
<el-table-column label="状态" align="center" prop="status" width="90">
|
||||||
|
<template #default="scope">
|
||||||
|
<dict-tag :options="dictType" :value="scope.row.status" />
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
|
||||||
|
<!-- 操作列 -->
|
||||||
|
<el-table-column label="操作" align="center" min-width="280">
|
||||||
|
<template #default="scope">
|
||||||
|
<el-button link type="primary" @click="handleEdit(scope.row)" class="action-button">编辑</el-button>
|
||||||
|
<el-button link type="danger" @click="handleDelete(scope.row)" class="action-button">删除</el-button>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
</el-table>
|
||||||
|
```
|
||||||
|
|
||||||
|
### 3.3 对话框组件
|
||||||
|
|
||||||
|
```vue
|
||||||
|
<el-dialog
|
||||||
|
:title="dialogTitle"
|
||||||
|
v-model="dialogVisible"
|
||||||
|
width="800px"
|
||||||
|
destroy-on-close
|
||||||
|
>
|
||||||
|
<el-form :model="form" :rules="rules" label-width="80px">
|
||||||
|
<!-- 表单内容 -->
|
||||||
|
</el-form>
|
||||||
|
|
||||||
|
<template #footer>
|
||||||
|
<div class="dialog-footer">
|
||||||
|
<el-button type="primary" @click="handleSubmit">确 定</el-button>
|
||||||
|
<el-button @click="handleCancel">取 消</el-button>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-dialog>
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4. 响应式设计
|
||||||
|
|
||||||
|
### 4.1 断点规范
|
||||||
|
```scss
|
||||||
|
$screen-xs: 480px;
|
||||||
|
$screen-sm: 768px;
|
||||||
|
$screen-md: 992px;
|
||||||
|
$screen-lg: 1200px;
|
||||||
|
```
|
||||||
|
|
||||||
|
### 4.2 响应式规范
|
||||||
|
```vue
|
||||||
|
<!-- 栅格系统 -->
|
||||||
|
<el-row :gutter="10">
|
||||||
|
<el-col :span="6" :xs="12" :sm="8">...</el-col>
|
||||||
|
<el-col :span="18" :xs="12" :sm="16">...</el-col>
|
||||||
|
</el-row>
|
||||||
|
|
||||||
|
<!-- 移动端表单 -->
|
||||||
|
<el-form :label-width="isMobile ? '80px' : '120px'">
|
||||||
|
```
|
||||||
|
|
||||||
|
## 5. 交互规范
|
||||||
|
|
||||||
|
### 5.1 加载状态
|
||||||
|
```vue
|
||||||
|
<!-- 表格加载 -->
|
||||||
|
<el-table v-loading="loading" :data="tableData">
|
||||||
|
|
||||||
|
<!-- 按钮加载 -->
|
||||||
|
<el-button :loading="saving">保存</el-button>
|
||||||
|
|
||||||
|
<!-- 全屏加载 -->
|
||||||
|
<el-button type="primary" :loading="true">提交</el-button>
|
||||||
|
```
|
||||||
|
|
||||||
|
### 5.2 空状态
|
||||||
|
```vue
|
||||||
|
<el-empty
|
||||||
|
description="暂无数据"
|
||||||
|
:image="emptyImage"
|
||||||
|
/>
|
||||||
|
```
|
||||||
|
|
||||||
|
### 5.3 确认对话框
|
||||||
|
```vue
|
||||||
|
<el-dialog title="确认提示" v-model="confirmVisible">
|
||||||
|
<p>{{ confirmMessage }}</p>
|
||||||
|
<template #footer>
|
||||||
|
<el-button @click="confirmVisible = false">取 消</el-button>
|
||||||
|
<el-button type="danger" @click="handleConfirm">确 定</el-button>
|
||||||
|
</template>
|
||||||
|
</el-dialog>
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6. 命名规范
|
||||||
|
|
||||||
|
### 6.1 CSS 类名
|
||||||
|
- 使用 kebab-case(短横线命名)
|
||||||
|
- 遵循 BEM 命名规范
|
||||||
|
- 示例:`notice-container`, `button-group`, `action-button`
|
||||||
|
|
||||||
|
### 6.2 变量命名
|
||||||
|
- Vue:使用 camelCase
|
||||||
|
- 事件处理:以 `handle` 开头
|
||||||
|
- 数据获取:以 `get`/`load` 开头
|
||||||
|
- 示例:`handleQuery`, `loadData`, `handleSubmit`
|
||||||
|
|
||||||
|
### 6.3 组件命名
|
||||||
|
- 使用 PascalCase
|
||||||
|
- 多个单词时使用驼峰命名
|
||||||
|
- 示例:`NoticePanel`, `TableHeader`, `SearchForm`
|
||||||
|
|
||||||
|
## 7. 国际化规范
|
||||||
|
|
||||||
|
```vue
|
||||||
|
<!-- 使用字典标签 -->
|
||||||
|
<dict-tag :options="dictType" :value="row.status" />
|
||||||
|
|
||||||
|
<!-- 使用占位符 -->
|
||||||
|
<el-input :placeholder="$t('common.placeholder')"/>
|
||||||
|
```
|
||||||
|
|
||||||
|
## 8. 性能优化
|
||||||
|
|
||||||
|
### 8.1 图片优化
|
||||||
|
- 使用 WebP 格式
|
||||||
|
- 图片懒加载
|
||||||
|
- 响应式图片
|
||||||
|
|
||||||
|
### 8.2 列表优化
|
||||||
|
- 虚拟滚动(大列表)
|
||||||
|
- 分页加载
|
||||||
|
- 骨架屏
|
||||||
|
|
||||||
|
### 8.3 缓存策略
|
||||||
|
- 使用 Vuex/Pinia 缓存用户数据
|
||||||
|
- 本地存储持久化配置
|
||||||
|
- 请求去重
|
||||||
|
|
||||||
|
## 9. 无障碍规范
|
||||||
|
|
||||||
|
### 9.1 语义化标签
|
||||||
|
```vue
|
||||||
|
<nav> <!-- 导航 -->
|
||||||
|
<main> <!-- 主内容 -->
|
||||||
|
<header> <!-- 头部 -->
|
||||||
|
<footer> <!-- 底部 -->
|
||||||
|
```
|
||||||
|
|
||||||
|
### 9.2 ARIA 属性
|
||||||
|
```vue
|
||||||
|
<el-button aria-label="提交按钮">提交</el-button>
|
||||||
|
<el-input aria-label="搜索框" />
|
||||||
|
```
|
||||||
|
|
||||||
|
### 9.3 键盘导航
|
||||||
|
- 支持键盘操作
|
||||||
|
- Tab 键焦点管理
|
||||||
|
- 快捷键支持
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**注意事项:**
|
||||||
|
1. 所有新增页面必须遵循此规范
|
||||||
|
2. 修改现有页面时尽量统一样式
|
||||||
|
3. 保持与系统整体风格一致
|
||||||
|
4. 优先使用已有的组件和样式
|
||||||
|
5. 遵循响应式设计原则
|
||||||
287
md/需求/94-手术室维护界面_2026-1-9.md
Normal file
287
md/需求/94-手术室维护界面_2026-1-9.md
Normal file
@@ -0,0 +1,287 @@
|
|||||||
|
## 手术室维护界面PRD文档
|
||||||
|
|
||||||
|
### 一、页面概述
|
||||||
|
|
||||||
|
**页面名称**:手术室维护界面
|
||||||
|
**页面目标**:提供手术室基础数据的维护功能,包括新增、编辑、启用/停用手术室信息,为手术安排提供基础数据支持
|
||||||
|
**适用场景**:医院管理员需要新增、修改、启用/停用手术室信息时使用
|
||||||
|
**页面类型**:列表页+表单页(含模态框)
|
||||||
|
|
||||||
|
**原型图地址:**https://static.pm-ai.cn/prototype/20260104/ee5d222231effefcb39624d1646a2e20/index.html
|
||||||
|
|
||||||
|
**核心功能**:
|
||||||
|
|
||||||
|
1. 手术室列表展示与查询
|
||||||
|
2. 新增手术室信息
|
||||||
|
3. 编辑现有手术室信息
|
||||||
|
4. 启用/停用手术室状态
|
||||||
|
5. 数据有效性校验
|
||||||
|
|
||||||
|
**用户价值**:
|
||||||
|
|
||||||
|
- 管理员可集中管理所有手术室基础信息
|
||||||
|
- 确保手术安排时能获取准确的手术室数据
|
||||||
|
- 通过状态管理控制手术室可用性
|
||||||
|
|
||||||
|
**流程图:**
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
```mermaid
|
||||||
|
flowchart TD
|
||||||
|
A[手术室维护界面] --> B[手术室列表展示]
|
||||||
|
|
||||||
|
B --> C[新增手术室]
|
||||||
|
|
||||||
|
B --> D[编辑手术室]
|
||||||
|
|
||||||
|
B --> E[启用/停用手术室]
|
||||||
|
|
||||||
|
B --> F[查询手术室]
|
||||||
|
|
||||||
|
C --> G[点击新增按钮]
|
||||||
|
|
||||||
|
G --> H[打开新增模态框]
|
||||||
|
|
||||||
|
H --> I[填写表单字段]
|
||||||
|
|
||||||
|
I --> J{必填字段校验}
|
||||||
|
|
||||||
|
J -->|通过| K[提交数据]
|
||||||
|
|
||||||
|
J -->|不通过| L[提示请填写所有必填项]
|
||||||
|
|
||||||
|
K --> M[表格新增数据行]
|
||||||
|
|
||||||
|
D --> N[点击修改按钮]
|
||||||
|
|
||||||
|
N --> O[打开编辑模态框]
|
||||||
|
|
||||||
|
O --> P[修改表单字段]
|
||||||
|
|
||||||
|
P --> Q{必填字段校验}
|
||||||
|
|
||||||
|
Q -->|通过| R[保存数据]
|
||||||
|
|
||||||
|
Q -->|不通过| S[提示请填写所有必填项]
|
||||||
|
|
||||||
|
R --> T[更新表格对应行]
|
||||||
|
|
||||||
|
E --> U[点击启用/停用按钮]
|
||||||
|
|
||||||
|
U --> V{二次确认}
|
||||||
|
|
||||||
|
V -->|确认| W[切换状态标签]
|
||||||
|
|
||||||
|
V -->|取消| X[取消操作]
|
||||||
|
|
||||||
|
W --> Y[更新按钮状态]
|
||||||
|
|
||||||
|
F --> Z[输入查询条件]
|
||||||
|
|
||||||
|
Z --> AA[筛选表格数据]
|
||||||
|
|
||||||
|
K --> AB{房间号重复校验}
|
||||||
|
|
||||||
|
AB -->|不重复| AC[提示房间号已存在]
|
||||||
|
|
||||||
|
AB -->|重复| AD[更新按钮状态]
|
||||||
|
```
|
||||||
|
|
||||||
|
### 二、整体布局分析
|
||||||
|
|
||||||
|
**页面宽度**:自适应布局
|
||||||
|
**主要区域划分**:
|
||||||
|
|
||||||
|
1. 页头区域(15%高度)
|
||||||
|
2. 表格展示区(85%高度)
|
||||||
|
**布局特点**:上下布局,表格采用固定表头+滚动内容区设计
|
||||||
|
**响应式要求**:移动端适配时改为纵向堆叠布局,操作按钮组变为纵向排列
|
||||||
|
|
||||||
|
### 三、页面区域详细描述
|
||||||
|
|
||||||
|
#### 1. 页头区域
|
||||||
|
|
||||||
|
**区域位置**:页面顶部
|
||||||
|
**区域尺寸**:高度60px,宽度100%
|
||||||
|
**区域功能**:展示标题和主要操作入口
|
||||||
|
**包含元素**:
|
||||||
|
|
||||||
|
- **标题文本**
|
||||||
|
- 元素类型:H1标题
|
||||||
|
- 显示内容:"手术室列表"
|
||||||
|
- 样式特征:1.75rem/600字重,深灰色(#333)
|
||||||
|
- **新增按钮**
|
||||||
|
- 元素类型:主要操作按钮
|
||||||
|
- 显示内容:"新增"(带+图标)
|
||||||
|
- 交互行为:点击触发新增模态框
|
||||||
|
- 样式特征:蓝色背景(#5a7cff),白色文字,8px圆角,悬停上浮1px
|
||||||
|
|
||||||
|
#### 2. 表格展示区(手术室列表表格)
|
||||||
|
|
||||||
|
**区域位置**:页头下方
|
||||||
|
**区域尺寸**:高度自适应,宽度100%
|
||||||
|
**区域功能**:展示手术室数据并支持行级操作
|
||||||
|
**包含元素**:
|
||||||
|
|
||||||
|
- **数据表格**
|
||||||
|
- 展示方式:固定表头表格
|
||||||
|
- 数据字段:
|
||||||
|
- 房间号:文本 - OR01 - 不可操作
|
||||||
|
- 手术室名称:文本 - 第一手术室 - 不可操作
|
||||||
|
- 类型:文本 - 普通/日间/复合 - 不可操作
|
||||||
|
- 所属科室:文本 - 外科 - 不可操作
|
||||||
|
- 状态:标签 - 有效/无效 - 通过操作按钮切换
|
||||||
|
- 操作功能:每行包含"修改"和"状态切换(停用-黄色/启用-绿色)"按钮
|
||||||
|
- **表格样式**:
|
||||||
|
- 表头:浅灰色背景(#f8f9fa),大写字母,14px字号
|
||||||
|
- 行悬停:浅灰色背景(#f8f9fa)
|
||||||
|
- 状态标签:
|
||||||
|
- 有效:绿色背景+文字(#28a745)
|
||||||
|
- 无效:灰色背景+文字(#6c757d)
|
||||||
|
|
||||||
|
#### 3. 新增手术室弹窗
|
||||||
|
|
||||||
|
**区域位置**:页面居中模态弹窗
|
||||||
|
**区域功能**:收集新增手术室所需信息
|
||||||
|
**包含元素**:
|
||||||
|
|
||||||
|
- 表单字段:
|
||||||
|
1. 房间号输入框
|
||||||
|
2. 类型:文本输入
|
||||||
|
3. 必填:是
|
||||||
|
4. 示例值:OR04
|
||||||
|
5. 校验规则:非空校验
|
||||||
|
6. 手术室名称输入框
|
||||||
|
- 类型:文本输入
|
||||||
|
- 必填:是
|
||||||
|
- 示例值:第四手术室
|
||||||
|
1. 手术室类型下拉框
|
||||||
|
- 类型:单选下拉
|
||||||
|
- 选项:普通/日间/复合/特殊
|
||||||
|
- 默认值:普通
|
||||||
|
1. 所属科室下拉框
|
||||||
|
- 类型:单选下拉
|
||||||
|
- 必填:是
|
||||||
|
- 选项:外科/妇产科等8个科室
|
||||||
|
- 默认提示:"请选择科室"
|
||||||
|
- 操作按钮:
|
||||||
|
- 取消按钮(灰色边框)
|
||||||
|
- 确认按钮(蓝色填充)
|
||||||
|
- 校验逻辑:必填字段非空校验
|
||||||
|
- 成功反馈:提示"手术室添加成功"
|
||||||
|
- 失败反馈:提示"请填写所有必填项"
|
||||||
|
|
||||||
|
#### 4. 编辑手术室弹窗
|
||||||
|
|
||||||
|
**区域位置**:页面居中模态弹窗
|
||||||
|
**区域功能**:修改现有手术室信息
|
||||||
|
**包含元素**:
|
||||||
|
|
||||||
|
- 表单字段(同新增弹窗,带初始值)
|
||||||
|
- 操作按钮:
|
||||||
|
- 取消按钮
|
||||||
|
- 保存按钮
|
||||||
|
- 校验逻辑:同新增弹窗
|
||||||
|
- 成功反馈:提示"手术室信息已更新"
|
||||||
|
|
||||||
|
### 四、交互功能详细说明
|
||||||
|
|
||||||
|
#### 1. 新增手术室
|
||||||
|
|
||||||
|
**功能描述**:添加新的手术室记录
|
||||||
|
**触发条件**:点击页头"新增"按钮
|
||||||
|
**操作流程**:
|
||||||
|
|
||||||
|
1. 打开新增模态框
|
||||||
|
2. 填写必填字段(房间号、名称、科室)
|
||||||
|
3. 点击确认提交(插入his_or_room表)
|
||||||
|
4. 表格末尾新增数据行
|
||||||
|
**异常处理**:
|
||||||
|
- 必填项为空时弹出"请填写所有必填项"提示
|
||||||
|
- 房间号重复需在后端校验并提示
|
||||||
|
|
||||||
|
#### 2. 编辑手术室
|
||||||
|
|
||||||
|
**功能描述**:修改现有手术室信息
|
||||||
|
**触发条件**:点击行内"修改"按钮
|
||||||
|
**操作流程**:
|
||||||
|
|
||||||
|
1. 打开编辑模态框(自动填充当前行数据)
|
||||||
|
2. 用户修改数据
|
||||||
|
3. 点击"保存"时校验并更新对应行数据
|
||||||
|
**状态保持**:记录当前编辑行索引确保数据更新准确
|
||||||
|
|
||||||
|
#### 3. 状态切换
|
||||||
|
|
||||||
|
**功能描述**:启用/停用手术室
|
||||||
|
**触发条件**:点击"停用"或"启用"按钮
|
||||||
|
**操作流程**:
|
||||||
|
|
||||||
|
1. 弹出二次确认对话框
|
||||||
|
2. 用户确认后切换状态标签
|
||||||
|
3. 按钮变为相反操作(停用↔启用)
|
||||||
|
4. 、停用手术室
|
||||||
|
- **步骤**:
|
||||||
|
1. 查询需要停用的手术室记录。
|
||||||
|
2. 将 valid_flag 设置为 0(无效)。
|
||||||
|
- **示例**:
|
||||||
|
|
||||||
|
UPDATE his_or_room
|
||||||
|
|
||||||
|
SET valid_flag = '0'
|
||||||
|
|
||||||
|
WHERE room_code = 'OR06';
|
||||||
|
|
||||||
|
5\. 启用手术室
|
||||||
|
|
||||||
|
**步骤**:
|
||||||
|
|
||||||
|
1. 查询需要启用的手术室记录。
|
||||||
|
1. 将 valid_flag 设置为 1(有效)。
|
||||||
|
- **示例**:
|
||||||
|
|
||||||
|
UPDATE his_or_room
|
||||||
|
|
||||||
|
SET valid_flag = '1'
|
||||||
|
|
||||||
|
WHERE room_code = 'OR06';
|
||||||
|
|
||||||
|
**防误操作**:所有状态变更需二次确认
|
||||||
|
|
||||||
|
### 五、数据结构说明(HIS_OR_ROOM手术室字典表)
|
||||||
|
|
||||||
|
| **字段名称** | **数据类型** | **是否为空** | **说明/典型值** | **外键/来源** |
|
||||||
|
|--------------|--------------|--------------|-----------------|-------------------------------|
|
||||||
|
| room_id | VARCHAR(10) | N | 主键 | 自增主键 |
|
||||||
|
| room_code | VARCHAR(10) | N | 手术室房间号 | 自定义编码,如 OR01、OR02 |
|
||||||
|
| room_name | VARCHAR(100) | N | 手术室名称 | 如 "第一手术室"、"第二手术室" |
|
||||||
|
| room_type | VARCHAR(10) | N | 手术室类型 | 普通、日间、复合 |
|
||||||
|
| dept_code | VARCHAR(10) | N | 所属科室 | FK → 科室管理的科室代码 |
|
||||||
|
| valid_flag | CHAR(1) | N | 是否有效 | 1有效,0无效 |
|
||||||
|
| created_time | DATETIME | N | 创建时间 | 默认当前时间 |
|
||||||
|
| updated_time | DATETIME | N | 更新时间 | 默认当前时间,自动更新 |
|
||||||
|
|
||||||
|
### 六、开发实现要点
|
||||||
|
|
||||||
|
**样式规范**:
|
||||||
|
|
||||||
|
- 主色调:#5a7cff(按钮/交互元素)
|
||||||
|
- 辅助色:#7b8a8b(次要文本)
|
||||||
|
- 字体:
|
||||||
|
- 标题:1.75rem/600字重
|
||||||
|
- 正文:0.875rem/400字重
|
||||||
|
- 间距系统:
|
||||||
|
- 卡片内边距:24px
|
||||||
|
- 表单字段间距:16px
|
||||||
|
|
||||||
|
**技术要求**:
|
||||||
|
|
||||||
|
**注意事项**:
|
||||||
|
|
||||||
|
1. 数据安全:
|
||||||
|
- 所有变更操作需记录操作日志
|
||||||
|
- 停用状态的手术室需在前端标记不可预约
|
||||||
|
2. 性能优化:
|
||||||
|
- 表格数据分页加载
|
||||||
|
- 模态框使用懒加载
|
||||||
45
openhis-server-new/com/openhis/tool/DatabaseFieldAdder.java
Normal file
45
openhis-server-new/com/openhis/tool/DatabaseFieldAdder.java
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
package com.openhis.tool;
|
||||||
|
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.DriverManager;
|
||||||
|
import java.sql.Statement;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Database field adder tool
|
||||||
|
*/
|
||||||
|
public class DatabaseFieldAdder {
|
||||||
|
public static void main(String[] args) {
|
||||||
|
String url = "jdbc:postgresql://192.168.110.252:15432/postgresql?currentSchema=public";
|
||||||
|
String username = "postgresql";
|
||||||
|
String password = "Jchl1528";
|
||||||
|
|
||||||
|
try (Connection conn = DriverManager.getConnection(url, username, password);
|
||||||
|
Statement stmt = conn.createStatement()) {
|
||||||
|
|
||||||
|
// Check if field exists
|
||||||
|
String checkSql = "SELECT column_name FROM information_schema.columns " +
|
||||||
|
"WHERE table_name = 'adm_healthcare_service' AND column_name = 'practitioner_id'";
|
||||||
|
|
||||||
|
boolean fieldExists = stmt.executeQuery(checkSql).next();
|
||||||
|
|
||||||
|
if (!fieldExists) {
|
||||||
|
// Add field
|
||||||
|
String addSql = "ALTER TABLE \"public\".\"adm_healthcare_service\" " +
|
||||||
|
"ADD COLUMN \"practitioner_id\" int8";
|
||||||
|
stmt.execute(addSql);
|
||||||
|
|
||||||
|
// Add comment
|
||||||
|
String commentSql = "COMMENT ON COLUMN \"public\".\"adm_healthcare_service\".\"practitioner_id\" IS 'practitioner_id'";
|
||||||
|
stmt.execute(commentSql);
|
||||||
|
|
||||||
|
System.out.println("Successfully added practitioner_id field to adm_healthcare_service table");
|
||||||
|
} else {
|
||||||
|
System.out.println("practitioner_id field already exists");
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.err.println("Error executing SQL: " + e.getMessage());
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -25,6 +25,11 @@
|
|||||||
<artifactId>spring-boot-devtools</artifactId>
|
<artifactId>spring-boot-devtools</artifactId>
|
||||||
<optional>true</optional> <!-- 表示依赖不会传递 -->
|
<optional>true</optional> <!-- 表示依赖不会传递 -->
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<!-- lombok -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.projectlombok</groupId>
|
||||||
|
<artifactId>lombok</artifactId>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<!-- swagger3-->
|
<!-- swagger3-->
|
||||||
<dependency>
|
<dependency>
|
||||||
@@ -38,9 +43,10 @@
|
|||||||
<artifactId>swagger-models</artifactId>
|
<artifactId>swagger-models</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<!-- Mysql驱动包 -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.mysql</groupId>
|
<groupId>mysql</groupId>
|
||||||
<artifactId>mysql-connector-j</artifactId>
|
<artifactId>mysql-connector-java</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- 核心模块-->
|
<!-- 核心模块-->
|
||||||
@@ -66,45 +72,12 @@
|
|||||||
<groupId>com.core</groupId>
|
<groupId>com.core</groupId>
|
||||||
<artifactId>core-flowable</artifactId>
|
<artifactId>core-flowable</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<!-- 通用工具-->
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.core</groupId>
|
||||||
|
<artifactId>core-common</artifactId>
|
||||||
|
<scope>compile</scope>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<!-- <build>-->
|
|
||||||
<!-- <plugins>-->
|
|
||||||
<!-- <plugin>-->
|
|
||||||
<!-- <groupId>org.springframework.boot</groupId>-->
|
|
||||||
<!-- <artifactId>spring-boot-maven-plugin</artifactId>-->
|
|
||||||
<!-- <version>2.5.15</version>-->
|
|
||||||
<!-- <configuration>-->
|
|
||||||
<!-- <fork>true</fork> <!– 如果没有该配置,devtools不会生效 –>-->
|
|
||||||
<!-- </configuration>-->
|
|
||||||
<!-- <executions>-->
|
|
||||||
<!-- <execution>-->
|
|
||||||
<!-- <goals>-->
|
|
||||||
<!-- <goal>repackage</goal>-->
|
|
||||||
<!-- </goals>-->
|
|
||||||
<!-- </execution>-->
|
|
||||||
<!-- </executions>-->
|
|
||||||
<!-- </plugin>-->
|
|
||||||
<!-- <plugin>-->
|
|
||||||
<!-- <groupId>org.apache.maven.plugins</groupId>-->
|
|
||||||
<!-- <artifactId>maven-war-plugin</artifactId>-->
|
|
||||||
<!-- <version>3.1.0</version>-->
|
|
||||||
<!-- <configuration>-->
|
|
||||||
<!-- <failOnMissingWebXml>false</failOnMissingWebXml>-->
|
|
||||||
<!-- <warName>${project.artifactId}</warName>-->
|
|
||||||
<!-- </configuration>-->
|
|
||||||
<!-- </plugin>-->
|
|
||||||
<!-- <plugin>-->
|
|
||||||
<!-- <groupId>org.apache.maven.plugins</groupId>-->
|
|
||||||
<!-- <artifactId>maven-compiler-plugin</artifactId>-->
|
|
||||||
<!-- <configuration>-->
|
|
||||||
<!-- <source>8</source>-->
|
|
||||||
<!-- <target>8</target>-->
|
|
||||||
<!-- </configuration>-->
|
|
||||||
<!-- </plugin>-->
|
|
||||||
<!-- </plugins>-->
|
|
||||||
<!-- <finalName>${project.artifactId}</finalName>-->
|
|
||||||
<!-- </build>-->
|
|
||||||
|
|
||||||
</project>
|
</project>
|
||||||
@@ -1,18 +1,5 @@
|
|||||||
package com.core.web.controller.common;
|
package com.core.web.controller.common;
|
||||||
|
|
||||||
import java.awt.image.BufferedImage;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
|
||||||
import javax.imageio.ImageIO;
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.util.FastByteArrayOutputStream;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import com.core.common.config.CoreConfig;
|
import com.core.common.config.CoreConfig;
|
||||||
import com.core.common.constant.CacheConstants;
|
import com.core.common.constant.CacheConstants;
|
||||||
import com.core.common.constant.Constants;
|
import com.core.common.constant.Constants;
|
||||||
@@ -22,6 +9,17 @@ import com.core.common.utils.sign.Base64;
|
|||||||
import com.core.common.utils.uuid.IdUtils;
|
import com.core.common.utils.uuid.IdUtils;
|
||||||
import com.core.system.service.ISysConfigService;
|
import com.core.system.service.ISysConfigService;
|
||||||
import com.google.code.kaptcha.Producer;
|
import com.google.code.kaptcha.Producer;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.util.FastByteArrayOutputStream;
|
||||||
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
import javax.imageio.ImageIO;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.awt.image.BufferedImage;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 验证码操作处理
|
* 验证码操作处理
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
package com.core.web.controller.common;
|
package com.core.web.controller.common;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import com.core.common.config.CoreConfig;
|
||||||
import java.util.List;
|
import com.core.common.constant.Constants;
|
||||||
|
import com.core.common.core.domain.AjaxResult;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import com.core.common.utils.StringUtils;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import com.core.common.utils.file.FileUploadUtils;
|
||||||
|
import com.core.common.utils.file.FileUtils;
|
||||||
|
import com.core.framework.config.ServerConfig;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
@@ -16,13 +17,10 @@ import org.springframework.web.bind.annotation.RequestMapping;
|
|||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
import org.springframework.web.multipart.MultipartFile;
|
import org.springframework.web.multipart.MultipartFile;
|
||||||
|
|
||||||
import com.core.common.config.CoreConfig;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import com.core.common.constant.Constants;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import java.util.ArrayList;
|
||||||
import com.core.common.utils.StringUtils;
|
import java.util.List;
|
||||||
import com.core.common.utils.file.FileUploadUtils;
|
|
||||||
import com.core.common.utils.file.FileUtils;
|
|
||||||
import com.core.framework.config.ServerConfig;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 通用请求处理
|
* 通用请求处理
|
||||||
|
|||||||
@@ -1,13 +1,5 @@
|
|||||||
package com.core.web.controller.common;
|
package com.core.web.controller.common;
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.web.bind.annotation.PostMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
import org.springframework.web.multipart.MultipartFile;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Anonymous;
|
import com.core.common.annotation.Anonymous;
|
||||||
import com.core.common.config.CoreConfig;
|
import com.core.common.config.CoreConfig;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
@@ -16,6 +8,13 @@ import com.core.common.utils.StringUtils;
|
|||||||
import com.core.common.utils.file.FileUploadUtils;
|
import com.core.common.utils.file.FileUploadUtils;
|
||||||
import com.core.common.utils.file.FileUtils;
|
import com.core.common.utils.file.FileUtils;
|
||||||
import com.core.framework.config.ServerConfig;
|
import com.core.framework.config.ServerConfig;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.PostMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
import org.springframework.web.multipart.MultipartFile;
|
||||||
|
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping("/file")
|
@RequestMapping("/file")
|
||||||
|
|||||||
@@ -1,17 +1,16 @@
|
|||||||
package com.core.web.controller.monitor;
|
package com.core.web.controller.monitor;
|
||||||
|
|
||||||
import java.util.*;
|
import com.core.common.constant.CacheConstants;
|
||||||
|
import com.core.common.core.domain.AjaxResult;
|
||||||
|
import com.core.common.utils.StringUtils;
|
||||||
|
import com.core.system.domain.SysCache;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.data.redis.core.RedisCallback;
|
import org.springframework.data.redis.core.RedisCallback;
|
||||||
import org.springframework.data.redis.core.RedisTemplate;
|
import org.springframework.data.redis.core.RedisTemplate;
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
import org.springframework.web.bind.annotation.*;
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
import com.core.common.constant.CacheConstants;
|
import java.util.*;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
|
||||||
import com.core.common.utils.StringUtils;
|
|
||||||
import com.core.system.domain.SysCache;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 缓存监控
|
* 缓存监控
|
||||||
|
|||||||
@@ -1,13 +1,12 @@
|
|||||||
package com.core.web.controller.monitor;
|
package com.core.web.controller.monitor;
|
||||||
|
|
||||||
|
import com.core.common.core.domain.AjaxResult;
|
||||||
|
import com.core.framework.web.domain.Server;
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
import com.core.common.core.domain.AjaxResult;
|
|
||||||
import com.core.framework.web.domain.Server;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 服务器监控
|
* 服务器监控
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,13 +1,5 @@
|
|||||||
package com.core.web.controller.monitor;
|
package com.core.web.controller.monitor;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
@@ -17,15 +9,23 @@ import com.core.common.utils.poi.ExcelUtil;
|
|||||||
import com.core.framework.web.service.SysPasswordService;
|
import com.core.framework.web.service.SysPasswordService;
|
||||||
import com.core.system.domain.SysLogininfor;
|
import com.core.system.domain.SysLogininfor;
|
||||||
import com.core.system.service.ISysLogininforService;
|
import com.core.system.service.ISysLogininforService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 系统访问记录
|
*
|
||||||
*
|
*
|
||||||
* @author system
|
* @author system
|
||||||
*/
|
*/
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping("/monitor/logininfor")
|
@RequestMapping("/monitor/logininfor")
|
||||||
|
|
||||||
public class SysLogininforController extends BaseController {
|
public class SysLogininforController extends BaseController {
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private ISysLogininforService logininforService;
|
private ISysLogininforService logininforService;
|
||||||
|
|
||||||
|
|||||||
@@ -1,13 +1,5 @@
|
|||||||
package com.core.web.controller.monitor;
|
package com.core.web.controller.monitor;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
@@ -16,6 +8,12 @@ import com.core.common.enums.BusinessType;
|
|||||||
import com.core.common.utils.poi.ExcelUtil;
|
import com.core.common.utils.poi.ExcelUtil;
|
||||||
import com.core.system.domain.SysOperLog;
|
import com.core.system.domain.SysOperLog;
|
||||||
import com.core.system.service.ISysOperLogService;
|
import com.core.system.service.ISysOperLogService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 操作日志记录
|
* 操作日志记录
|
||||||
|
|||||||
@@ -1,14 +1,5 @@
|
|||||||
package com.core.web.controller.monitor;
|
package com.core.web.controller.monitor;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.constant.CacheConstants;
|
import com.core.common.constant.CacheConstants;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
@@ -20,6 +11,14 @@ import com.core.common.enums.BusinessType;
|
|||||||
import com.core.common.utils.StringUtils;
|
import com.core.common.utils.StringUtils;
|
||||||
import com.core.system.domain.SysUserOnline;
|
import com.core.system.domain.SysUserOnline;
|
||||||
import com.core.system.service.ISysUserOnlineService;
|
import com.core.system.service.ISysUserOnlineService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 在线用户监控
|
* 在线用户监控
|
||||||
|
|||||||
@@ -1,14 +1,5 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
@@ -17,6 +8,13 @@ import com.core.common.enums.BusinessType;
|
|||||||
import com.core.common.utils.poi.ExcelUtil;
|
import com.core.common.utils.poi.ExcelUtil;
|
||||||
import com.core.system.domain.SysConfig;
|
import com.core.system.domain.SysConfig;
|
||||||
import com.core.system.service.ISysConfigService;
|
import com.core.system.service.ISysConfigService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 参数配置 信息操作处理
|
* 参数配置 信息操作处理
|
||||||
@@ -63,7 +61,25 @@ public class SysConfigController extends BaseController {
|
|||||||
*/
|
*/
|
||||||
@GetMapping(value = "/configKey/{configKey}")
|
@GetMapping(value = "/configKey/{configKey}")
|
||||||
public AjaxResult getConfigKey(@PathVariable String configKey) {
|
public AjaxResult getConfigKey(@PathVariable String configKey) {
|
||||||
return success(configService.selectConfigByKey(configKey));
|
String configValue = configService.selectConfigByKey(configKey);
|
||||||
|
// 确保即使返回 null 或空字符串,也明确设置 data 字段
|
||||||
|
// 如果 configValue 是 null,转换为空字符串
|
||||||
|
if (configValue == null) {
|
||||||
|
configValue = "";
|
||||||
|
}
|
||||||
|
// 直接创建 AjaxResult 并明确设置 data 字段,确保 data 字段始终存在
|
||||||
|
AjaxResult result = new AjaxResult();
|
||||||
|
result.put("code", 200);
|
||||||
|
result.put("msg", "操作成功");
|
||||||
|
result.put("data", configValue); // 明确设置 data 字段,即使值为空字符串
|
||||||
|
System.out.println("=== getConfigKey 调试信息 ===");
|
||||||
|
System.out.println("configKey: " + configKey);
|
||||||
|
System.out.println("configValue: [" + configValue + "]");
|
||||||
|
System.out.println("result.data: " + result.get("data"));
|
||||||
|
System.out.println("result.msg: " + result.get("msg"));
|
||||||
|
System.out.println("result.code: " + result.get("code"));
|
||||||
|
System.out.println("============================");
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -1,13 +1,5 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.ArrayUtils;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.constant.UserConstants;
|
import com.core.common.constant.UserConstants;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
@@ -16,6 +8,13 @@ import com.core.common.core.domain.entity.SysDept;
|
|||||||
import com.core.common.enums.BusinessType;
|
import com.core.common.enums.BusinessType;
|
||||||
import com.core.common.utils.StringUtils;
|
import com.core.common.utils.StringUtils;
|
||||||
import com.core.system.service.ISysDeptService;
|
import com.core.system.service.ISysDeptService;
|
||||||
|
import org.apache.commons.lang3.ArrayUtils;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 部门信息
|
* 部门信息
|
||||||
|
|||||||
@@ -1,15 +1,5 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
@@ -20,6 +10,14 @@ import com.core.common.utils.StringUtils;
|
|||||||
import com.core.common.utils.poi.ExcelUtil;
|
import com.core.common.utils.poi.ExcelUtil;
|
||||||
import com.core.system.service.ISysDictDataService;
|
import com.core.system.service.ISysDictDataService;
|
||||||
import com.core.system.service.ISysDictTypeService;
|
import com.core.system.service.ISysDictTypeService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 数据字典信息
|
* 数据字典信息
|
||||||
@@ -62,11 +60,12 @@ public class SysDictDataController extends BaseController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据字典类型查询字典数据信息
|
* 根据字典类型查询字典数据信息(支持拼音搜索)
|
||||||
*/
|
*/
|
||||||
@GetMapping(value = "/type/{dictType}")
|
@GetMapping(value = "/type/{dictType}")
|
||||||
public AjaxResult dictType(@PathVariable String dictType) {
|
public AjaxResult dictType(@PathVariable String dictType,
|
||||||
List<SysDictData> data = dictTypeService.selectDictDataByType(dictType);
|
@RequestParam(value = "searchKey", required = false) String searchKey) {
|
||||||
|
List<SysDictData> data = dictTypeService.selectDictDataByType(dictType, searchKey);
|
||||||
if (StringUtils.isNull(data)) {
|
if (StringUtils.isNull(data)) {
|
||||||
data = new ArrayList<SysDictData>();
|
data = new ArrayList<SysDictData>();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,14 +1,5 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
@@ -17,6 +8,13 @@ import com.core.common.core.page.TableDataInfo;
|
|||||||
import com.core.common.enums.BusinessType;
|
import com.core.common.enums.BusinessType;
|
||||||
import com.core.common.utils.poi.ExcelUtil;
|
import com.core.common.utils.poi.ExcelUtil;
|
||||||
import com.core.system.service.ISysDictTypeService;
|
import com.core.system.service.ISysDictTypeService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 数据字典信息
|
* 数据字典信息
|
||||||
|
|||||||
@@ -1,11 +1,10 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import com.core.common.config.CoreConfig;
|
import com.core.common.config.CoreConfig;
|
||||||
import com.core.common.utils.StringUtils;
|
import com.core.common.utils.StringUtils;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 首页
|
* 首页
|
||||||
|
|||||||
@@ -1,14 +1,5 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
|
||||||
import org.springframework.web.bind.annotation.PostMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestBody;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import com.core.common.constant.Constants;
|
import com.core.common.constant.Constants;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
import com.core.common.core.domain.entity.SysMenu;
|
import com.core.common.core.domain.entity.SysMenu;
|
||||||
@@ -20,6 +11,15 @@ import com.core.framework.web.service.SysLoginService;
|
|||||||
import com.core.framework.web.service.SysPermissionService;
|
import com.core.framework.web.service.SysPermissionService;
|
||||||
import com.core.framework.web.service.TokenService;
|
import com.core.framework.web.service.TokenService;
|
||||||
import com.core.system.service.ISysMenuService;
|
import com.core.system.service.ISysMenuService;
|
||||||
|
import com.core.system.service.ISysTenantService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
import org.springframework.web.bind.annotation.PostMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
/**已评审
|
/**已评审
|
||||||
* 登录验证
|
* 登录验证
|
||||||
@@ -40,6 +40,9 @@ public class SysLoginController {
|
|||||||
@Autowired
|
@Autowired
|
||||||
private TokenService tokenService;
|
private TokenService tokenService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private ISysTenantService tenantService;
|
||||||
|
|
||||||
/**已评审
|
/**已评审
|
||||||
* 登录方法
|
* 登录方法
|
||||||
*
|
*
|
||||||
@@ -73,12 +76,22 @@ public class SysLoginController {
|
|||||||
loginUser.setPermissions(permissions);
|
loginUser.setPermissions(permissions);
|
||||||
tokenService.refreshToken(loginUser);
|
tokenService.refreshToken(loginUser);
|
||||||
}
|
}
|
||||||
|
// 获取租户名称
|
||||||
|
String tenantName = null;
|
||||||
|
if (loginUser.getTenantId() != null) {
|
||||||
|
com.core.system.domain.SysTenant tenant = tenantService.getById(loginUser.getTenantId());
|
||||||
|
if (tenant != null) {
|
||||||
|
tenantName = tenant.getTenantName();
|
||||||
|
}
|
||||||
|
}
|
||||||
AjaxResult ajax = AjaxResult.success();
|
AjaxResult ajax = AjaxResult.success();
|
||||||
ajax.put("optionJson", loginUser.getOptionJson());
|
ajax.put("optionJson", loginUser.getOptionJson());
|
||||||
|
ajax.put("optionMap", loginUser.getOptionMap());
|
||||||
ajax.put("practitionerId", String.valueOf(loginUser.getPractitionerId()));
|
ajax.put("practitionerId", String.valueOf(loginUser.getPractitionerId()));
|
||||||
ajax.put("user", user);
|
ajax.put("user", user);
|
||||||
ajax.put("roles", roles);
|
ajax.put("roles", roles);
|
||||||
ajax.put("permissions", permissions);
|
ajax.put("permissions", permissions);
|
||||||
|
ajax.put("tenantName", tenantName);
|
||||||
return ajax;
|
return ajax;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,12 +1,5 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.constant.UserConstants;
|
import com.core.common.constant.UserConstants;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
@@ -15,6 +8,12 @@ import com.core.common.core.domain.entity.SysMenu;
|
|||||||
import com.core.common.enums.BusinessType;
|
import com.core.common.enums.BusinessType;
|
||||||
import com.core.common.utils.StringUtils;
|
import com.core.common.utils.StringUtils;
|
||||||
import com.core.system.service.ISysMenuService;
|
import com.core.system.service.ISysMenuService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 菜单信息
|
* 菜单信息
|
||||||
|
|||||||
@@ -1,19 +1,21 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
import com.core.common.annotation.Log;
|
||||||
|
import com.core.common.core.controller.BaseController;
|
||||||
|
import com.core.common.core.domain.AjaxResult;
|
||||||
|
import com.core.common.core.domain.entity.SysUser;
|
||||||
|
import com.core.common.core.domain.model.LoginUser;
|
||||||
|
import com.core.common.core.page.TableDataInfo;
|
||||||
|
import com.core.common.enums.BusinessType;
|
||||||
|
import com.core.system.domain.SysNotice;
|
||||||
|
import com.core.system.service.ISysNoticeReadService;
|
||||||
|
import com.core.system.service.ISysNoticeService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
import org.springframework.validation.annotation.Validated;
|
import org.springframework.validation.annotation.Validated;
|
||||||
import org.springframework.web.bind.annotation.*;
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import java.util.List;
|
||||||
import com.core.common.core.controller.BaseController;
|
|
||||||
import com.core.common.core.domain.AjaxResult;
|
|
||||||
import com.core.common.core.page.TableDataInfo;
|
|
||||||
import com.core.common.enums.BusinessType;
|
|
||||||
import com.core.system.domain.SysNotice;
|
|
||||||
import com.core.system.service.ISysNoticeService;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 公告 信息操作处理
|
* 公告 信息操作处理
|
||||||
@@ -26,6 +28,9 @@ public class SysNoticeController extends BaseController {
|
|||||||
@Autowired
|
@Autowired
|
||||||
private ISysNoticeService noticeService;
|
private ISysNoticeService noticeService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private ISysNoticeReadService noticeReadService;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取通知公告列表
|
* 获取通知公告列表
|
||||||
*/
|
*/
|
||||||
@@ -37,6 +42,108 @@ public class SysNoticeController extends BaseController {
|
|||||||
return getDataTable(list);
|
return getDataTable(list);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取当前用户的公告列表(公开接口)
|
||||||
|
* 公告类型:通常 noticeType = '1' 代表通知,noticeType = '2' 代表公告
|
||||||
|
*/
|
||||||
|
@GetMapping("/public/list")
|
||||||
|
public TableDataInfo getPublicList(SysNotice notice) {
|
||||||
|
// 只查询状态为正常(0)且已发布(1)的公告
|
||||||
|
notice.setStatus("0");
|
||||||
|
notice.setPublishStatus("1");
|
||||||
|
// 公告类型设置为 '2'(公告)
|
||||||
|
notice.setNoticeType("2");
|
||||||
|
// 设置分页参数
|
||||||
|
startPage();
|
||||||
|
List<SysNotice> list = noticeService.selectNoticeList(notice);
|
||||||
|
return getDataTable(list);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取当前用户的通知列表(公开接口)
|
||||||
|
* 通知类型:通常 noticeType = '1' 代表通知,noticeType = '2' 代表公告
|
||||||
|
* 返回已发布且状态正常的所有公告和通知,并标注已读状态
|
||||||
|
* 按优先级排序,高优先级在前
|
||||||
|
*/
|
||||||
|
@GetMapping("/public/notice")
|
||||||
|
public AjaxResult getUserNotices() {
|
||||||
|
// 获取当前用户信息
|
||||||
|
LoginUser loginUser = getLoginUser();
|
||||||
|
SysUser currentUser = loginUser.getUser();
|
||||||
|
|
||||||
|
// 查询已发布且状态正常的所有公告和通知
|
||||||
|
SysNotice notice = new SysNotice();
|
||||||
|
notice.setStatus("0");
|
||||||
|
notice.setPublishStatus("1");
|
||||||
|
|
||||||
|
List<SysNotice> list = noticeService.selectNoticeList(notice);
|
||||||
|
|
||||||
|
// 按优先级排序(1高 2中 3低),相同优先级按创建时间降序
|
||||||
|
list.sort((a, b) -> {
|
||||||
|
String priorityA = a.getPriority() != null ? a.getPriority() : "3";
|
||||||
|
String priorityB = b.getPriority() != null ? b.getPriority() : "3";
|
||||||
|
int priorityCompare = priorityA.compareTo(priorityB);
|
||||||
|
if (priorityCompare != 0) {
|
||||||
|
return priorityCompare;
|
||||||
|
}
|
||||||
|
// 相同优先级,按创建时间降序
|
||||||
|
return b.getCreateTime().compareTo(a.getCreateTime());
|
||||||
|
});
|
||||||
|
|
||||||
|
// 获取用户已读的公告/通知ID列表
|
||||||
|
List<Long> readIds = noticeReadService.selectReadNoticeIdsByUserId(currentUser.getUserId());
|
||||||
|
|
||||||
|
// 为每个公告/通知添加已读状态
|
||||||
|
for (SysNotice item : list) {
|
||||||
|
boolean isRead = readIds.contains(item.getNoticeId());
|
||||||
|
item.setIsRead(isRead);
|
||||||
|
}
|
||||||
|
|
||||||
|
return success(list);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取用户未读公告/通知数量(公开接口)
|
||||||
|
*/
|
||||||
|
@GetMapping("/public/unread/count")
|
||||||
|
public AjaxResult getUnreadCount() {
|
||||||
|
LoginUser loginUser = getLoginUser();
|
||||||
|
SysUser currentUser = loginUser.getUser();
|
||||||
|
int count = noticeReadService.getUnreadCount(currentUser.getUserId());
|
||||||
|
return success(count);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 标记公告/通知为已读(公开接口)
|
||||||
|
*/
|
||||||
|
@PostMapping("/public/read/{noticeId}")
|
||||||
|
public AjaxResult markAsRead(@PathVariable Long noticeId) {
|
||||||
|
LoginUser loginUser = getLoginUser();
|
||||||
|
SysUser currentUser = loginUser.getUser();
|
||||||
|
return noticeReadService.markAsRead(noticeId, currentUser.getUserId());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 批量标记公告/通知为已读(公开接口)
|
||||||
|
*/
|
||||||
|
@PostMapping("/public/read/all")
|
||||||
|
public AjaxResult markAllAsRead(@RequestBody Long[] noticeIds) {
|
||||||
|
LoginUser loginUser = getLoginUser();
|
||||||
|
SysUser currentUser = loginUser.getUser();
|
||||||
|
return noticeReadService.markAllAsRead(noticeIds, currentUser.getUserId());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取用户已读公告/通知ID列表(公开接口)
|
||||||
|
*/
|
||||||
|
@GetMapping("/public/read/ids")
|
||||||
|
public AjaxResult getReadNoticeIds() {
|
||||||
|
LoginUser loginUser = getLoginUser();
|
||||||
|
SysUser currentUser = loginUser.getUser();
|
||||||
|
List<Long> readIds = noticeReadService.selectReadNoticeIdsByUserId(currentUser.getUserId());
|
||||||
|
return success(readIds);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据通知公告编号获取详细信息
|
* 根据通知公告编号获取详细信息
|
||||||
*/
|
*/
|
||||||
@@ -54,6 +161,14 @@ public class SysNoticeController extends BaseController {
|
|||||||
@PostMapping
|
@PostMapping
|
||||||
public AjaxResult add(@Validated @RequestBody SysNotice notice) {
|
public AjaxResult add(@Validated @RequestBody SysNotice notice) {
|
||||||
notice.setCreateBy(getUsername());
|
notice.setCreateBy(getUsername());
|
||||||
|
// 新建的公告默认为未发布状态
|
||||||
|
if (notice.getPublishStatus() == null || notice.getPublishStatus().isEmpty()) {
|
||||||
|
notice.setPublishStatus("0");
|
||||||
|
}
|
||||||
|
// 设置默认优先级为中(2)
|
||||||
|
if (notice.getPriority() == null || notice.getPriority().isEmpty()) {
|
||||||
|
notice.setPriority("2");
|
||||||
|
}
|
||||||
return toAjax(noticeService.insertNotice(notice));
|
return toAjax(noticeService.insertNotice(notice));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -77,4 +192,42 @@ public class SysNoticeController extends BaseController {
|
|||||||
public AjaxResult remove(@PathVariable Long[] noticeIds) {
|
public AjaxResult remove(@PathVariable Long[] noticeIds) {
|
||||||
return toAjax(noticeService.deleteNoticeByIds(noticeIds));
|
return toAjax(noticeService.deleteNoticeByIds(noticeIds));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 发布公告/通知
|
||||||
|
*/
|
||||||
|
@PreAuthorize("@ss.hasPermi('system:notice:edit')")
|
||||||
|
@Log(title = "发布公告", businessType = BusinessType.UPDATE)
|
||||||
|
@PutMapping("/publish/{noticeId}")
|
||||||
|
public AjaxResult publish(@PathVariable Long noticeId) {
|
||||||
|
SysNotice notice = noticeService.selectNoticeById(noticeId);
|
||||||
|
if (notice == null) {
|
||||||
|
return error("公告不存在");
|
||||||
|
}
|
||||||
|
if ("1".equals(notice.getPublishStatus())) {
|
||||||
|
return error("该公告已发布");
|
||||||
|
}
|
||||||
|
notice.setPublishStatus("1");
|
||||||
|
notice.setUpdateBy(getUsername());
|
||||||
|
return toAjax(noticeService.updateNotice(notice));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 取消发布公告/通知
|
||||||
|
*/
|
||||||
|
@PreAuthorize("@ss.hasPermi('system:notice:edit')")
|
||||||
|
@Log(title = "取消发布", businessType = BusinessType.UPDATE)
|
||||||
|
@PutMapping("/unpublish/{noticeId}")
|
||||||
|
public AjaxResult unpublish(@PathVariable Long noticeId) {
|
||||||
|
SysNotice notice = noticeService.selectNoticeById(noticeId);
|
||||||
|
if (notice == null) {
|
||||||
|
return error("公告不存在");
|
||||||
|
}
|
||||||
|
if ("0".equals(notice.getPublishStatus())) {
|
||||||
|
return error("该公告未发布");
|
||||||
|
}
|
||||||
|
notice.setPublishStatus("0");
|
||||||
|
notice.setUpdateBy(getUsername());
|
||||||
|
return toAjax(noticeService.updateNotice(notice));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,14 +1,5 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
@@ -17,6 +8,13 @@ import com.core.common.enums.BusinessType;
|
|||||||
import com.core.common.utils.poi.ExcelUtil;
|
import com.core.common.utils.poi.ExcelUtil;
|
||||||
import com.core.system.domain.SysPost;
|
import com.core.system.domain.SysPost;
|
||||||
import com.core.system.service.ISysPostService;
|
import com.core.system.service.ISysPostService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 岗位信息操作处理
|
* 岗位信息操作处理
|
||||||
|
|||||||
@@ -1,9 +1,5 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
import org.springframework.web.multipart.MultipartFile;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.config.CoreConfig;
|
import com.core.common.config.CoreConfig;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
@@ -17,6 +13,9 @@ import com.core.common.utils.file.FileUploadUtils;
|
|||||||
import com.core.common.utils.file.MimeTypeUtils;
|
import com.core.common.utils.file.MimeTypeUtils;
|
||||||
import com.core.framework.web.service.TokenService;
|
import com.core.framework.web.service.TokenService;
|
||||||
import com.core.system.service.ISysUserService;
|
import com.core.system.service.ISysUserService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
import org.springframework.web.multipart.MultipartFile;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 个人信息 业务处理
|
* 个人信息 业务处理
|
||||||
|
|||||||
@@ -1,16 +1,15 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.web.bind.annotation.PostMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestBody;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
import com.core.common.core.domain.model.RegisterBody;
|
import com.core.common.core.domain.model.RegisterBody;
|
||||||
import com.core.common.utils.StringUtils;
|
import com.core.common.utils.StringUtils;
|
||||||
import com.core.framework.web.service.SysRegisterService;
|
import com.core.framework.web.service.SysRegisterService;
|
||||||
import com.core.system.service.ISysConfigService;
|
import com.core.system.service.ISysConfigService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.PostMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 注册验证
|
* 注册验证
|
||||||
|
|||||||
@@ -1,14 +1,5 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
@@ -26,6 +17,13 @@ import com.core.system.domain.SysUserRole;
|
|||||||
import com.core.system.service.ISysDeptService;
|
import com.core.system.service.ISysDeptService;
|
||||||
import com.core.system.service.ISysRoleService;
|
import com.core.system.service.ISysRoleService;
|
||||||
import com.core.system.service.ISysUserService;
|
import com.core.system.service.ISysUserService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 角色信息
|
* 角色信息
|
||||||
|
|||||||
@@ -1,11 +1,5 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||||
import com.core.common.annotation.Anonymous;
|
import com.core.common.annotation.Anonymous;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
@@ -13,6 +7,11 @@ import com.core.common.core.domain.R;
|
|||||||
import com.core.common.core.domain.entity.SysUser;
|
import com.core.common.core.domain.entity.SysUser;
|
||||||
import com.core.system.domain.SysTenant;
|
import com.core.system.domain.SysTenant;
|
||||||
import com.core.system.service.ISysTenantService;
|
import com.core.system.service.ISysTenantService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 租户信息controller
|
* 租户信息controller
|
||||||
|
|||||||
@@ -1,16 +1,15 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
import com.core.common.core.domain.R;
|
import com.core.common.core.domain.R;
|
||||||
import com.core.system.domain.dto.SaveTenantOptionDetailDto;
|
import com.core.system.domain.dto.SaveTenantOptionDetailDto;
|
||||||
import com.core.system.domain.dto.TenantOptionDto;
|
import com.core.system.domain.dto.TenantOptionDto;
|
||||||
import com.core.system.service.ISysTenantOptionService;
|
import com.core.system.service.ISysTenantOptionService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 租户配置项信息controller
|
* 租户配置项信息controller
|
||||||
|
|||||||
@@ -1,17 +1,5 @@
|
|||||||
package com.core.web.controller.system;
|
package com.core.web.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.ArrayUtils;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
import org.springframework.web.multipart.MultipartFile;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Log;
|
import com.core.common.annotation.Log;
|
||||||
import com.core.common.core.controller.BaseController;
|
import com.core.common.core.controller.BaseController;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
@@ -27,6 +15,16 @@ import com.core.system.service.ISysDeptService;
|
|||||||
import com.core.system.service.ISysPostService;
|
import com.core.system.service.ISysPostService;
|
||||||
import com.core.system.service.ISysRoleService;
|
import com.core.system.service.ISysRoleService;
|
||||||
import com.core.system.service.ISysUserService;
|
import com.core.system.service.ISysUserService;
|
||||||
|
import org.apache.commons.lang3.ArrayUtils;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
import org.springframework.web.multipart.MultipartFile;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 用户信息
|
* 用户信息
|
||||||
|
|||||||
@@ -1,18 +1,16 @@
|
|||||||
package com.core.web.controller.tool;
|
package com.core.web.controller.tool;
|
||||||
|
|
||||||
|
import com.core.common.core.controller.BaseController;
|
||||||
|
import com.core.common.core.domain.R;
|
||||||
|
import com.core.common.utils.StringUtils;
|
||||||
|
import io.swagger.annotations.*;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.core.controller.BaseController;
|
|
||||||
import com.core.common.core.domain.R;
|
|
||||||
import com.core.common.utils.StringUtils;
|
|
||||||
|
|
||||||
import io.swagger.annotations.*;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* swagger 用户测试方法
|
* swagger 用户测试方法
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,17 +1,12 @@
|
|||||||
package com.core.web.core.config;
|
package com.core.web.core.config;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import com.core.common.config.CoreConfig;
|
||||||
import java.util.List;
|
import io.swagger.annotations.ApiOperation;
|
||||||
|
import io.swagger.models.auth.In;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.beans.factory.annotation.Value;
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
import org.springframework.context.annotation.Configuration;
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
|
||||||
import com.core.common.config.CoreConfig;
|
|
||||||
|
|
||||||
import io.swagger.annotations.ApiOperation;
|
|
||||||
import io.swagger.models.auth.In;
|
|
||||||
import springfox.documentation.builders.ApiInfoBuilder;
|
import springfox.documentation.builders.ApiInfoBuilder;
|
||||||
import springfox.documentation.builders.PathSelectors;
|
import springfox.documentation.builders.PathSelectors;
|
||||||
import springfox.documentation.builders.RequestHandlerSelectors;
|
import springfox.documentation.builders.RequestHandlerSelectors;
|
||||||
@@ -20,6 +15,9 @@ import springfox.documentation.spi.DocumentationType;
|
|||||||
import springfox.documentation.spi.service.contexts.SecurityContext;
|
import springfox.documentation.spi.service.contexts.SecurityContext;
|
||||||
import springfox.documentation.spring.web.plugins.Docket;
|
import springfox.documentation.spring.web.plugins.Docket;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Swagger2的接口配置
|
* Swagger2的接口配置
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ package com.core.web.util;
|
|||||||
import com.core.common.core.domain.model.LoginUser;
|
import com.core.common.core.domain.model.LoginUser;
|
||||||
import com.core.common.enums.TenantOptionDict;
|
import com.core.common.enums.TenantOptionDict;
|
||||||
import com.core.common.utils.SecurityUtils;
|
import com.core.common.utils.SecurityUtils;
|
||||||
|
import com.core.common.utils.StringUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 租户配置工具类
|
* 租户配置工具类
|
||||||
@@ -30,7 +31,12 @@ public class TenantOptionUtil {
|
|||||||
if (loginUser.getOptionMap() == null || loginUser.getOptionMap().isEmpty()) {
|
if (loginUser.getOptionMap() == null || loginUser.getOptionMap().isEmpty()) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return loginUser.getOptionMap().get(optionDict.getCode());
|
// return loginUser.getOptionMap().get(optionDict.getCode());
|
||||||
|
|
||||||
|
// TODO:2025/10/17 李永兴提出的sys_option切换TenantOption临时防止报错方案,最晚2025年11月底删除
|
||||||
|
String newValue = loginUser.getOptionMap().get(optionDict.getCode());
|
||||||
|
String oldValue = loginUser.getOptionJson().getString(optionDict.getCode());
|
||||||
|
return StringUtils.isEmpty(newValue) ? oldValue : newValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,6 +16,31 @@
|
|||||||
common通用工具
|
common通用工具
|
||||||
</description>
|
</description>
|
||||||
|
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
|
<version>3.8.1</version>
|
||||||
|
<configuration>
|
||||||
|
<source>17</source>
|
||||||
|
<target>17</target>
|
||||||
|
<encoding>UTF-8</encoding>
|
||||||
|
<compilerArgs>
|
||||||
|
<arg>-parameters</arg>
|
||||||
|
</compilerArgs>
|
||||||
|
<annotationProcessorPaths>
|
||||||
|
<path>
|
||||||
|
<groupId>org.projectlombok</groupId>
|
||||||
|
<artifactId>lombok</artifactId>
|
||||||
|
<version>1.18.34</version>
|
||||||
|
</path>
|
||||||
|
</annotationProcessorPaths>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
|
|
||||||
<!-- mybatis-plus 增强CRUD -->
|
<!-- mybatis-plus 增强CRUD -->
|
||||||
@@ -54,6 +79,12 @@
|
|||||||
<artifactId>pagehelper-spring-boot-starter</artifactId>
|
<artifactId>pagehelper-spring-boot-starter</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<!-- jsr250 annotations -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>javax.annotation</groupId>
|
||||||
|
<artifactId>javax.annotation-api</artifactId>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<!-- 自定义验证注解 -->
|
<!-- 自定义验证注解 -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
@@ -77,10 +108,6 @@
|
|||||||
<groupId>com.alibaba.fastjson2</groupId>
|
<groupId>com.alibaba.fastjson2</groupId>
|
||||||
<artifactId>fastjson2</artifactId>
|
<artifactId>fastjson2</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
|
||||||
<groupId>com.alibaba</groupId>
|
|
||||||
<artifactId>fastjson</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- io常用工具类 -->
|
<!-- io常用工具类 -->
|
||||||
<dependency>
|
<dependency>
|
||||||
@@ -140,6 +167,12 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.belerweb</groupId>
|
<groupId>com.belerweb</groupId>
|
||||||
<artifactId>pinyin4j</artifactId>
|
<artifactId>pinyin4j</artifactId>
|
||||||
|
<version>2.5.1</version>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.google.code.gson</groupId>
|
||||||
|
<artifactId>gson</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
package com.core.common.annotation;
|
package com.core.common.annotation;
|
||||||
|
|
||||||
import java.lang.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.enums.DataSourceType;
|
import com.core.common.enums.DataSourceType;
|
||||||
|
|
||||||
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 自定义多数据源切换注解
|
* 自定义多数据源切换注解
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,16 +1,15 @@
|
|||||||
package com.core.common.annotation;
|
package com.core.common.annotation;
|
||||||
|
|
||||||
|
import com.core.common.utils.poi.ExcelHandlerAdapter;
|
||||||
|
import org.apache.poi.ss.usermodel.HorizontalAlignment;
|
||||||
|
import org.apache.poi.ss.usermodel.IndexedColors;
|
||||||
|
|
||||||
import java.lang.annotation.ElementType;
|
import java.lang.annotation.ElementType;
|
||||||
import java.lang.annotation.Retention;
|
import java.lang.annotation.Retention;
|
||||||
import java.lang.annotation.RetentionPolicy;
|
import java.lang.annotation.RetentionPolicy;
|
||||||
import java.lang.annotation.Target;
|
import java.lang.annotation.Target;
|
||||||
import java.math.BigDecimal;
|
import java.math.BigDecimal;
|
||||||
|
|
||||||
import org.apache.poi.ss.usermodel.HorizontalAlignment;
|
|
||||||
import org.apache.poi.ss.usermodel.IndexedColors;
|
|
||||||
|
|
||||||
import com.core.common.utils.poi.ExcelHandlerAdapter;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 自定义导出Excel数据注解
|
* 自定义导出Excel数据注解
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -0,0 +1,38 @@
|
|||||||
|
package com.core.common.annotation;
|
||||||
|
|
||||||
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Excel额外表头信息注解
|
||||||
|
*
|
||||||
|
* @author swb
|
||||||
|
*/
|
||||||
|
@Target(ElementType.FIELD)
|
||||||
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
|
@Documented
|
||||||
|
public @interface ExcelExtra {
|
||||||
|
/**
|
||||||
|
* 表头名称
|
||||||
|
*/
|
||||||
|
String name();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 日期格式,如:yyyy-MM-dd HH:mm:ss
|
||||||
|
*/
|
||||||
|
String dateFormat() default "";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 排序(越小越靠前)
|
||||||
|
*/
|
||||||
|
int sort() default 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 默认值
|
||||||
|
*/
|
||||||
|
String defaultValue() default "";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否导出
|
||||||
|
*/
|
||||||
|
boolean isExport() default true;
|
||||||
|
}
|
||||||
@@ -1,10 +1,10 @@
|
|||||||
package com.core.common.annotation;
|
package com.core.common.annotation;
|
||||||
|
|
||||||
import java.lang.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.enums.BusinessType;
|
import com.core.common.enums.BusinessType;
|
||||||
import com.core.common.enums.OperatorType;
|
import com.core.common.enums.OperatorType;
|
||||||
|
|
||||||
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 自定义操作日志记录注解
|
* 自定义操作日志记录注解
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
package com.core.common.annotation;
|
package com.core.common.annotation;
|
||||||
|
|
||||||
import java.lang.annotation.*;
|
|
||||||
|
|
||||||
import com.core.common.constant.CacheConstants;
|
import com.core.common.constant.CacheConstants;
|
||||||
import com.core.common.enums.LimitType;
|
import com.core.common.enums.LimitType;
|
||||||
|
|
||||||
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 限流注解
|
* 限流注解
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,15 +1,15 @@
|
|||||||
package com.core.common.annotation;
|
package com.core.common.annotation;
|
||||||
|
|
||||||
import java.lang.annotation.ElementType;
|
|
||||||
import java.lang.annotation.Retention;
|
|
||||||
import java.lang.annotation.RetentionPolicy;
|
|
||||||
import java.lang.annotation.Target;
|
|
||||||
|
|
||||||
import com.core.common.config.serializer.SensitiveJsonSerializer;
|
import com.core.common.config.serializer.SensitiveJsonSerializer;
|
||||||
import com.core.common.enums.DesensitizedType;
|
import com.core.common.enums.DesensitizedType;
|
||||||
import com.fasterxml.jackson.annotation.JacksonAnnotationsInside;
|
import com.fasterxml.jackson.annotation.JacksonAnnotationsInside;
|
||||||
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
|
||||||
|
import java.lang.annotation.ElementType;
|
||||||
|
import java.lang.annotation.Retention;
|
||||||
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
import java.lang.annotation.Target;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 数据脱敏注解
|
* 数据脱敏注解
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,8 +1,5 @@
|
|||||||
package com.core.common.config.serializer;
|
package com.core.common.config.serializer;
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.Objects;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Sensitive;
|
import com.core.common.annotation.Sensitive;
|
||||||
import com.core.common.core.domain.model.LoginUser;
|
import com.core.common.core.domain.model.LoginUser;
|
||||||
import com.core.common.enums.DesensitizedType;
|
import com.core.common.enums.DesensitizedType;
|
||||||
@@ -14,6 +11,9 @@ import com.fasterxml.jackson.databind.JsonSerializer;
|
|||||||
import com.fasterxml.jackson.databind.SerializerProvider;
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
import com.fasterxml.jackson.databind.ser.ContextualSerializer;
|
import com.fasterxml.jackson.databind.ser.ContextualSerializer;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 数据脱敏序列化过滤
|
* 数据脱敏序列化过滤
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
package com.core.common.constant;
|
package com.core.common.constant;
|
||||||
|
|
||||||
import java.util.Locale;
|
|
||||||
|
|
||||||
import io.jsonwebtoken.Claims;
|
import io.jsonwebtoken.Claims;
|
||||||
|
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 通用常量信息
|
* 通用常量信息
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,14 +1,5 @@
|
|||||||
package com.core.common.core.controller;
|
package com.core.common.core.controller;
|
||||||
|
|
||||||
import java.beans.PropertyEditorSupport;
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.web.bind.WebDataBinder;
|
|
||||||
import org.springframework.web.bind.annotation.InitBinder;
|
|
||||||
|
|
||||||
import com.core.common.constant.HttpStatus;
|
import com.core.common.constant.HttpStatus;
|
||||||
import com.core.common.core.domain.AjaxResult;
|
import com.core.common.core.domain.AjaxResult;
|
||||||
import com.core.common.core.domain.model.LoginUser;
|
import com.core.common.core.domain.model.LoginUser;
|
||||||
@@ -22,6 +13,14 @@ import com.core.common.utils.StringUtils;
|
|||||||
import com.core.common.utils.sql.SqlUtil;
|
import com.core.common.utils.sql.SqlUtil;
|
||||||
import com.github.pagehelper.PageHelper;
|
import com.github.pagehelper.PageHelper;
|
||||||
import com.github.pagehelper.PageInfo;
|
import com.github.pagehelper.PageInfo;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.springframework.web.bind.WebDataBinder;
|
||||||
|
import org.springframework.web.bind.annotation.InitBinder;
|
||||||
|
|
||||||
|
import java.beans.PropertyEditorSupport;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* web层通用数据处理
|
* web层通用数据处理
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
package com.core.common.core.domain;
|
package com.core.common.core.domain;
|
||||||
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Objects;
|
|
||||||
|
|
||||||
import com.core.common.constant.HttpStatus;
|
import com.core.common.constant.HttpStatus;
|
||||||
import com.core.common.utils.StringUtils;
|
import com.core.common.utils.StringUtils;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 操作消息提醒
|
* 操作消息提醒
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,15 +1,15 @@
|
|||||||
package com.core.common.core.domain;
|
package com.core.common.core.domain;
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableField;
|
import com.baomidou.mybatisplus.annotation.TableField;
|
||||||
import com.fasterxml.jackson.annotation.JsonFormat;
|
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
import com.fasterxml.jackson.annotation.JsonInclude;
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Entity基类
|
* Entity基类
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,16 +1,15 @@
|
|||||||
package com.core.common.core.domain;
|
package com.core.common.core.domain;
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.Date;
|
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.FieldFill;
|
import com.baomidou.mybatisplus.annotation.FieldFill;
|
||||||
import com.baomidou.mybatisplus.annotation.TableField;
|
import com.baomidou.mybatisplus.annotation.TableField;
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableLogic;
|
import com.baomidou.mybatisplus.annotation.TableLogic;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
import lombok.experimental.Accessors;
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Entity基类
|
* Entity基类
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
package com.core.common.core.domain;
|
package com.core.common.core.domain;
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
|
|
||||||
import com.core.common.constant.HttpStatus;
|
import com.core.common.constant.HttpStatus;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 响应信息主体
|
* 响应信息主体
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,13 +1,13 @@
|
|||||||
package com.core.common.core.domain;
|
package com.core.common.core.domain;
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
import com.core.common.core.domain.entity.SysDept;
|
import com.core.common.core.domain.entity.SysDept;
|
||||||
import com.core.common.core.domain.entity.SysMenu;
|
import com.core.common.core.domain.entity.SysMenu;
|
||||||
import com.fasterxml.jackson.annotation.JsonInclude;
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Treeselect树结构实体类
|
* Treeselect树结构实体类
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,17 +1,15 @@
|
|||||||
package com.core.common.core.domain.entity;
|
package com.core.common.core.domain.entity;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import com.core.common.core.domain.BaseEntity;
|
||||||
import java.util.List;
|
import org.apache.commons.lang3.builder.ToStringBuilder;
|
||||||
|
import org.apache.commons.lang3.builder.ToStringStyle;
|
||||||
|
|
||||||
import javax.validation.constraints.Email;
|
import javax.validation.constraints.Email;
|
||||||
import javax.validation.constraints.NotBlank;
|
import javax.validation.constraints.NotBlank;
|
||||||
import javax.validation.constraints.NotNull;
|
import javax.validation.constraints.NotNull;
|
||||||
import javax.validation.constraints.Size;
|
import javax.validation.constraints.Size;
|
||||||
|
import java.util.ArrayList;
|
||||||
import org.apache.commons.lang3.builder.ToStringBuilder;
|
import java.util.List;
|
||||||
import org.apache.commons.lang3.builder.ToStringStyle;
|
|
||||||
|
|
||||||
import com.core.common.core.domain.BaseEntity;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 部门表 sys_dept
|
* 部门表 sys_dept
|
||||||
|
|||||||
@@ -1,15 +1,14 @@
|
|||||||
package com.core.common.core.domain.entity;
|
package com.core.common.core.domain.entity;
|
||||||
|
|
||||||
import javax.validation.constraints.NotBlank;
|
|
||||||
import javax.validation.constraints.Size;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.builder.ToStringBuilder;
|
|
||||||
import org.apache.commons.lang3.builder.ToStringStyle;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Excel;
|
import com.core.common.annotation.Excel;
|
||||||
import com.core.common.annotation.Excel.ColumnType;
|
import com.core.common.annotation.Excel.ColumnType;
|
||||||
import com.core.common.constant.UserConstants;
|
import com.core.common.constant.UserConstants;
|
||||||
import com.core.common.core.domain.BaseEntity;
|
import com.core.common.core.domain.BaseEntity;
|
||||||
|
import org.apache.commons.lang3.builder.ToStringBuilder;
|
||||||
|
import org.apache.commons.lang3.builder.ToStringStyle;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotBlank;
|
||||||
|
import javax.validation.constraints.Size;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字典数据表 sys_dict_data
|
* 字典数据表 sys_dict_data
|
||||||
@@ -53,6 +52,9 @@ public class SysDictData extends BaseEntity {
|
|||||||
@Excel(name = "状态", readConverterExp = "0=正常,1=停用")
|
@Excel(name = "状态", readConverterExp = "0=正常,1=停用")
|
||||||
private String status;
|
private String status;
|
||||||
|
|
||||||
|
/** 拼音首字母 */
|
||||||
|
private String pyStr;
|
||||||
|
|
||||||
public Long getDictCode() {
|
public Long getDictCode() {
|
||||||
return dictCode;
|
return dictCode;
|
||||||
}
|
}
|
||||||
@@ -136,13 +138,21 @@ public class SysDictData extends BaseEntity {
|
|||||||
this.status = status;
|
this.status = status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getPyStr() {
|
||||||
|
return pyStr;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPyStr(String pyStr) {
|
||||||
|
this.pyStr = pyStr;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE).append("dictCode", getDictCode())
|
return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE).append("dictCode", getDictCode())
|
||||||
.append("dictSort", getDictSort()).append("dictLabel", getDictLabel()).append("dictValue", getDictValue())
|
.append("dictSort", getDictSort()).append("dictLabel", getDictLabel()).append("dictValue", getDictValue())
|
||||||
.append("dictType", getDictType()).append("cssClass", getCssClass()).append("listClass", getListClass())
|
.append("dictType", getDictType()).append("cssClass", getCssClass()).append("listClass", getListClass())
|
||||||
.append("isDefault", getIsDefault()).append("status", getStatus()).append("createBy", getCreateBy())
|
.append("isDefault", getIsDefault()).append("status", getStatus()).append("pyStr", getPyStr())
|
||||||
.append("createTime", getCreateTime()).append("updateBy", getUpdateBy())
|
.append("createBy", getCreateBy()).append("createTime", getCreateTime()).append("updateBy", getUpdateBy())
|
||||||
.append("updateTime", getUpdateTime()).append("remark", getRemark()).toString();
|
.append("updateTime", getUpdateTime()).append("remark", getRemark()).toString();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,15 +1,14 @@
|
|||||||
package com.core.common.core.domain.entity;
|
package com.core.common.core.domain.entity;
|
||||||
|
|
||||||
import javax.validation.constraints.NotBlank;
|
|
||||||
import javax.validation.constraints.Pattern;
|
|
||||||
import javax.validation.constraints.Size;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.builder.ToStringBuilder;
|
|
||||||
import org.apache.commons.lang3.builder.ToStringStyle;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Excel;
|
import com.core.common.annotation.Excel;
|
||||||
import com.core.common.annotation.Excel.ColumnType;
|
import com.core.common.annotation.Excel.ColumnType;
|
||||||
import com.core.common.core.domain.BaseEntity;
|
import com.core.common.core.domain.BaseEntity;
|
||||||
|
import org.apache.commons.lang3.builder.ToStringBuilder;
|
||||||
|
import org.apache.commons.lang3.builder.ToStringStyle;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotBlank;
|
||||||
|
import javax.validation.constraints.Pattern;
|
||||||
|
import javax.validation.constraints.Size;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字典类型表 sys_dict_type
|
* 字典类型表 sys_dict_type
|
||||||
|
|||||||
@@ -1,16 +1,14 @@
|
|||||||
package com.core.common.core.domain.entity;
|
package com.core.common.core.domain.entity;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import com.core.common.core.domain.BaseEntity;
|
||||||
import java.util.List;
|
import org.apache.commons.lang3.builder.ToStringBuilder;
|
||||||
|
import org.apache.commons.lang3.builder.ToStringStyle;
|
||||||
|
|
||||||
import javax.validation.constraints.NotBlank;
|
import javax.validation.constraints.NotBlank;
|
||||||
import javax.validation.constraints.NotNull;
|
import javax.validation.constraints.NotNull;
|
||||||
import javax.validation.constraints.Size;
|
import javax.validation.constraints.Size;
|
||||||
|
import java.util.ArrayList;
|
||||||
import org.apache.commons.lang3.builder.ToStringBuilder;
|
import java.util.List;
|
||||||
import org.apache.commons.lang3.builder.ToStringStyle;
|
|
||||||
|
|
||||||
import com.core.common.core.domain.BaseEntity;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 菜单权限表 sys_menu
|
* 菜单权限表 sys_menu
|
||||||
|
|||||||
@@ -1,17 +1,15 @@
|
|||||||
package com.core.common.core.domain.entity;
|
package com.core.common.core.domain.entity;
|
||||||
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import javax.validation.constraints.NotBlank;
|
|
||||||
import javax.validation.constraints.NotNull;
|
|
||||||
import javax.validation.constraints.Size;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.builder.ToStringBuilder;
|
|
||||||
import org.apache.commons.lang3.builder.ToStringStyle;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Excel;
|
import com.core.common.annotation.Excel;
|
||||||
import com.core.common.annotation.Excel.ColumnType;
|
import com.core.common.annotation.Excel.ColumnType;
|
||||||
import com.core.common.core.domain.BaseEntity;
|
import com.core.common.core.domain.BaseEntity;
|
||||||
|
import org.apache.commons.lang3.builder.ToStringBuilder;
|
||||||
|
import org.apache.commons.lang3.builder.ToStringStyle;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotBlank;
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
import javax.validation.constraints.Size;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 角色表 sys_role
|
* 角色表 sys_role
|
||||||
|
|||||||
@@ -1,16 +1,8 @@
|
|||||||
package com.core.common.core.domain.entity;
|
package com.core.common.core.domain.entity;
|
||||||
|
|
||||||
import java.util.Date;
|
import com.baomidou.mybatisplus.annotation.IdType;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.validation.constraints.Email;
|
|
||||||
import javax.validation.constraints.NotBlank;
|
|
||||||
import javax.validation.constraints.Size;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.builder.ToStringBuilder;
|
|
||||||
import org.apache.commons.lang3.builder.ToStringStyle;
|
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableField;
|
import com.baomidou.mybatisplus.annotation.TableField;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
import com.core.common.annotation.Excel;
|
import com.core.common.annotation.Excel;
|
||||||
import com.core.common.annotation.Excel.ColumnType;
|
import com.core.common.annotation.Excel.ColumnType;
|
||||||
import com.core.common.annotation.Excel.Type;
|
import com.core.common.annotation.Excel.Type;
|
||||||
@@ -19,8 +11,15 @@ import com.core.common.core.domain.BaseEntity;
|
|||||||
import com.core.common.xss.Xss;
|
import com.core.common.xss.Xss;
|
||||||
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
|
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
import org.apache.commons.lang3.builder.ToStringBuilder;
|
||||||
|
import org.apache.commons.lang3.builder.ToStringStyle;
|
||||||
|
|
||||||
|
import javax.validation.constraints.Email;
|
||||||
|
import javax.validation.constraints.NotBlank;
|
||||||
|
import javax.validation.constraints.Size;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 用户对象 sys_user
|
* 用户对象 sys_user
|
||||||
@@ -32,6 +31,7 @@ public class SysUser extends BaseEntity {
|
|||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
/** 用户ID */
|
/** 用户ID */
|
||||||
|
@TableId(type = IdType.ASSIGN_ID)
|
||||||
@Excel(name = "用户序号", type = Type.EXPORT, cellType = ColumnType.NUMERIC, prompt = "用户编号")
|
@Excel(name = "用户序号", type = Type.EXPORT, cellType = ColumnType.NUMERIC, prompt = "用户编号")
|
||||||
private Long userId;
|
private Long userId;
|
||||||
|
|
||||||
|
|||||||
@@ -1,20 +1,18 @@
|
|||||||
package com.core.common.core.domain.model;
|
package com.core.common.core.domain.model;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson2.JSONObject;
|
||||||
|
import com.alibaba.fastjson2.annotation.JSONField;
|
||||||
|
import com.core.common.core.domain.entity.SysRole;
|
||||||
|
import com.core.common.core.domain.entity.SysUser;
|
||||||
|
import lombok.Data;
|
||||||
|
import org.springframework.security.core.GrantedAuthority;
|
||||||
|
import org.springframework.security.core.userdetails.UserDetails;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import com.core.common.core.domain.entity.SysRole;
|
|
||||||
import org.springframework.security.core.GrantedAuthority;
|
|
||||||
import org.springframework.security.core.userdetails.UserDetails;
|
|
||||||
|
|
||||||
import com.alibaba.fastjson2.JSONObject;
|
|
||||||
import com.alibaba.fastjson2.annotation.JSONField;
|
|
||||||
import com.core.common.core.domain.entity.SysUser;
|
|
||||||
|
|
||||||
import lombok.Data;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 登录用户身份权限
|
* 登录用户身份权限
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,13 +1,16 @@
|
|||||||
package com.core.common.core.redis;
|
package com.core.common.core.redis;
|
||||||
|
|
||||||
import java.util.*;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
import com.core.common.exception.UtilException;
|
import com.core.common.exception.UtilException;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.data.redis.core.*;
|
import org.springframework.data.redis.core.BoundSetOperations;
|
||||||
|
import org.springframework.data.redis.core.HashOperations;
|
||||||
|
import org.springframework.data.redis.core.RedisTemplate;
|
||||||
|
import org.springframework.data.redis.core.ValueOperations;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* spring redis 工具类
|
* spring redis 工具类
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
package com.core.common.core.text;
|
package com.core.common.core.text;
|
||||||
|
|
||||||
|
import com.core.common.utils.StringUtils;
|
||||||
|
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
|
|
||||||
import com.core.common.utils.StringUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字符集工具类
|
* 字符集工具类
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,5 +1,8 @@
|
|||||||
package com.core.common.core.text;
|
package com.core.common.core.text;
|
||||||
|
|
||||||
|
import com.core.common.utils.StringUtils;
|
||||||
|
import org.apache.commons.lang3.ArrayUtils;
|
||||||
|
|
||||||
import java.math.BigDecimal;
|
import java.math.BigDecimal;
|
||||||
import java.math.BigInteger;
|
import java.math.BigInteger;
|
||||||
import java.math.RoundingMode;
|
import java.math.RoundingMode;
|
||||||
@@ -8,10 +11,6 @@ import java.nio.charset.Charset;
|
|||||||
import java.text.NumberFormat;
|
import java.text.NumberFormat;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import org.apache.commons.lang3.ArrayUtils;
|
|
||||||
|
|
||||||
import com.core.common.utils.StringUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 类型转换器
|
* 类型转换器
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -0,0 +1,32 @@
|
|||||||
|
package com.core.common.enums;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Desc: 调价类型枚举
|
||||||
|
* @Author raymond
|
||||||
|
* @Date 09:14 2025/10/16
|
||||||
|
* @return
|
||||||
|
**/
|
||||||
|
public enum AdjustPriceEnum {
|
||||||
|
|
||||||
|
MEDICINE(0, "药品"),
|
||||||
|
CONSUMABLES(1, "耗材"),
|
||||||
|
DIAGNOSIS(2, "诊疗"),
|
||||||
|
REGISTER(3, "挂号");
|
||||||
|
|
||||||
|
|
||||||
|
private final Integer code;
|
||||||
|
private final String info;
|
||||||
|
|
||||||
|
AdjustPriceEnum(Integer code, String info) {
|
||||||
|
this.code = code;
|
||||||
|
this.info = info;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getCode() {
|
||||||
|
return code;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getInfo() {
|
||||||
|
return info;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,10 +1,13 @@
|
|||||||
package com.openhis.common.enums;
|
package com.core.common.enums;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 删除标识
|
* 删除标识
|
||||||
*
|
*
|
||||||
* @author system
|
* @author system
|
||||||
*/
|
*/
|
||||||
|
@Getter
|
||||||
public enum DelFlag {
|
public enum DelFlag {
|
||||||
/**
|
/**
|
||||||
* 未删除
|
* 未删除
|
||||||
@@ -25,6 +28,23 @@ public enum DelFlag {
|
|||||||
this.info = info;
|
this.info = info;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static DelFlag getByValue(Integer value) {
|
||||||
|
if (value == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
for (DelFlag val : values()) {
|
||||||
|
if (val.value.equals(value)) {
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 手动添加 getter 方法以解决 Lombok 兼容性问题
|
||||||
|
public Integer getValue() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
public String getCode() {
|
public String getCode() {
|
||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
@@ -32,20 +52,4 @@ public enum DelFlag {
|
|||||||
public String getInfo() {
|
public String getInfo() {
|
||||||
return info;
|
return info;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Integer getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static DelFlag getByValue(Integer value) {
|
|
||||||
if (value == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
for (DelFlag val : values()) {
|
|
||||||
if (val.getValue().equals(value)) {
|
|
||||||
return val;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
@@ -1,26 +0,0 @@
|
|||||||
package com.core.common.enums;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 删除标志
|
|
||||||
*
|
|
||||||
* @author system
|
|
||||||
*/
|
|
||||||
public enum DeleteFlag {
|
|
||||||
NOT_DELETED("0", "未删除"), DELETED("1", "已删除");
|
|
||||||
|
|
||||||
private final String code;
|
|
||||||
private final String info;
|
|
||||||
|
|
||||||
DeleteFlag(String code, String info) {
|
|
||||||
this.code = code;
|
|
||||||
this.info = info;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getCode() {
|
|
||||||
return code;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getInfo() {
|
|
||||||
return info;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,9 +1,9 @@
|
|||||||
package com.core.common.enums;
|
package com.core.common.enums;
|
||||||
|
|
||||||
import java.util.function.Function;
|
|
||||||
|
|
||||||
import com.core.common.utils.DesensitizedUtil;
|
import com.core.common.utils.DesensitizedUtil;
|
||||||
|
|
||||||
|
import java.util.function.Function;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 脱敏类型
|
* 脱敏类型
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
package com.core.common.enums;
|
package com.core.common.enums;
|
||||||
|
|
||||||
|
import org.springframework.lang.Nullable;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.springframework.lang.Nullable;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 请求方式
|
* 请求方式
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -6,98 +6,39 @@ package com.core.common.enums;
|
|||||||
* @author system
|
* @author system
|
||||||
*/
|
*/
|
||||||
public enum TenantOptionDict {
|
public enum TenantOptionDict {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 医院名称
|
* 医院名称
|
||||||
*/
|
*/
|
||||||
HOSPITAL_NAME("hospitalName", "医院名称", 0),
|
YB_HOSPITAL_NAME("hospitalName", "医保-医院名称", 0),
|
||||||
/**
|
/**
|
||||||
* 医疗机构等级
|
* 医保-医疗机构等级(3101接口)
|
||||||
*/
|
*/
|
||||||
MEDINS_LV("medinsLv", "医疗机构等级", 1),
|
YB_MEDINS_LV("medinsLv", "医保_医疗机构等级", 1),
|
||||||
/**
|
/**
|
||||||
* 定点医药机构编号
|
* 定点医药机构编号
|
||||||
*/
|
*/
|
||||||
FIXMEDINS_CODE("fixmedinsCode", "定点医药机构编号", 2),
|
YB_FIXMEDINS_CODE("fixmedinsCode", "医保_定点医药机构编号", 2),
|
||||||
/**
|
/**
|
||||||
* 电子发票appid
|
* 电子发票appid
|
||||||
*/
|
*/
|
||||||
APP_ID("app_id", "电子发票appid", 3),
|
EINVOICE_APP_ID("app_id", "电子发票-appid", 3),
|
||||||
/**
|
/**
|
||||||
* 电子发票key
|
* 电子发票key
|
||||||
*/
|
*/
|
||||||
KEY("key", "电子发票key", 4),
|
EINVOICE_KEY("key", "电子发票-key", 4),
|
||||||
/**
|
/**
|
||||||
* 电子发票url
|
* 电子发票url
|
||||||
*/
|
*/
|
||||||
URL("url", "电子发票url", 5),
|
EINVOICE_URL("url", "电子发票-url", 5),
|
||||||
/**
|
/**
|
||||||
* 医保开关
|
* 医保开关
|
||||||
*/
|
*/
|
||||||
YB_SWITCH("yb_switch", "医保开关", 6),
|
YB_SWITCH("yb_switch", "医保开关", 6),
|
||||||
/**
|
|
||||||
* 客户端私钥
|
|
||||||
*/
|
|
||||||
CLI_PRV_KEY("cliPrvKey", "客户端私钥", 7),
|
|
||||||
/**
|
|
||||||
* 客户端公钥
|
|
||||||
*/
|
|
||||||
CLI_PUB_KEY("cliPubKey", "客户端公钥", 8),
|
|
||||||
/**
|
|
||||||
* 服务端公钥
|
|
||||||
*/
|
|
||||||
SERVER_PUB_KEY("serverPubKey", "服务端公钥", 9),
|
|
||||||
/**
|
|
||||||
* 定点医药机构名称
|
|
||||||
*/
|
|
||||||
FIXMEDINS_NAME("fixmedinsName", "定点医药机构名称", 10),
|
|
||||||
/**
|
|
||||||
* 行政区划
|
|
||||||
*/
|
|
||||||
ADMVS("admvs", "行政区划", 11),
|
|
||||||
/**
|
|
||||||
* 授权范围
|
|
||||||
*/
|
|
||||||
SCOPE("scope", "授权范围", 12),
|
|
||||||
/**
|
|
||||||
* 授权类型
|
|
||||||
*/
|
|
||||||
GRANT_TYPE("grantType", "授权类型", 13),
|
|
||||||
/**
|
|
||||||
* 密码
|
|
||||||
*/
|
|
||||||
PASSWORD("password", "密码", 14),
|
|
||||||
/**
|
|
||||||
* 用户名
|
|
||||||
*/
|
|
||||||
USERNAME("username", "用户名", 15),
|
|
||||||
/**
|
|
||||||
* 客户端安全码
|
|
||||||
*/
|
|
||||||
CLIENT_SECRET("clientSecret", "客户端安全码", 16),
|
|
||||||
/**
|
|
||||||
* 客户端ID
|
|
||||||
*/
|
|
||||||
CLIENT_ID("clientId", "客户端ID", 17),
|
|
||||||
/**
|
|
||||||
* 生产环境客户端公钥
|
|
||||||
*/
|
|
||||||
PROD_CLI_PUB_KEY("prod_cliPubKey", "生产环境客户端公钥", 18),
|
|
||||||
/**
|
|
||||||
* 生产环境客户端私钥
|
|
||||||
*/
|
|
||||||
PROD_CLI_PRV_KEY("prod_cliPrvKey", "生产环境客户端私钥", 19),
|
|
||||||
/**
|
|
||||||
* 生产环境客户端ID
|
|
||||||
*/
|
|
||||||
PROD_CLIENT_ID("prod_clientId", "生产环境客户端ID", 20),
|
|
||||||
/**
|
|
||||||
* 文件路径
|
|
||||||
*/
|
|
||||||
FILE_PATH("filePath", "文件路径", 21),
|
|
||||||
/**
|
/**
|
||||||
* 电子地址
|
* 电子地址
|
||||||
*/
|
*/
|
||||||
ELE_ADDRESS("eleAddress", "电子地址", 22),
|
ELE_ADDRESS("eleAddress", "电子处方-请求地址", 22),
|
||||||
/**
|
/**
|
||||||
* 服务地址
|
* 服务地址
|
||||||
*/
|
*/
|
||||||
@@ -109,63 +50,35 @@ public enum TenantOptionDict {
|
|||||||
/**
|
/**
|
||||||
* 是否加密
|
* 是否加密
|
||||||
*/
|
*/
|
||||||
IS_ENCRYPT("isEncrypt", "是否加密", 25),
|
YB_IS_ENCRYPT("isEncrypt", "医保-是否加密", 25),
|
||||||
/**
|
/**
|
||||||
* 医保区划
|
* 医保区划
|
||||||
*/
|
*/
|
||||||
INSUPLC_ADMDVS("insuplc_admdvs", "医保区划", 26),
|
YB_INSUPLC_ADMDVS("insuplc_admdvs", "医保-区划", 26),
|
||||||
/**
|
/**
|
||||||
* 电子处方appId
|
* 电子处方appId
|
||||||
*/
|
*/
|
||||||
PRE_APP_ID("pre_app_id", "电子处方appId", 27),
|
ELE_PRE_APP_ID("pre_app_id", "电子处方-appId", 27),
|
||||||
/**
|
/**
|
||||||
* 电子处方appSecret
|
* 电子处方appSecret
|
||||||
*/
|
*/
|
||||||
PRE_APP_SECRET("pre_app_secret", "电子处方appSecret", 28),
|
ELE_PRE_APP_SECRET("pre_app_secret", "电子处方-appSecret", 28),
|
||||||
/**
|
/**
|
||||||
* 电子处方私钥
|
* 电子处方私钥
|
||||||
*/
|
*/
|
||||||
APP_PRVKEY("APP_PRVKEY", "电子处方私钥", 29),
|
ELE_APP_PRVKEY("APP_PRVKEY", "电子处方-私钥", 29),
|
||||||
/**
|
/**
|
||||||
* 电子处方公钥
|
* 电子处方公钥
|
||||||
*/
|
*/
|
||||||
PLAF_PUBKEY("PLAF_PUBKEY", "电子处方公钥", 30),
|
ELE_PLAF_PUBKEY("PLAF_PUBKEY", "电子处方-公钥", 30),
|
||||||
/**
|
|
||||||
* 医保客户端ID
|
|
||||||
*/
|
|
||||||
YB_CLIENT_ID("ybClientId", "医保客户端ID", 31),
|
|
||||||
/**
|
|
||||||
* 医保客户端安全码
|
|
||||||
*/
|
|
||||||
YB_CLIENT_SECRET("ybClientSecret", "医保客户端安全码", 32),
|
|
||||||
/**
|
|
||||||
* 医保用户名
|
|
||||||
*/
|
|
||||||
YB_USERNAME("ybUsername", "医保用户名", 33),
|
|
||||||
/**
|
|
||||||
* 医保密码
|
|
||||||
*/
|
|
||||||
YB_PASSWORD("ybPassword", "医保密码", 34),
|
|
||||||
/**
|
|
||||||
* 医保授权类型
|
|
||||||
*/
|
|
||||||
YB_GRANT_TYPE("ybGrantType", "医保授权类型", 35),
|
|
||||||
/**
|
|
||||||
* 医保授权范围
|
|
||||||
*/
|
|
||||||
YB_SCOPE("ybScope", "医保授权范围", 36),
|
|
||||||
/**
|
|
||||||
* 医保密钥
|
|
||||||
*/
|
|
||||||
YB_CLI_PRV_KEY("ybCliPrvKey", "医保密钥", 37),
|
|
||||||
/**
|
|
||||||
* 医保服务URL
|
|
||||||
*/
|
|
||||||
YB_URL("ybUrl", "医保服务URL", 38),
|
|
||||||
/**
|
/**
|
||||||
* 医院等级
|
* 医院等级
|
||||||
*/
|
*/
|
||||||
HOSPITAL_LV("hospital_lv", "医院等级", 39),
|
EINVOICE_HOSPITAL_LV("hospital_lv", "电子发票-医院等级", 39),
|
||||||
|
/**
|
||||||
|
* 无视LIS&PACS报错
|
||||||
|
*/
|
||||||
|
LIS_PACS_ERROR_IGNORE("lisPacsErrorIgnore", "无视LIS&PACS报错", 40),
|
||||||
/**
|
/**
|
||||||
* LIS接口地址
|
* LIS接口地址
|
||||||
*/
|
*/
|
||||||
@@ -191,13 +104,13 @@ public enum TenantOptionDict {
|
|||||||
*/
|
*/
|
||||||
PACS_APP_SECRET("pacsAppSecret", "PACSAppSecret", 45),
|
PACS_APP_SECRET("pacsAppSecret", "PACSAppSecret", 45),
|
||||||
/**
|
/**
|
||||||
* PACSAppSecret
|
* 电子发票-中转服务的路径
|
||||||
*/
|
*/
|
||||||
INVOICE_URL("invoiceUrl", "电子发票中转服务的路径", 46),
|
INVOICE_FORWARD_URL("invoiceUrl", "电子发票-中转服务的路径", 46),
|
||||||
/**
|
/**
|
||||||
* PACSAppSecret
|
* 电子发票-中转服务开关
|
||||||
*/
|
*/
|
||||||
FORWARD_SWITCH("forwardSwitch", "电子发票中转服务开关", 47),
|
FORWARD_SWITCH("forwardSwitch", "电子发票-中转服务开关", 47),
|
||||||
/**
|
/**
|
||||||
* 食源性开关
|
* 食源性开关
|
||||||
*/
|
*/
|
||||||
@@ -229,7 +142,164 @@ public enum TenantOptionDict {
|
|||||||
/**
|
/**
|
||||||
* BPC请求URL
|
* BPC请求URL
|
||||||
*/
|
*/
|
||||||
BPC_REQUEST_URL("bpcRequestUrl", "BPC请求URL", 55);
|
BPC_REQUEST_URL("bpcRequestUrl", "BPC请求URL", 55),
|
||||||
|
/**
|
||||||
|
* 电子发票开关
|
||||||
|
*/
|
||||||
|
INVOICE_SWITCH("invoiceSwitch", "电子发票开关", 56),
|
||||||
|
/**
|
||||||
|
* 医嘱定价来源
|
||||||
|
*/
|
||||||
|
ORDER_PRICING_SOURCE("orderPricingSource", "定价来源 batchSellingPrice/retailPrice", 57),
|
||||||
|
/**
|
||||||
|
* 三方支付(签到)
|
||||||
|
*/
|
||||||
|
THREE_PART_SIGN_URL("threePartSignUrl", "三方支付【签到】请求路径", 58),
|
||||||
|
/**
|
||||||
|
* 三方支付(签到)
|
||||||
|
*/
|
||||||
|
THREE_PART_SIGN_STATIC_PARAM("threePartSignStaticParam", "三方支付【签到】固定参数", 59),
|
||||||
|
/**
|
||||||
|
* 三方支付(签到)
|
||||||
|
*/
|
||||||
|
THREE_PART_SIGN_ACTIVE_PARAM("threePartSignActiveParam", "三方支付【签到】可变参数", 60),
|
||||||
|
/**
|
||||||
|
* 三方支付(签到)
|
||||||
|
*/
|
||||||
|
THREE_PART_SIGN_MAPPING_METHOD("threePartSignMappingMethod", "三方支付【签到】请求方式", 61),
|
||||||
|
/**
|
||||||
|
* 三方支付(消费)
|
||||||
|
*/
|
||||||
|
THREE_PART_PAY_URL("threePartPayUrl", "三方支付【消费】请求路径", 62),
|
||||||
|
/**
|
||||||
|
* 三方支付(消费)
|
||||||
|
*/
|
||||||
|
THREE_PART_PAY_STATIC_PARAM("threePartPayStaticParam", "三方支付【消费】固定参数", 63),
|
||||||
|
/**
|
||||||
|
* 三方支付(消费)
|
||||||
|
*/
|
||||||
|
THREE_PART_PAY_ACTIVE_PARAM("threePartPayActiveParam", "三方支付【消费】可变参数", 64),
|
||||||
|
/**
|
||||||
|
* 三方支付(消费)
|
||||||
|
*/
|
||||||
|
THREE_PART_PAY_MAPPING_METHOD("threePartPayMappingMethod", "三方支付【消费】请求方式", 65),
|
||||||
|
/**
|
||||||
|
* 三方支付(退费)
|
||||||
|
*/
|
||||||
|
THREE_PART_RETURN_URL("threePartReturnUrl", "三方支付【退费】请求路径", 66),
|
||||||
|
/**
|
||||||
|
* 三方支付(退费)
|
||||||
|
*/
|
||||||
|
THREE_PART_RETURN_STATIC_PARAM("threePartReturnStaticParam", "三方支付【退费】固定参数", 67),
|
||||||
|
/**
|
||||||
|
* 三方支付(退费)
|
||||||
|
*/
|
||||||
|
THREE_PART_RETURN_ACTIVE_PARAM("threePartReturnActiveParam", "三方支付【退费】可变参数", 68),
|
||||||
|
/**
|
||||||
|
* 三方支付(退费)
|
||||||
|
*/
|
||||||
|
THREE_PART_RETURN_MAPPING_METHOD("threePartReturnMappingMethod", "三方支付【退费】请求方式", 69),
|
||||||
|
/**
|
||||||
|
* 三方支付(隔天退费)
|
||||||
|
*/
|
||||||
|
THREE_PART_NEXT_DAY_RETURN_URL("threePartNextDayReturnUrl", "三方支付【隔天退费】请求路径", 70),
|
||||||
|
/**
|
||||||
|
* 三方支付(隔天退费)
|
||||||
|
*/
|
||||||
|
THREE_PART_NEXT_DAY_RETURN_STATIC_PARAM("threePartNextDayReturnStaticParam", "三方支付【隔天退费】固定参数", 71),
|
||||||
|
/**
|
||||||
|
* 三方支付(隔天退费)
|
||||||
|
*/
|
||||||
|
THREE_PART_NEXT_DAY_RETURN_ACTIVE_PARAM("threePartNextDayReturnActiveParam", "三方支付【隔天退费】可变参数", 72),
|
||||||
|
/**
|
||||||
|
* 三方支付(隔天退费)
|
||||||
|
*/
|
||||||
|
THREE_PART_NEXT_DAY_RETURN_MAPPING_METHOD("threePartNextDayReturnMappingMethod", "三方支付【隔天退费】请求方式", 73),
|
||||||
|
/**
|
||||||
|
* 三方支付路径(支付结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_PAY_QUERY_URL("threePartPayQueryUrl", "三方支付【支付结果查询】请求路径", 74),
|
||||||
|
/**
|
||||||
|
* 三方支付(支付结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_PAY_QUERY_STATIC_PARAM("threePartPayQueryStaticParam", "三方支付【支付结果查询】固定参数", 75),
|
||||||
|
/**
|
||||||
|
* 三方支付(支付结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_PAY_QUERY_ACTIVE_PARAM("threePartPayQueryActiveParam", "三方支付【支付结果查询】可变参数", 76),
|
||||||
|
/**
|
||||||
|
* 三方支付(支付结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_PAY_QUERY_MAPPING_METHOD("threePartPayQueryMappingMethod", "三方支付【支付结果查询】请求方式", 77),
|
||||||
|
/**
|
||||||
|
* 三方支付路径(退费结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_RETURN_QUERY_URL("threePartReturnQueryUrl", "三方支付【退费结果查询】请求路径", 78),
|
||||||
|
/**
|
||||||
|
* 三方支付(退费结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_RETURN_QUERY_STATIC_PARAM("threePartReturnQueryStaticParam", "三方支付【退费结果查询】固定参数", 79),
|
||||||
|
/**
|
||||||
|
* 三方支付(退费结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_RETURN_QUERY_ACTIVE_PARAM("threePartReturnQueryActiveParam", "三方支付【退费结果查询】可变参数", 80),
|
||||||
|
/**
|
||||||
|
* 三方支付(退费结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_RETURN_QUERY_MAPPING_METHOD("threePartReturnQueryMappingMethod", "三方支付【退费结果查询】请求方式", 81),
|
||||||
|
/**
|
||||||
|
* 三方支付路径(隔天退费结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_NEXT_DAY_RETURN_QUERY_URL("threePartNextDayReturnQueryUrl", "三方支付【隔天退费结果查询】请求路径", 82),
|
||||||
|
/**
|
||||||
|
* 三方支付(隔天退费结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_NEXT_DAY_RETURN_QUERY_STATIC_PARAM("threePartNextDayReturnQueryStaticParam", "三方支付【隔天退费结果查询】固定参数", 83),
|
||||||
|
/**
|
||||||
|
* 三方支付(隔天退费结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_NEXT_DAY_RETURN_QUERY_ACTIVE_PARAM("threePartNextDayReturnQueryActiveParam", "三方支付【隔天退费结果查询】可变参数", 84),
|
||||||
|
/**
|
||||||
|
* 三方支付(隔天退费结果查询)
|
||||||
|
*/
|
||||||
|
THREE_PART_NEXT_DAY_RETURN_QUERY_MAPPING_METHOD("threePartNextDayReturnQueryMappingMethod", "三方支付【隔天退费结果查询】请求方式",
|
||||||
|
85),
|
||||||
|
/**
|
||||||
|
* 三方支付(签出)
|
||||||
|
*/
|
||||||
|
THREE_PART_SIGN_OUT_URL("threePartSignOutUrl", "三方支付【签出】请求路径", 86),
|
||||||
|
/**
|
||||||
|
* 三方支付(签出)
|
||||||
|
*/
|
||||||
|
THREE_PART_SIGN_OUT_STATIC_PARAM("threePartSignOutStaticParam", "三方支付【签出】固定参数", 87),
|
||||||
|
/**
|
||||||
|
* 三方支付(签出)
|
||||||
|
*/
|
||||||
|
THREE_PART_SIGN_OUT_ACTIVE_PARAM("threePartSignOutActiveParam", "三方支付【签出】可变参数", 88),
|
||||||
|
/**
|
||||||
|
* 三方支付(签出)
|
||||||
|
*/
|
||||||
|
THREE_PART_SIGN_OUT_MAPPING_METHOD("threePartSignOutMappingMethod", "三方支付【签出】请求方式", 89),
|
||||||
|
/**
|
||||||
|
* 三方支付(签出)
|
||||||
|
*/
|
||||||
|
YB_INPATIENT_SETTLEMENT_UP_URL("ybInpatientSetlUp", "选填4101或4101A", 90),
|
||||||
|
/**
|
||||||
|
* PACS查看报告地址
|
||||||
|
*/
|
||||||
|
PACS_REPORT_URL("pacsReportUrl", "PACS查看报告地址", 91),
|
||||||
|
/**
|
||||||
|
* LIS查看报告地址
|
||||||
|
*/
|
||||||
|
LIS_REPORT_URL("lisReportUrl", "LIS查看报告地址", 92),
|
||||||
|
/**
|
||||||
|
* 开药时药房允许多选开关
|
||||||
|
*/
|
||||||
|
PHARMACY_MULTIPLE_CHOICE_SWITCH("pharmacyMultipleChoiceSwitch", "开药时药房允许多选开关", 93),
|
||||||
|
/**
|
||||||
|
* PEIS服务地址
|
||||||
|
*/
|
||||||
|
PEIS_SERVER_URL("peisServerUrl", "PEIS服务地址", 94);
|
||||||
|
|
||||||
private final String code;
|
private final String code;
|
||||||
private final String name;
|
private final String name;
|
||||||
@@ -241,18 +311,6 @@ public enum TenantOptionDict {
|
|||||||
this.sort = sort;
|
this.sort = sort;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getCode() {
|
|
||||||
return code;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getName() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Integer getSort() {
|
|
||||||
return sort;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static TenantOptionDict getByCode(String code) {
|
public static TenantOptionDict getByCode(String code) {
|
||||||
if (code == null) {
|
if (code == null) {
|
||||||
return null;
|
return null;
|
||||||
@@ -264,4 +322,16 @@ public enum TenantOptionDict {
|
|||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getCode() {
|
||||||
|
return code;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getSort() {
|
||||||
|
return sort;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,13 +1,11 @@
|
|||||||
package com.core.common.filter;
|
package com.core.common.filter;
|
||||||
|
|
||||||
import java.io.IOException;
|
import com.core.common.utils.StringUtils;
|
||||||
|
import org.springframework.http.MediaType;
|
||||||
|
|
||||||
import javax.servlet.*;
|
import javax.servlet.*;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import java.io.IOException;
|
||||||
import org.springframework.http.MediaType;
|
|
||||||
|
|
||||||
import com.core.common.utils.StringUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Repeatable 过滤器
|
* Repeatable 过滤器
|
||||||
|
|||||||
@@ -1,18 +1,17 @@
|
|||||||
package com.core.common.filter;
|
package com.core.common.filter;
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
import com.core.common.constant.Constants;
|
||||||
import java.io.ByteArrayInputStream;
|
import com.core.common.utils.http.HttpHelper;
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStreamReader;
|
|
||||||
|
|
||||||
import javax.servlet.ReadListener;
|
import javax.servlet.ReadListener;
|
||||||
import javax.servlet.ServletInputStream;
|
import javax.servlet.ServletInputStream;
|
||||||
import javax.servlet.ServletResponse;
|
import javax.servlet.ServletResponse;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletRequestWrapper;
|
import javax.servlet.http.HttpServletRequestWrapper;
|
||||||
|
import java.io.BufferedReader;
|
||||||
import com.core.common.constant.Constants;
|
import java.io.ByteArrayInputStream;
|
||||||
import com.core.common.utils.http.HttpHelper;
|
import java.io.IOException;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 构建可重复读取inputStream的request
|
* 构建可重复读取inputStream的request
|
||||||
|
|||||||
@@ -1,15 +1,14 @@
|
|||||||
package com.core.common.filter;
|
package com.core.common.filter;
|
||||||
|
|
||||||
import java.io.IOException;
|
import com.core.common.enums.HttpMethod;
|
||||||
import java.util.ArrayList;
|
import com.core.common.utils.StringUtils;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.servlet.*;
|
import javax.servlet.*;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.io.IOException;
|
||||||
import com.core.common.enums.HttpMethod;
|
import java.util.ArrayList;
|
||||||
import com.core.common.utils.StringUtils;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 防止XSS攻击的过滤器
|
* 防止XSS攻击的过滤器
|
||||||
|
|||||||
@@ -1,19 +1,17 @@
|
|||||||
package com.core.common.filter;
|
package com.core.common.filter;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import com.core.common.utils.StringUtils;
|
||||||
import java.io.IOException;
|
import com.core.common.utils.html.EscapeUtil;
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.springframework.http.HttpHeaders;
|
||||||
|
import org.springframework.http.MediaType;
|
||||||
|
|
||||||
import javax.servlet.ReadListener;
|
import javax.servlet.ReadListener;
|
||||||
import javax.servlet.ServletInputStream;
|
import javax.servlet.ServletInputStream;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletRequestWrapper;
|
import javax.servlet.http.HttpServletRequestWrapper;
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
import org.apache.commons.io.IOUtils;
|
import java.io.IOException;
|
||||||
import org.springframework.http.HttpHeaders;
|
|
||||||
import org.springframework.http.MediaType;
|
|
||||||
|
|
||||||
import com.core.common.utils.StringUtils;
|
|
||||||
import com.core.common.utils.html.EscapeUtil;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* XSS过滤处理
|
* XSS过滤处理
|
||||||
|
|||||||
@@ -37,6 +37,10 @@ public final class AgeCalculatorUtil {
|
|||||||
* 当前年龄取得(床位列表表示年龄用)
|
* 当前年龄取得(床位列表表示年龄用)
|
||||||
*/
|
*/
|
||||||
public static String getAge(Date date) {
|
public static String getAge(Date date) {
|
||||||
|
// 添加空值检查
|
||||||
|
if (date == null) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
// 将 Date 转换为 LocalDateTime
|
// 将 Date 转换为 LocalDateTime
|
||||||
LocalDateTime dateTime = date.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime();
|
LocalDateTime dateTime = date.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime();
|
||||||
LocalDateTime now = LocalDateTime.now();
|
LocalDateTime now = LocalDateTime.now();
|
||||||
|
|||||||
@@ -3,16 +3,15 @@
|
|||||||
*/
|
*/
|
||||||
package com.core.common.utils;
|
package com.core.common.utils;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import com.core.common.constant.CacheConstants;
|
||||||
import java.util.List;
|
import com.core.common.core.redis.RedisCache;
|
||||||
|
import com.core.common.exception.UtilException;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
import com.core.common.constant.CacheConstants;
|
import java.util.ArrayList;
|
||||||
import com.core.common.core.redis.RedisCache;
|
import java.util.List;
|
||||||
import com.core.common.exception.UtilException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 排番组件
|
* 排番组件
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
package com.core.common.utils;
|
package com.core.common.utils;
|
||||||
|
|
||||||
|
import org.apache.commons.lang3.time.DateFormatUtils;
|
||||||
|
|
||||||
import java.lang.management.ManagementFactory;
|
import java.lang.management.ManagementFactory;
|
||||||
import java.text.ParseException;
|
import java.text.ParseException;
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
@@ -9,8 +11,6 @@ import java.time.format.DateTimeParseException;
|
|||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
import org.apache.commons.lang3.time.DateFormatUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 时间工具类
|
* 时间工具类
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,14 +1,14 @@
|
|||||||
package com.core.common.utils;
|
package com.core.common.utils;
|
||||||
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.alibaba.fastjson2.JSONArray;
|
import com.alibaba.fastjson2.JSONArray;
|
||||||
import com.core.common.constant.CacheConstants;
|
import com.core.common.constant.CacheConstants;
|
||||||
import com.core.common.core.domain.entity.SysDictData;
|
import com.core.common.core.domain.entity.SysDictData;
|
||||||
import com.core.common.core.redis.RedisCache;
|
import com.core.common.core.redis.RedisCache;
|
||||||
import com.core.common.utils.spring.SpringUtils;
|
import com.core.common.utils.spring.SpringUtils;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字典工具类
|
* 字典工具类
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
package com.core.common.utils;
|
package com.core.common.utils;
|
||||||
|
|
||||||
|
import org.apache.commons.lang3.exception.ExceptionUtils;
|
||||||
|
|
||||||
import java.io.PrintWriter;
|
import java.io.PrintWriter;
|
||||||
import java.io.StringWriter;
|
import java.io.StringWriter;
|
||||||
|
|
||||||
import org.apache.commons.lang3.exception.ExceptionUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 错误信息处理类。
|
* 错误信息处理类。
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,9 +1,8 @@
|
|||||||
package com.core.common.utils;
|
package com.core.common.utils;
|
||||||
|
|
||||||
|
import com.core.common.utils.spring.SpringUtils;
|
||||||
import org.springframework.context.MessageSource;
|
import org.springframework.context.MessageSource;
|
||||||
import org.springframework.context.i18n.LocaleContextHolder;
|
import org.springframework.context.i18n.LocaleContextHolder;
|
||||||
|
|
||||||
import com.core.common.utils.spring.SpringUtils;
|
|
||||||
import org.springframework.lang.Nullable;
|
import org.springframework.lang.Nullable;
|
||||||
|
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -1,19 +1,18 @@
|
|||||||
package com.core.common.utils;
|
package com.core.common.utils;
|
||||||
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
import org.springframework.security.core.Authentication;
|
|
||||||
import org.springframework.security.core.context.SecurityContextHolder;
|
|
||||||
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
|
|
||||||
import org.springframework.util.PatternMatchUtils;
|
|
||||||
|
|
||||||
import com.core.common.constant.Constants;
|
import com.core.common.constant.Constants;
|
||||||
import com.core.common.constant.HttpStatus;
|
import com.core.common.constant.HttpStatus;
|
||||||
import com.core.common.core.domain.entity.SysRole;
|
import com.core.common.core.domain.entity.SysRole;
|
||||||
import com.core.common.core.domain.model.LoginUser;
|
import com.core.common.core.domain.model.LoginUser;
|
||||||
import com.core.common.exception.ServiceException;
|
import com.core.common.exception.ServiceException;
|
||||||
|
import org.springframework.security.core.Authentication;
|
||||||
|
import org.springframework.security.core.context.SecurityContextHolder;
|
||||||
|
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
|
||||||
|
import org.springframework.util.PatternMatchUtils;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 安全服务工具类
|
* 安全服务工具类
|
||||||
@@ -55,6 +54,17 @@ public class SecurityUtils {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取用户昵称
|
||||||
|
**/
|
||||||
|
public static String getNickName() {
|
||||||
|
try {
|
||||||
|
return getLoginUser().getUser().getNickName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new ServiceException("获取用户昵称异常", HttpStatus.UNAUTHORIZED);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取用户
|
* 获取用户
|
||||||
**/
|
**/
|
||||||
@@ -66,6 +76,25 @@ public class SecurityUtils {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 安全获取用户名(失败时返回默认值)
|
||||||
|
**/
|
||||||
|
public static String getUsernameSafe() {
|
||||||
|
try {
|
||||||
|
Authentication authentication = getAuthentication();
|
||||||
|
if (authentication != null && authentication.getPrincipal() != null) {
|
||||||
|
if (authentication.getPrincipal() instanceof LoginUser) {
|
||||||
|
return ((LoginUser) authentication.getPrincipal()).getUsername();
|
||||||
|
} else {
|
||||||
|
return authentication.getPrincipal().toString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
// 静默处理异常,返回默认值
|
||||||
|
}
|
||||||
|
return "anonymous";
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取Authentication
|
* 获取Authentication
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -1,5 +1,15 @@
|
|||||||
package com.core.common.utils;
|
package com.core.common.utils;
|
||||||
|
|
||||||
|
import com.core.common.constant.Constants;
|
||||||
|
import com.core.common.core.text.Convert;
|
||||||
|
import org.springframework.web.context.request.RequestAttributes;
|
||||||
|
import org.springframework.web.context.request.RequestContextHolder;
|
||||||
|
import org.springframework.web.context.request.ServletRequestAttributes;
|
||||||
|
|
||||||
|
import javax.servlet.ServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import javax.servlet.http.HttpSession;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.UnsupportedEncodingException;
|
import java.io.UnsupportedEncodingException;
|
||||||
import java.net.URLDecoder;
|
import java.net.URLDecoder;
|
||||||
@@ -8,18 +18,6 @@ import java.util.Collections;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import javax.servlet.ServletRequest;
|
|
||||||
import javax.servlet.http.HttpServletRequest;
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
import javax.servlet.http.HttpSession;
|
|
||||||
|
|
||||||
import org.springframework.web.context.request.RequestAttributes;
|
|
||||||
import org.springframework.web.context.request.RequestContextHolder;
|
|
||||||
import org.springframework.web.context.request.ServletRequestAttributes;
|
|
||||||
|
|
||||||
import com.core.common.constant.Constants;
|
|
||||||
import com.core.common.core.text.Convert;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 客户端工具类
|
* 客户端工具类
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,11 +1,10 @@
|
|||||||
package com.core.common.utils;
|
package com.core.common.utils;
|
||||||
|
|
||||||
import java.util.*;
|
|
||||||
|
|
||||||
import org.springframework.util.AntPathMatcher;
|
|
||||||
|
|
||||||
import com.core.common.constant.Constants;
|
import com.core.common.constant.Constants;
|
||||||
import com.core.common.core.text.StrFormatter;
|
import com.core.common.core.text.StrFormatter;
|
||||||
|
import org.springframework.util.AntPathMatcher;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字符串工具类
|
* 字符串工具类
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
package com.core.common.utils;
|
package com.core.common.utils;
|
||||||
|
|
||||||
import java.util.concurrent.*;
|
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.util.concurrent.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 线程相关工具类.
|
* 线程相关工具类.
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,14 +1,10 @@
|
|||||||
package com.core.common.utils;
|
package com.core.common.utils;
|
||||||
|
|
||||||
import org.apache.commons.lang3.time.DateFormatUtils;
|
import java.time.LocalDate;
|
||||||
|
import java.time.LocalDateTime;
|
||||||
import java.lang.management.ManagementFactory;
|
import java.time.LocalTime;
|
||||||
import java.text.ParseException;
|
import java.time.ZoneId;
|
||||||
import java.text.SimpleDateFormat;
|
|
||||||
import java.time.*;
|
|
||||||
import java.time.format.DateTimeFormatter;
|
import java.time.format.DateTimeFormatter;
|
||||||
import java.time.format.DateTimeParseException;
|
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,10 +1,9 @@
|
|||||||
package com.core.common.utils.bean;
|
package com.core.common.utils.bean;
|
||||||
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import javax.validation.ConstraintViolation;
|
import javax.validation.ConstraintViolation;
|
||||||
import javax.validation.ConstraintViolationException;
|
import javax.validation.ConstraintViolationException;
|
||||||
import javax.validation.Validator;
|
import javax.validation.Validator;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* bean对象属性验证
|
* bean对象属性验证
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
package com.core.common.utils.file;
|
package com.core.common.utils.file;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 文件类型工具类
|
* 文件类型工具类
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,13 +1,5 @@
|
|||||||
package com.core.common.utils.file;
|
package com.core.common.utils.file;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.nio.file.Paths;
|
|
||||||
import java.util.Objects;
|
|
||||||
|
|
||||||
import org.apache.commons.io.FilenameUtils;
|
|
||||||
import org.springframework.web.multipart.MultipartFile;
|
|
||||||
|
|
||||||
import com.core.common.config.CoreConfig;
|
import com.core.common.config.CoreConfig;
|
||||||
import com.core.common.constant.Constants;
|
import com.core.common.constant.Constants;
|
||||||
import com.core.common.exception.file.FileNameLengthLimitExceededException;
|
import com.core.common.exception.file.FileNameLengthLimitExceededException;
|
||||||
@@ -16,6 +8,13 @@ import com.core.common.exception.file.InvalidExtensionException;
|
|||||||
import com.core.common.utils.DateUtils;
|
import com.core.common.utils.DateUtils;
|
||||||
import com.core.common.utils.StringUtils;
|
import com.core.common.utils.StringUtils;
|
||||||
import com.core.common.utils.uuid.Seq;
|
import com.core.common.utils.uuid.Seq;
|
||||||
|
import org.apache.commons.io.FilenameUtils;
|
||||||
|
import org.springframework.web.multipart.MultipartFile;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.nio.file.Paths;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 文件上传工具类
|
* 文件上传工具类
|
||||||
|
|||||||
@@ -1,20 +1,18 @@
|
|||||||
package com.core.common.utils.file;
|
package com.core.common.utils.file;
|
||||||
|
|
||||||
import java.io.*;
|
|
||||||
import java.net.URLEncoder;
|
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletRequest;
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.apache.commons.io.FilenameUtils;
|
|
||||||
import org.apache.commons.io.IOUtils;
|
|
||||||
import org.apache.commons.lang3.ArrayUtils;
|
|
||||||
|
|
||||||
import com.core.common.config.CoreConfig;
|
import com.core.common.config.CoreConfig;
|
||||||
import com.core.common.utils.DateUtils;
|
import com.core.common.utils.DateUtils;
|
||||||
import com.core.common.utils.StringUtils;
|
import com.core.common.utils.StringUtils;
|
||||||
import com.core.common.utils.uuid.IdUtils;
|
import com.core.common.utils.uuid.IdUtils;
|
||||||
|
import org.apache.commons.io.FilenameUtils;
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.apache.commons.lang3.ArrayUtils;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.io.*;
|
||||||
|
import java.net.URLEncoder;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 文件处理工具类
|
* 文件处理工具类
|
||||||
|
|||||||
@@ -1,5 +1,12 @@
|
|||||||
package com.core.common.utils.file;
|
package com.core.common.utils.file;
|
||||||
|
|
||||||
|
import com.core.common.config.CoreConfig;
|
||||||
|
import com.core.common.constant.Constants;
|
||||||
|
import com.core.common.utils.StringUtils;
|
||||||
|
import org.apache.poi.util.IOUtils;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
@@ -7,14 +14,6 @@ import java.net.URL;
|
|||||||
import java.net.URLConnection;
|
import java.net.URLConnection;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
|
||||||
import org.apache.poi.util.IOUtils;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
import com.core.common.config.CoreConfig;
|
|
||||||
import com.core.common.constant.Constants;
|
|
||||||
import com.core.common.utils.StringUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 图片处理工具类
|
* 图片处理工具类
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,17 +1,16 @@
|
|||||||
package com.core.common.utils.http;
|
package com.core.common.utils.http;
|
||||||
|
|
||||||
|
import org.apache.commons.lang3.exception.ExceptionUtils;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import javax.servlet.ServletRequest;
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
|
|
||||||
import javax.servlet.ServletRequest;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.exception.ExceptionUtils;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 通用http工具封装
|
* 通用http工具封装
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,5 +1,11 @@
|
|||||||
package com.core.common.utils.http;
|
package com.core.common.utils.http;
|
||||||
|
|
||||||
|
import com.core.common.constant.Constants;
|
||||||
|
import com.core.common.utils.StringUtils;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import javax.net.ssl.*;
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.net.ConnectException;
|
import java.net.ConnectException;
|
||||||
import java.net.SocketTimeoutException;
|
import java.net.SocketTimeoutException;
|
||||||
@@ -8,14 +14,6 @@ import java.net.URLConnection;
|
|||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.security.cert.X509Certificate;
|
import java.security.cert.X509Certificate;
|
||||||
|
|
||||||
import javax.net.ssl.*;
|
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
import com.core.common.constant.Constants;
|
|
||||||
import com.core.common.utils.StringUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 通用http发送方法
|
* 通用http发送方法
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,14 +1,13 @@
|
|||||||
package com.core.common.utils.ip;
|
package com.core.common.utils.ip;
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
import com.alibaba.fastjson2.JSON;
|
import com.alibaba.fastjson2.JSON;
|
||||||
import com.alibaba.fastjson2.JSONObject;
|
import com.alibaba.fastjson2.JSONObject;
|
||||||
import com.core.common.config.CoreConfig;
|
import com.core.common.config.CoreConfig;
|
||||||
import com.core.common.constant.Constants;
|
import com.core.common.constant.Constants;
|
||||||
import com.core.common.utils.StringUtils;
|
import com.core.common.utils.StringUtils;
|
||||||
import com.core.common.utils.http.HttpUtils;
|
import com.core.common.utils.http.HttpUtils;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取地址类
|
* 获取地址类
|
||||||
|
|||||||
@@ -1,13 +1,12 @@
|
|||||||
package com.core.common.utils.ip;
|
package com.core.common.utils.ip;
|
||||||
|
|
||||||
import java.net.InetAddress;
|
|
||||||
import java.net.UnknownHostException;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletRequest;
|
|
||||||
|
|
||||||
import com.core.common.utils.ServletUtils;
|
import com.core.common.utils.ServletUtils;
|
||||||
import com.core.common.utils.StringUtils;
|
import com.core.common.utils.StringUtils;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import java.net.InetAddress;
|
||||||
|
import java.net.UnknownHostException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取IP方法
|
* 获取IP方法
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -1,33 +1,5 @@
|
|||||||
package com.core.common.utils.poi;
|
package com.core.common.utils.poi;
|
||||||
|
|
||||||
import java.io.*;
|
|
||||||
import java.lang.reflect.Field;
|
|
||||||
import java.lang.reflect.Method;
|
|
||||||
import java.lang.reflect.ParameterizedType;
|
|
||||||
import java.math.BigDecimal;
|
|
||||||
import java.text.DecimalFormat;
|
|
||||||
import java.time.LocalDate;
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
import java.util.*;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.ArrayUtils;
|
|
||||||
import org.apache.commons.lang3.RegExUtils;
|
|
||||||
import org.apache.commons.lang3.reflect.FieldUtils;
|
|
||||||
import org.apache.poi.hssf.usermodel.*;
|
|
||||||
import org.apache.poi.ooxml.POIXMLDocumentPart;
|
|
||||||
import org.apache.poi.ss.usermodel.*;
|
|
||||||
import org.apache.poi.ss.util.CellRangeAddress;
|
|
||||||
import org.apache.poi.ss.util.CellRangeAddressList;
|
|
||||||
import org.apache.poi.util.IOUtils;
|
|
||||||
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
|
|
||||||
import org.apache.poi.xssf.usermodel.*;
|
|
||||||
import org.openxmlformats.schemas.drawingml.x2006.spreadsheetDrawing.CTMarker;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
import com.core.common.annotation.Excel;
|
import com.core.common.annotation.Excel;
|
||||||
import com.core.common.annotation.Excel.ColumnType;
|
import com.core.common.annotation.Excel.ColumnType;
|
||||||
import com.core.common.annotation.Excel.Type;
|
import com.core.common.annotation.Excel.Type;
|
||||||
@@ -43,6 +15,32 @@ import com.core.common.utils.file.FileTypeUtils;
|
|||||||
import com.core.common.utils.file.FileUtils;
|
import com.core.common.utils.file.FileUtils;
|
||||||
import com.core.common.utils.file.ImageUtils;
|
import com.core.common.utils.file.ImageUtils;
|
||||||
import com.core.common.utils.reflect.ReflectUtils;
|
import com.core.common.utils.reflect.ReflectUtils;
|
||||||
|
import org.apache.commons.lang3.ArrayUtils;
|
||||||
|
import org.apache.commons.lang3.RegExUtils;
|
||||||
|
import org.apache.commons.lang3.reflect.FieldUtils;
|
||||||
|
import org.apache.poi.hssf.usermodel.*;
|
||||||
|
import org.apache.poi.ooxml.POIXMLDocumentPart;
|
||||||
|
import org.apache.poi.ss.usermodel.*;
|
||||||
|
import org.apache.poi.ss.util.CellRangeAddress;
|
||||||
|
import org.apache.poi.ss.util.CellRangeAddressList;
|
||||||
|
import org.apache.poi.util.IOUtils;
|
||||||
|
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
|
||||||
|
import org.apache.poi.xssf.usermodel.*;
|
||||||
|
import org.openxmlformats.schemas.drawingml.x2006.spreadsheetDrawing.CTMarker;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.io.*;
|
||||||
|
import java.lang.reflect.Field;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.lang.reflect.ParameterizedType;
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
import java.text.DecimalFormat;
|
||||||
|
import java.time.LocalDate;
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.util.*;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Excel相关处理
|
* Excel相关处理
|
||||||
|
|||||||
@@ -1,16 +1,15 @@
|
|||||||
package com.core.common.utils.reflect;
|
package com.core.common.utils.reflect;
|
||||||
|
|
||||||
import java.lang.reflect.*;
|
import com.core.common.core.text.Convert;
|
||||||
import java.util.Date;
|
import com.core.common.utils.DateUtils;
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.apache.commons.lang3.Validate;
|
import org.apache.commons.lang3.Validate;
|
||||||
import org.apache.poi.ss.usermodel.DateUtil;
|
import org.apache.poi.ss.usermodel.DateUtil;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import com.core.common.core.text.Convert;
|
import java.lang.reflect.*;
|
||||||
import com.core.common.utils.DateUtils;
|
import java.util.Date;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 反射工具类. 提供调用getter/setter方法, 访问私有变量, 调用私有方法, 获取泛型类型Class, 被AOP过的真实类等工具函数.
|
* 反射工具类. 提供调用getter/setter方法, 访问私有变量, 调用私有方法, 获取泛型类型Class, 被AOP过的真实类等工具函数.
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
package com.core.common.utils.sign;
|
package com.core.common.utils.sign;
|
||||||
|
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
import java.security.MessageDigest;
|
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.security.MessageDigest;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Md5加密方法
|
* Md5加密方法
|
||||||
*
|
*
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user