提交 | 用户 | 时间
|
e7c126
|
1 |
spring: |
d9f9ba
|
2 |
application: |
H |
3 |
name: system-server |
|
4 |
|
|
5 |
profiles: |
|
6 |
active: local |
|
7 |
|
e7c126
|
8 |
main: |
H |
9 |
allow-circular-references: true # 允许循环依赖,因为项目是三层架构,无法避免这个情况。 |
|
10 |
allow-bean-definition-overriding: true # 允许 Bean 覆盖,例如说 Feign 等会存在重复定义的服务 |
d9f9ba
|
11 |
|
H |
12 |
config: |
|
13 |
import: |
|
14 |
- optional:classpath:application-${spring.profiles.active}.yaml # 加载【本地】配置 |
|
15 |
- optional:nacos:${spring.application.name}-${spring.profiles.active}.yaml # 加载【Nacos】的配置 |
e7c126
|
16 |
|
H |
17 |
# Servlet 配置 |
|
18 |
servlet: |
|
19 |
# 文件上传相关配置项 |
|
20 |
multipart: |
|
21 |
max-file-size: 16MB # 单个文件大小 |
|
22 |
max-request-size: 32MB # 设置总上传的文件大小 |
|
23 |
mvc: |
|
24 |
pathmatch: |
|
25 |
matching-strategy: ANT_PATH_MATCHER # 解决 SpringFox 与 SpringBoot 2.6.x 不兼容的问题,参见 SpringFoxHandlerProviderBeanPostProcessor 类 |
|
26 |
|
|
27 |
# Jackson 配置项 |
|
28 |
jackson: |
|
29 |
serialization: |
|
30 |
write-dates-as-timestamps: true # 设置 LocalDateTime 的格式,使用时间戳 |
|
31 |
write-date-timestamps-as-nanoseconds: false # 设置不使用 nanoseconds 的格式。例如说 1611460870.401,而是直接 1611460870401 |
|
32 |
write-durations-as-timestamps: true # 设置 Duration 的格式,使用时间戳 |
|
33 |
fail-on-empty-beans: false # 允许序列化无属性的 Bean |
|
34 |
|
|
35 |
# Cache 配置项 |
|
36 |
cache: |
|
37 |
type: REDIS |
|
38 |
redis: |
|
39 |
time-to-live: 1h # 设置过期时间为 1 小时 |
d9f9ba
|
40 |
|
H |
41 |
server: |
|
42 |
port: 48081 |
|
43 |
|
|
44 |
logging: |
|
45 |
file: |
|
46 |
name: ${user.home}/logs/${spring.application.name}.log # 日志文件名,全路径 |
e7c126
|
47 |
|
H |
48 |
--- #################### 接口文档配置 #################### |
|
49 |
|
|
50 |
springdoc: |
|
51 |
api-docs: |
|
52 |
enabled: true # 1. 是否开启 Swagger 接文档的元数据 |
|
53 |
path: /v3/api-docs |
|
54 |
swagger-ui: |
|
55 |
enabled: true # 2.1 是否开启 Swagger 文档的官方 UI 界面 |
|
56 |
path: /swagger-ui.html |
|
57 |
default-flat-param-object: true # 参见 https://doc.xiaominfo.com/docs/faq/v4/knife4j-parameterobject-flat-param 文档 |
|
58 |
|
|
59 |
knife4j: |
|
60 |
enable: true # 2.2 是否开启 Swagger 文档的 Knife4j UI 界面 |
|
61 |
setting: |
|
62 |
language: zh_cn |
|
63 |
|
|
64 |
# MyBatis Plus 的配置项 |
|
65 |
mybatis-plus: |
|
66 |
configuration: |
|
67 |
map-underscore-to-camel-case: true # 虽然默认为 true ,但是还是显示去指定下。 |
|
68 |
global-config: |
|
69 |
db-config: |
|
70 |
id-type: AUTO # “智能”模式,基于 IdTypeEnvironmentPostProcessor + 数据源的类型,自动适配成 AUTO、INPUT 模式。 |
|
71 |
# id-type: AUTO # 自增 ID,适合 MySQL 等直接自增的数据库 |
|
72 |
# id-type: INPUT # 用户输入 ID,适合 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库 |
|
73 |
# id-type: ASSIGN_ID # 分配 ID,默认使用雪花算法。注意,Oracle、PostgreSQL、Kingbase、DB2、H2 数据库时,需要去除实体类上的 @KeySequence 注解 |
|
74 |
logic-delete-value: 1 # 逻辑已删除值(默认为 1) |
|
75 |
logic-not-delete-value: 0 # 逻辑未删除值(默认为 0) |
|
76 |
banner: false # 关闭控制台的 Banner 打印 |
|
77 |
type-aliases-package: ${iailab.info.base-package}.dal.dataobject |
|
78 |
encryptor: |
|
79 |
password: XDV71a+xqStEA3WH # 加解密的秘钥,可使用 https://www.imaegoo.com/2020/aes-key-generator/ 网站生成 |
|
80 |
|
|
81 |
mybatis-plus-join: |
|
82 |
banner: false # 关闭控制台的 Banner 打印 |
|
83 |
|
|
84 |
# Spring Data Redis 配置 |
|
85 |
spring: |
|
86 |
data: |
|
87 |
redis: |
|
88 |
repositories: |
|
89 |
enabled: false # 项目未使用到 Spring Data Redis 的 Repository,所以直接禁用,保证启动速度 |
|
90 |
|
|
91 |
# VO 转换(数据翻译)相关 |
|
92 |
easy-trans: |
|
93 |
is-enable-global: true # 启用全局翻译(拦截所有 SpringMVC ResponseBody 进行自动翻译 )。如果对于性能要求很高可关闭此配置,或通过 @IgnoreTrans 忽略某个接口 |
|
94 |
is-enable-cloud: false # 禁用 TransType.RPC 微服务模式 |
|
95 |
|
|
96 |
--- #################### RPC 远程调用相关配置 #################### |
|
97 |
|
|
98 |
--- #################### 消息队列相关 #################### |
|
99 |
|
|
100 |
# rocketmq 配置项,对应 RocketMQProperties 配置类 |
|
101 |
rocketmq: |
|
102 |
# Producer 配置项 |
|
103 |
producer: |
|
104 |
group: ${spring.application.name}_PRODUCER # 生产者分组 |
|
105 |
|
|
106 |
spring: |
|
107 |
# Kafka 配置项,对应 KafkaProperties 配置类 |
|
108 |
kafka: |
|
109 |
# Kafka Producer 配置项 |
|
110 |
producer: |
|
111 |
acks: 1 # 0-不应答。1-leader 应答。all-所有 leader 和 follower 应答。 |
|
112 |
retries: 3 # 发送失败时,重试发送的次数 |
|
113 |
value-serializer: org.springframework.kafka.support.serializer.JsonSerializer # 消息的 value 的序列化 |
|
114 |
# Kafka Consumer 配置项 |
|
115 |
consumer: |
|
116 |
auto-offset-reset: earliest # 设置消费者分组最初的消费进度为 earliest 。可参考博客 https://blog.csdn.net/lishuangzhe7047/article/details/74530417 理解 |
|
117 |
value-deserializer: org.springframework.kafka.support.serializer.JsonDeserializer |
|
118 |
properties: |
|
119 |
spring.json.trusted.packages: '*' |
|
120 |
# Kafka Consumer Listener 监听器配置 |
|
121 |
listener: |
|
122 |
missing-topics-fatal: false # 消费监听接口监听的主题不存在时,默认会报错。所以通过设置为 false ,解决报错 |
|
123 |
|
|
124 |
--- #################### 定时任务相关配置 #################### |
|
125 |
|
|
126 |
xxl: |
|
127 |
job: |
|
128 |
executor: |
|
129 |
appname: ${spring.application.name} # 执行器 AppName |
|
130 |
logpath: ${user.home}/logs/xxl-job/${spring.application.name} # 执行器运行日志文件存储磁盘路径 |
|
131 |
accessToken: default_token # 执行器通讯TOKEN |
|
132 |
|
|
133 |
--- #################### 验证码相关配置 #################### |
|
134 |
|
|
135 |
aj: |
|
136 |
captcha: |
|
137 |
jigsaw: classpath:images/jigsaw # 滑动验证,底图路径,不配置将使用默认图片;以 classpath: 开头,取 resource 目录下路径 |
|
138 |
pic-click: classpath:images/pic-click # 滑动验证,底图路径,不配置将使用默认图片;以 classpath: 开头,取 resource 目录下路径 |
|
139 |
cache-type: redis # 缓存 local/redis... |
|
140 |
cache-number: 1000 # local 缓存的阈值,达到这个值,清除缓存 |
|
141 |
timing-clear: 180 # local定时清除过期缓存(单位秒),设置为0代表不执行 |
|
142 |
type: blockPuzzle # 验证码类型 default两种都实例化。 blockPuzzle 滑块拼图 clickWord 文字点选 |
|
143 |
water-mark: iailab # 右下角水印文字(我的水印),可使用 https://tool.chinaz.com/tools/unicode.aspx 中文转 Unicode,Linux 可能需要转 unicode |
|
144 |
interference-options: 0 # 滑动干扰项(0/1/2) |
|
145 |
req-frequency-limit-enable: false # 接口请求次数一分钟限制是否开启 true|false |
|
146 |
req-get-lock-limit: 5 # 验证失败5次,get接口锁定 |
|
147 |
req-get-lock-seconds: 10 # 验证失败后,锁定时间间隔 |
|
148 |
req-get-minute-limit: 30 # get 接口一分钟内请求数限制 |
|
149 |
req-check-minute-limit: 60 # check 接口一分钟内请求数限制 |
|
150 |
req-verify-minute-limit: 60 # verify 接口一分钟内请求数限制 |
|
151 |
|
|
152 |
--- #################### 平台相关配置 #################### |
|
153 |
|
|
154 |
iailab: |
|
155 |
info: |
|
156 |
version: 1.0.0 |
|
157 |
base-package: com.iailab.module.system |
|
158 |
web: |
|
159 |
admin-ui: |
|
160 |
url: http://dashboard.iailab.iocoder.cn # Admin 管理后台 UI 的地址 |
325d2f
|
161 |
xss: |
H |
162 |
enable: false |
|
163 |
exclude-urls: # 如下 url,仅仅是为了演示,去掉配置也没关系 |
|
164 |
- ${management.endpoints.web.base-path}/** # 不处理 Actuator 的请求 |
e7c126
|
165 |
swagger: |
H |
166 |
title: 管理后台 |
|
167 |
description: 提供管理员管理的所有功能 |
|
168 |
version: ${iailab.info.version} |
|
169 |
tenant: # 多租户相关配置项 |
|
170 |
enable: true |
|
171 |
ignore-urls: |
|
172 |
- /admin-api/system/tenant/get-id-by-name # 基于名字获取租户,不许带租户编号 |
|
173 |
- /admin-api/system/tenant/get-by-website # 基于域名获取租户,不许带租户编号 |
|
174 |
- /admin-api/system/captcha/get-image # 获取图片验证码,和租户无关 |
|
175 |
- /admin-api/system/captcha/get # 获取图片验证码,和租户无关 |
|
176 |
- /admin-api/system/captcha/check # 校验图片验证码,和租户无关 |
|
177 |
- /admin-api/system/sms/callback/* # 短信回调接口,无法带上租户编号 |
|
178 |
- /rpc-api/system/tenant/valid # 防止递归。避免调用 /rpc-api/system/tenant/valid 接口时,又去触发 /rpc-api/system/tenant/valid 去校验 |
|
179 |
- /rpc-api/system/tenant/id-list # 获得租户列表的时候,无需传递租户编号 |
|
180 |
- /rpc-api/system/oauth2/token/check # 访问令牌校验时,无需传递租户编号;主要解决上传文件的场景,前端不会传递 tenant-id! |
|
181 |
ignore-tables: |
|
182 |
- system_tenant |
|
183 |
- system_tenant_package |
|
184 |
- system_dict_data |
|
185 |
- system_dict_type |
|
186 |
- system_error_code |
|
187 |
- system_menu |
|
188 |
- system_sms_channel |
|
189 |
- system_sms_template |
|
190 |
- system_sms_log |
|
191 |
- system_sensitive_word |
|
192 |
- system_oauth2_client |
|
193 |
- system_mail_account |
|
194 |
- system_mail_template |
|
195 |
- system_mail_log |
|
196 |
- system_notify_template |
|
197 |
sms-code: # 短信验证码相关的配置项 |
|
198 |
expire-times: 10m |
|
199 |
send-frequency: 1m |
|
200 |
send-maximum-quantity-per-day: 10 |
|
201 |
begin-code: 9999 # 这里配置 9999 的原因是,测试方便。 |
|
202 |
end-code: 9999 # 这里配置 9999 的原因是,测试方便。 |
|
203 |
|
|
204 |
debug: false |