Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
D
datav_platform
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
廖旭伟
datav_platform
Commits
db0f293e
Commit
db0f293e
authored
Nov 07, 2023
by
廖旭伟
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/master'
# Conflicts: # datav-manager/pom.xml
parents
8e7bbdf5
81b41750
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
169 additions
and
59 deletions
+169
-59
common-lib/pom.xml
common-lib/pom.xml
+9
-0
common-lib/src/main/java/com/mortals/xhx/common/keys/QueueKey.java
...b/src/main/java/com/mortals/xhx/common/keys/QueueKey.java
+25
-0
common-lib/src/main/java/com/mortals/xhx/system/MessageProducer.java
...src/main/java/com/mortals/xhx/system/MessageProducer.java
+48
-0
datav-manager/src/main/java/com/mortals/xhx/base/framework/aspect/OperlogAspect.java
.../com/mortals/xhx/base/framework/aspect/OperlogAspect.java
+22
-1
datav-manager/src/main/java/com/mortals/xhx/base/framework/aspect/WebLogAspect.java
...a/com/mortals/xhx/base/framework/aspect/WebLogAspect.java
+2
-2
datav-manager/src/main/java/com/mortals/xhx/base/framework/security/SecurityUtils.java
...om/mortals/xhx/base/framework/security/SecurityUtils.java
+54
-54
datav-manager/src/main/java/com/mortals/xhx/module/picture/web/PictureGroupController.java
...ortals/xhx/module/picture/web/PictureGroupController.java
+0
-1
datav-manager/src/main/resources/bootstrap.yml
datav-manager/src/main/resources/bootstrap.yml
+9
-1
No files found.
common-lib/pom.xml
View file @
db0f293e
...
...
@@ -53,7 +53,16 @@
<artifactId>
guava
</artifactId>
</dependency>
<dependency>
<groupId>
com.rabbitmq
</groupId>
<artifactId>
amqp-client
</artifactId>
<version>
4.8.0
</version>
</dependency>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-amqp
</artifactId>
</dependency>
<dependency>
<groupId>
junit
</groupId>
...
...
common-lib/src/main/java/com/mortals/xhx/common/keys/QueueKey.java
0 → 100644
View file @
db0f293e
package
com.mortals.xhx.common.keys
;
/**
* rabbit 队列key定义
*/
public
class
QueueKey
{
public
static
final
String
ACCESS_LOG_QUEUE
=
"ACCESS_LOG_QUEUE"
;
public
static
final
String
BIZ_LOG_QUEUE
=
"BIZ_LOG_QUEUE"
;
public
static
final
String
ERROR_LOG_QUEUE
=
"ERROR_LOG_QUEUE"
;
public
static
final
String
OPERATION_LOG_QUEUE
=
"OPERATION_LOG_QUEUE"
;
public
static
final
String
EXCHANGE
=
"LOG"
;
public
static
final
String
ROUTING_KEY
=
"LOG_ROUTING_KEY"
;
}
common-lib/src/main/java/com/mortals/xhx/system/MessageProducer.java
0 → 100644
View file @
db0f293e
package
com.mortals.xhx.system
;
import
com.alibaba.fastjson.JSON
;
import
com.mortals.framework.model.AccessLogPdu
;
import
com.mortals.framework.model.BizLogPdu
;
import
com.mortals.framework.model.ErrorLogPdu
;
import
com.mortals.framework.model.OperateLogPdu
;
import
com.mortals.framework.service.IMessageProduceService
;
import
com.mortals.xhx.common.keys.QueueKey
;
import
lombok.extern.slf4j.Slf4j
;
import
org.springframework.amqp.rabbit.core.RabbitTemplate
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.context.annotation.Primary
;
import
org.springframework.stereotype.Component
;
@Component
@Primary
@Slf4j
public
class
MessageProducer
implements
IMessageProduceService
{
@Autowired
private
RabbitTemplate
rabbitTemplate
;
public
void
syncAccessSend
(
AccessLogPdu
accessLogPdu
)
{
//new Message(JSON.toJSONString(accessLogPdu).getBytes(StandardCharsets.UTF_8))
//rabbitTemplate.send(QueueKey.EXCHANGE, QueueKey.ACCESS_LOG_QUEUE,new Message(JSON.toJSONString(accessLogPdu).getBytes(StandardCharsets.UTF_8)));
rabbitTemplate
.
convertAndSend
(
QueueKey
.
EXCHANGE
,
QueueKey
.
ACCESS_LOG_QUEUE
,
JSON
.
toJSONString
(
accessLogPdu
));
//rabbitTemplate.convertAndSend(QueueKey.EXCHANGE, QueueKey.ACCESS_LOG_QUEUE, accessLogPdu);
}
@Override
public
void
syncBizSend
(
BizLogPdu
bizLogPdu
)
{
rabbitTemplate
.
convertAndSend
(
QueueKey
.
EXCHANGE
,
QueueKey
.
BIZ_LOG_QUEUE
,
JSON
.
toJSONString
(
bizLogPdu
));
}
@Override
public
void
syncErrorSend
(
ErrorLogPdu
errorLogPdu
)
{
rabbitTemplate
.
convertAndSend
(
QueueKey
.
EXCHANGE
,
QueueKey
.
ERROR_LOG_QUEUE
,
JSON
.
toJSONString
(
errorLogPdu
));
}
@Override
public
void
syncOperSend
(
OperateLogPdu
operLogPdu
)
{
log
.
info
(
JSON
.
toJSONString
(
operLogPdu
));
rabbitTemplate
.
convertAndSend
(
QueueKey
.
EXCHANGE
,
QueueKey
.
OPERATION_LOG_QUEUE
,
JSON
.
toJSONString
(
operLogPdu
));
}
}
datav-manager/src/main/java/com/mortals/xhx/base/framework/aspect/OperlogAspect.java
View file @
db0f293e
...
...
@@ -4,6 +4,9 @@ import java.util.Date;
import
javax.servlet.http.HttpServletRequest
;
import
com.mortals.framework.model.OperateLogPdu
;
import
com.mortals.framework.service.IMessageProduceService
;
import
com.mortals.xhx.system.MessageProducer
;
import
org.aspectj.lang.JoinPoint
;
import
org.aspectj.lang.annotation.AfterReturning
;
import
org.aspectj.lang.annotation.Aspect
;
...
...
@@ -13,6 +16,7 @@ import org.slf4j.Logger;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Component
;
import
org.springframework.util.ObjectUtils
;
import
org.springframework.web.context.request.RequestContextHolder
;
import
org.springframework.web.context.request.ServletRequestAttributes
;
...
...
@@ -30,12 +34,27 @@ public class OperlogAspect extends FileLogServiceImpl implements ILogService {
@Autowired
private
OperLogService
operLogService
;
@Autowired
private
IMessageProduceService
messageProducer
;
@Override
public
void
doHandlerLog
(
String
platformMark
,
Long
userId
,
String
userName
,
String
loginName
,
String
requestUrl
,
String
content
,
String
ip
,
Date
logDate
)
{
super
.
doHandlerLog
(
platformMark
,
userId
,
userName
,
loginName
,
requestUrl
,
content
,
ip
,
logDate
);
operLogService
.
insertOperLog
(
ip
,
requestUrl
,
userId
,
userName
,
loginName
,
content
);
OperateLogPdu
operateLogPdu
=
new
OperateLogPdu
();
operateLogPdu
.
initAttrValue
();
operateLogPdu
.
setIp
(
ip
);
operateLogPdu
.
setRequestUrl
(
requestUrl
);
operateLogPdu
.
setUserId
(
userId
);
operateLogPdu
.
setUserName
(
userName
);
operateLogPdu
.
setLoginName
(
loginName
);
operateLogPdu
.
setPlatformMark
(
platformMark
);
operateLogPdu
.
setLogDate
(
logDate
);
operateLogPdu
.
setContent
(
content
);
operateLogPdu
.
setOperType
(
1
);
messageProducer
.
syncOperSend
(
operateLogPdu
);
}
@Override
...
...
@@ -43,6 +62,8 @@ public class OperlogAspect extends FileLogServiceImpl implements ILogService {
// operLogService.insertOperLog(ip, requestUrl, null, "", loginName,
// content);
this
.
doHandlerLog
(
platformMark
,
null
,
""
,
loginName
,
requestUrl
,
content
,
ip
,
new
Date
());
}
@Pointcut
(
"execution(public * com.mortals.xhx..*Controller.*(..))"
)
...
...
datav-manager/src/main/java/com/mortals/xhx/base/framework/aspect/WebLogAspect.java
View file @
db0f293e
...
...
@@ -27,8 +27,8 @@ import java.util.Map;
* @author: zxfei
* @date: 2022/4/20 9:24
*/
@Aspect
@Component
//
@Aspect
//
@Component
@Slf4j
@Order
(
1
)
@Profile
({
"default"
,
"develop"
,
"test"
})
...
...
datav-manager/src/main/java/com/mortals/xhx/base/framework/security/SecurityUtils.java
View file @
db0f293e
package
com.mortals.xhx.base.framework.security
;
import
org.springframework.security.core.Authentication
;
import
org.springframework.security.core.context.SecurityContextHolder
;
import
org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder
;
/**
* 安全服务工具类
*
* @author zxfei
*/
public
class
SecurityUtils
{
/**
* 获取Authentication
*/
public
static
Authentication
getAuthentication
()
{
return
SecurityContextHolder
.
getContext
().
getAuthentication
();
}
/**
* 生成BCryptPasswordEncoder密码
*
* @param password 密码
* @return 加密字符串
*/
public
static
String
encryptPassword
(
String
password
)
{
BCryptPasswordEncoder
passwordEncoder
=
new
BCryptPasswordEncoder
();
return
passwordEncoder
.
encode
(
password
);
}
/**
* 判断密码是否相同
*
* @param rawPassword 真实密码
* @param encodedPassword 加密后字符
* @return 结果
*/
public
static
boolean
matchesPassword
(
String
rawPassword
,
String
encodedPassword
)
{
BCryptPasswordEncoder
passwordEncoder
=
new
BCryptPasswordEncoder
();
return
passwordEncoder
.
matches
(
rawPassword
,
encodedPassword
);
}
/**
* 是否为管理员
*
* @param userId 用户ID
* @return 结果
*/
public
static
boolean
isAdmin
(
Long
userId
)
{
return
userId
!=
null
&&
1L
==
userId
;
}
}
//
package com.mortals.xhx.base.framework.security;
//
//
import org.springframework.security.core.Authentication;
//
import org.springframework.security.core.context.SecurityContextHolder;
//
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
//
/
//
**
//
* 安全服务工具类
//
*
//
* @author zxfei
//
*/
//
public class SecurityUtils {
//
//
//
/**
//
* 获取Authentication
//
*/
//
public static Authentication getAuthentication() {
//
return SecurityContextHolder.getContext().getAuthentication();
//
}
//
//
/**
//
* 生成BCryptPasswordEncoder密码
//
*
//
* @param password 密码
//
* @return 加密字符串
//
*/
//
public static String encryptPassword(String password) {
//
BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder();
//
return passwordEncoder.encode(password);
//
}
//
//
/**
//
* 判断密码是否相同
//
*
//
* @param rawPassword 真实密码
//
* @param encodedPassword 加密后字符
//
* @return 结果
//
*/
//
public static boolean matchesPassword(String rawPassword, String encodedPassword) {
//
BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder();
//
return passwordEncoder.matches(rawPassword, encodedPassword);
//
}
//
//
/**
//
* 是否为管理员
//
*
//
* @param userId 用户ID
//
* @return 结果
//
*/
//
public static boolean isAdmin(Long userId) {
//
return userId != null && 1L == userId;
//
}
//
}
datav-manager/src/main/java/com/mortals/xhx/module/picture/web/PictureGroupController.java
View file @
db0f293e
...
...
@@ -17,7 +17,6 @@ import com.mortals.xhx.common.utils.StringUtils;
import
com.mortals.xhx.module.picture.model.vo.PictureGroupCountVo
;
import
com.mortals.xhx.module.picture.service.PictureMaterialService
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.security.core.parameters.P
;
import
org.springframework.web.bind.annotation.PostMapping
;
import
org.springframework.web.bind.annotation.RequestBody
;
import
org.springframework.web.bind.annotation.RequestMapping
;
...
...
datav-manager/src/main/resources/bootstrap.yml
View file @
db0f293e
...
...
@@ -4,9 +4,11 @@ server:
context-path
:
/dm
tomcat
:
uri-encoding
:
utf-8
platform
:
mark
:
datav-manager
spring
:
application
:
name
:
certificate
-manager
name
:
datav
-manager
profiles
:
active
:
@
profiles.active@
servlet
:
...
...
@@ -16,6 +18,12 @@ spring:
jackson
:
date-format
:
yyyy-MM-dd HH:mm:ss
time-zone
:
GMT+8
rabbitmq
:
host
:
@
profiles.rabbitmq.host@
port
:
@
profiles.rabbitmq.port@
username
:
@
profiles.rabbitmq.username@
password
:
@
profiles.rabbitmq.password@
virtualHost
:
@
profiles.rabbitmq.virtualhost@
security
:
enable
:
true
user
:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment