Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
doc_wei
Skyeye
提交
030c022e
S
Skyeye
项目概览
doc_wei
/
Skyeye
通知
1194
Star
154
Fork
127
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
Skyeye
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
030c022e
编写于
7月 16, 2024
作者:
doc_wei
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: 新增开发环境与正式环境的区分
上级
81353331
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
103 addition
and
16 deletion
+103
-16
pom.xml
pom.xml
+6
-0
web/src/main/java/com/skyeye/ConfigProperties.java
web/src/main/java/com/skyeye/ConfigProperties.java
+86
-11
web/src/main/java/com/skyeye/ConfigrationController.java
web/src/main/java/com/skyeye/ConfigrationController.java
+3
-2
web/src/main/resources/bootstrap.yml
web/src/main/resources/bootstrap.yml
+2
-1
web/src/main/resources/template/assets/lib/layui/custom.js
web/src/main/resources/template/assets/lib/layui/custom.js
+4
-1
web/src/main/resources/template/js/index/login.js
web/src/main/resources/template/js/index/login.js
+2
-1
未找到文件。
pom.xml
浏览文件 @
030c022e
...
@@ -148,6 +148,12 @@
...
@@ -148,6 +148,12 @@
<artifactId>
freemarker
</artifactId>
<artifactId>
freemarker
</artifactId>
</dependency>
</dependency>
<dependency>
<groupId>
org.yaml
</groupId>
<artifactId>
snakeyaml
</artifactId>
<version>
1.27
</version>
</dependency>
</dependencies>
</dependencies>
<build>
<build>
...
...
web/src/main/java/com/skyeye/ConfigProperties.java
浏览文件 @
030c022e
...
@@ -4,11 +4,21 @@
...
@@ -4,11 +4,21 @@
package
com.skyeye
;
package
com.skyeye
;
import
cn.hutool.core.collection.CollectionUtil
;
import
cn.hutool.core.date.DateUtil
;
import
cn.hutool.core.date.DateUtil
;
import
org.springframework.boot.context.properties.ConfigurationProperties
;
import
cn.hutool.core.util.StrUtil
;
import
com.alibaba.nacos.api.NacosFactory
;
import
com.alibaba.nacos.api.PropertyKeyConst
;
import
com.alibaba.nacos.api.config.ConfigService
;
import
com.alibaba.nacos.api.exception.NacosException
;
import
com.skyeye.common.filter.PropertiesUtil
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.stereotype.Component
;
import
org.springframework.stereotype.Component
;
import
org.yaml.snakeyaml.Yaml
;
import
java.util.Map
;
import
java.io.ByteArrayInputStream
;
import
java.util.*
;
import
java.util.stream.Collectors
;
/**
/**
* @ClassName: ConfigProperties
* @ClassName: ConfigProperties
...
@@ -19,20 +29,85 @@ import java.util.Map;
...
@@ -19,20 +29,85 @@ import java.util.Map;
* 注意:本内容仅限购买后使用.禁止私自外泄以及用于其他的商业目的
* 注意:本内容仅限购买后使用.禁止私自外泄以及用于其他的商业目的
*/
*/
@Component
@Component
@ConfigurationProperties
(
prefix
=
"skyeye.configuation"
)
public
class
ConfigProperties
{
public
class
ConfigProperties
{
public
ConfigProperties
()
{
@Value
(
"${spring.cloud.nacos.config.server-addr}"
)
System
.
setProperty
(
"skyeye.year"
,
String
.
valueOf
(
DateUtil
.
thisYear
()));
private
String
serverAddr
;
}
@Value
(
"${spring.cloud.nacos.config.namespace}"
)
private
String
namespace
;
@Value
(
"${spring.application.name}.${spring.cloud.nacos.config.file-extension}"
)
private
String
dataId
;
@Value
(
"${spring.cloud.nacos.config.group}"
)
private
String
group
;
public
Map
<
String
,
String
>
bindPropertiesToObject
(
String
env
,
String
...
prefix
)
{
try
{
// 创建 Nacos 客户端
Properties
properties
=
new
Properties
();
properties
.
setProperty
(
PropertyKeyConst
.
SERVER_ADDR
,
serverAddr
);
properties
.
setProperty
(
PropertyKeyConst
.
NAMESPACE
,
namespace
);
// 获取配置服务
ConfigService
configService
=
NacosFactory
.
createConfigService
(
properties
);
private
Map
<
String
,
String
>
config
;
// 获取配置
String
content
=
configService
.
getConfig
(
dataId
,
group
,
5000
);
public
Map
<
String
,
String
>
getConfig
()
{
// 使用SnakeYAML解析配置内容为Map
return
config
;
Yaml
yaml
=
new
Yaml
();
ByteArrayInputStream
stream
=
new
ByteArrayInputStream
(
content
.
getBytes
());
Map
<
String
,
Object
>
configMap
=
yaml
.
load
(
stream
);
Map
<
String
,
String
>
result
=
new
HashMap
<>();
loadYamlConfig
(
result
,
configMap
,
prefix
);
Map
<
String
,
String
>
temp
=
new
HashMap
<>();
String
zuulApiKey
=
StrUtil
.
isEmpty
(
env
)
?
"${skyeye.zuulApi}"
:
"${skyeye."
+
env
+
".zuulApi}"
;
String
zuulApi
=
PropertiesUtil
.
getPropertiesValue
(
zuulApiKey
);
temp
.
put
(
zuulApiKey
,
zuulApi
);
temp
.
put
(
"${skyeye.year}"
,
String
.
valueOf
(
DateUtil
.
thisYear
()));
result
.
forEach
((
key
,
value
)
->
{
temp
.
forEach
((
k
,
v
)
->
{
if
(
value
.
contains
(
k
))
{
result
.
put
(
key
,
value
.
replace
(
k
,
v
));
}
});
});
return
result
;
}
catch
(
NacosException
e
)
{
e
.
printStackTrace
();
}
return
null
;
}
}
public
void
setConfig
(
Map
<
String
,
String
>
config
)
{
public
void
loadYamlConfig
(
Map
<
String
,
String
>
result
,
Map
<
String
,
Object
>
configMap
,
String
...
keys
)
{
this
.
config
=
config
;
List
<
String
>
keyList
=
Arrays
.
asList
(
keys
).
stream
().
filter
(
StrUtil:
:
isNotBlank
).
collect
(
Collectors
.
toList
());
if
(
CollectionUtil
.
isEmpty
(
keyList
))
{
configMap
.
forEach
((
key
,
value
)
->
{
result
.
put
(
key
,
value
.
toString
());
});
return
;
}
String
key
=
keyList
.
get
(
0
);
if
(
configMap
.
containsKey
(
key
))
{
Object
value
=
configMap
.
get
(
key
);
if
(
value
instanceof
Map
)
{
if
(
keyList
.
size
()
==
1
)
{
loadYamlConfig
(
result
,
(
Map
<
String
,
Object
>)
value
,
StrUtil
.
EMPTY
);
}
else
{
loadYamlConfig
(
result
,
(
Map
<
String
,
Object
>)
value
,
Arrays
.
copyOfRange
(
keys
,
1
,
keys
.
length
));
}
}
else
{
result
.
put
(
key
,
value
.
toString
());
}
}
}
}
public
Map
<
String
,
String
>
getConfig
(
String
env
)
{
Map
<
String
,
String
>
map
=
bindPropertiesToObject
(
env
,
"skyeye"
,
"configuation"
,
"config"
,
env
);
return
map
;
}
}
}
web/src/main/java/com/skyeye/ConfigrationController.java
浏览文件 @
030c022e
...
@@ -6,6 +6,7 @@ package com.skyeye;
...
@@ -6,6 +6,7 @@ package com.skyeye;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.web.bind.annotation.GetMapping
;
import
org.springframework.web.bind.annotation.GetMapping
;
import
org.springframework.web.bind.annotation.RequestParam
;
import
org.springframework.web.bind.annotation.RestController
;
import
org.springframework.web.bind.annotation.RestController
;
import
java.util.Map
;
import
java.util.Map
;
...
@@ -25,8 +26,8 @@ public class ConfigrationController {
...
@@ -25,8 +26,8 @@ public class ConfigrationController {
private
ConfigProperties
configProperties
;
private
ConfigProperties
configProperties
;
@GetMapping
(
value
=
"/getConfigRation"
)
@GetMapping
(
value
=
"/getConfigRation"
)
public
Map
<
String
,
String
>
getConfigRation
()
{
public
Map
<
String
,
String
>
getConfigRation
(
@RequestParam
(
"env"
)
String
env
)
{
return
configProperties
.
getConfig
();
return
configProperties
.
getConfig
(
env
);
}
}
}
}
web/src/main/resources/bootstrap.yml
浏览文件 @
030c022e
...
@@ -17,4 +17,5 @@ spring:
...
@@ -17,4 +17,5 @@ spring:
# 指定nacos server的地址
# 指定nacos server的地址
server-addr
:
172.18.92.40:9000
server-addr
:
172.18.92.40:9000
file-extension
:
yml
file-extension
:
yml
namespace
:
${spring.profiles.active}
# 配置命名空间
namespace
:
${spring.profiles.active}
# 配置命名空间
\ No newline at end of file
group
:
DEFAULT_GROUP
# 配置分组
\ No newline at end of file
web/src/main/resources/template/assets/lib/layui/custom.js
浏览文件 @
030c022e
...
@@ -34,10 +34,13 @@ var customerJS = {
...
@@ -34,10 +34,13 @@ var customerJS = {
"
schoolUtil
"
:
"
../../assets/lib/layui/customer/skyeye/schoolUtil.js
"
,
// 学校模块工具类
"
schoolUtil
"
:
"
../../assets/lib/layui/customer/skyeye/schoolUtil.js
"
,
// 学校模块工具类
};
};
// 登录界面赋值
var
env
=
''
;
//系统基础信息
//系统基础信息
var
sysMainMation
=
{};
// 系统基础信息json
var
sysMainMation
=
{};
// 系统基础信息json
if
(
isNull
(
localStorage
.
getItem
(
"
sysMainMation
"
)))
{
if
(
isNull
(
localStorage
.
getItem
(
"
sysMainMation
"
)))
{
jsGetJsonFile
(
"
../../configRation.json
"
,
function
(
data
)
{
jsGetJsonFile
(
"
../../configRation.json
?env=
"
+
env
,
function
(
data
)
{
sysMainMation
=
data
;
sysMainMation
=
data
;
localStorage
.
setItem
(
"
sysMainMation
"
,
JSON
.
stringify
(
sysMainMation
));
localStorage
.
setItem
(
"
sysMainMation
"
,
JSON
.
stringify
(
sysMainMation
));
initBaseParams
();
initBaseParams
();
...
...
web/src/main/resources/template/js/index/login.js
浏览文件 @
030c022e
...
@@ -9,9 +9,10 @@ layui.config({
...
@@ -9,9 +9,10 @@ layui.config({
winui
.
renderColor
();
winui
.
renderColor
();
layui
.
use
([
'
form
'
],
function
(
form
)
{
layui
.
use
([
'
form
'
],
function
(
form
)
{
var
$
=
layui
.
$
;
var
$
=
layui
.
$
;
env
=
GetUrlParam
(
"
env
"
);
// 系统配置文件
// 系统配置文件
jsGetJsonFile
(
"
../../configRation.json
"
,
function
(
data
)
{
jsGetJsonFile
(
"
../../configRation.json
?env=
"
+
env
,
function
(
data
)
{
sysMainMation
=
data
;
sysMainMation
=
data
;
localStorage
.
setItem
(
"
sysMainMation
"
,
JSON
.
stringify
(
sysMainMation
));
localStorage
.
setItem
(
"
sysMainMation
"
,
JSON
.
stringify
(
sysMainMation
));
});
});
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录