Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
I
ibzdict
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
ibiz4jteam
ibzdict
提交
24c142ab
提交
24c142ab
编写于
4月 26, 2020
作者:
ibizdev
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ibizdev提交
上级
a2e3b81c
变更
14
隐藏空白字符变更
内嵌
并排
正在显示
14 个修改的文件
包含
357 行增加
和
70 行删除
+357
-70
IBZDictMapper.xml
.../src/main/resources/mapper/dict/ibzdict/IBZDictMapper.xml
+2
-1
IBZDictItemMapper.xml
...n/resources/mapper/dict/ibzdictitem/IBZDictItemMapper.xml
+2
-1
pom.xml
ibzdict-util/pom.xml
+5
-0
BadRequestAlertException.java
...java/cn/ibizlab/util/errors/BadRequestAlertException.java
+40
-0
CustomParameterizedException.java
.../cn/ibizlab/util/errors/CustomParameterizedException.java
+41
-0
ErrorConstants.java
.../src/main/java/cn/ibizlab/util/errors/ErrorConstants.java
+16
-0
ExceptionTranslator.java
...main/java/cn/ibizlab/util/errors/ExceptionTranslator.java
+99
-0
FieldErrorVM.java
...il/src/main/java/cn/ibizlab/util/errors/FieldErrorVM.java
+33
-0
InternalServerErrorException.java
.../cn/ibizlab/util/errors/InternalServerErrorException.java
+11
-0
AuthenticationController.java
...n/java/cn/ibizlab/util/rest/AuthenticationController.java
+5
-13
AuthorizationTokenFilter.java
...va/cn/ibizlab/util/security/AuthorizationTokenFilter.java
+1
-1
IBZUSERService.java
...src/main/java/cn/ibizlab/util/service/IBZUSERService.java
+1
-19
IBZUSERServiceImpl.java
...main/java/cn/ibizlab/util/service/IBZUSERServiceImpl.java
+49
-32
SimpleUserService.java
.../main/java/cn/ibizlab/util/service/SimpleUserService.java
+52
-3
未找到文件。
ibzdict-core/src/main/resources/mapper/dict/ibzdict/IBZDictMapper.xml
浏览文件 @
24c142ab
...
@@ -12,7 +12,8 @@
...
@@ -12,7 +12,8 @@
<resultMap
id=
"IBZDictResultMap"
type=
"cn.ibizlab.core.dict.domain.IBZDict"
autoMapping=
"true"
>
<resultMap
id=
"IBZDictResultMap"
type=
"cn.ibizlab.core.dict.domain.IBZDict"
autoMapping=
"true"
>
<id
property=
"dictid"
column=
"ibzdictid"
/>
<!--主键字段映射-->
<id
property=
"dictid"
column=
"ibzdictid"
/>
<!--主键字段映射-->
<result
property=
"dictname"
column=
"ibzdictname"
/>
<result
property=
"dictname"
column=
"ibzdictname"
/>
</resultMap>
</resultMap>
...
...
ibzdict-core/src/main/resources/mapper/dict/ibzdictitem/IBZDictItemMapper.xml
浏览文件 @
24c142ab
...
@@ -14,7 +14,8 @@
...
@@ -14,7 +14,8 @@
<result
property=
"itemname"
column=
"ibzdictitemname"
/>
<result
property=
"itemname"
column=
"ibzdictitemname"
/>
<result
property=
"itemval"
column=
"dictitemval"
/>
<result
property=
"itemval"
column=
"dictitemval"
/>
<result
property=
"dictid"
column=
"dictid"
/>
<result
property=
"dictid"
column=
"dictid"
/>
<!--通过mybatis自动注入关系属性[主实体],fetchType="lazy"为懒加载配置 -->
<!--通过mybatis自动注入关系属性[主实体],fetchType="lazy"为懒加载配置 -->
<association
property=
"dict"
javaType=
"cn.ibizlab.core.dict.domain.IBZDict"
column=
"dictid"
select=
"cn.ibizlab.core.dict.mapper.IBZDictMapper.selectById"
fetchType=
"lazy"
></association>
<association
property=
"dict"
javaType=
"cn.ibizlab.core.dict.domain.IBZDict"
column=
"dictid"
select=
"cn.ibizlab.core.dict.mapper.IBZDictMapper.selectById"
fetchType=
"lazy"
></association>
</resultMap>
</resultMap>
...
...
ibzdict-util/pom.xml
浏览文件 @
24c142ab
...
@@ -49,5 +49,10 @@
...
@@ -49,5 +49,10 @@
<artifactId>
jjwt
</artifactId>
<artifactId>
jjwt
</artifactId>
</dependency>
</dependency>
<dependency>
<groupId>
org.zalando
</groupId>
<artifactId>
problem-spring-web
</artifactId>
</dependency>
</dependencies>
</dependencies>
</project>
</project>
ibzdict-util/src/main/java/cn/ibizlab/util/errors/BadRequestAlertException.java
0 → 100644
浏览文件 @
24c142ab
package
cn
.
ibizlab
.
util
.
errors
;
import
org.zalando.problem.AbstractThrowableProblem
;
import
org.zalando.problem.Status
;
import
java.net.URI
;
import
java.util.HashMap
;
import
java.util.Map
;
public
class
BadRequestAlertException
extends
AbstractThrowableProblem
{
private
final
String
entityName
;
private
final
String
errorKey
;
public
BadRequestAlertException
(
String
defaultMessage
,
String
entityName
,
String
errorKey
)
{
this
(
ErrorConstants
.
DEFAULT_TYPE
,
defaultMessage
,
entityName
,
errorKey
);
}
public
BadRequestAlertException
(
URI
type
,
String
defaultMessage
,
String
entityName
,
String
errorKey
)
{
super
(
type
,
defaultMessage
,
Status
.
BAD_REQUEST
,
null
,
null
,
null
,
getAlertParameters
(
entityName
,
errorKey
));
this
.
entityName
=
entityName
;
this
.
errorKey
=
errorKey
;
}
public
String
getEntityName
()
{
return
entityName
;
}
public
String
getErrorKey
()
{
return
errorKey
;
}
private
static
Map
<
String
,
Object
>
getAlertParameters
(
String
entityName
,
String
errorKey
)
{
Map
<
String
,
Object
>
parameters
=
new
HashMap
<>();
parameters
.
put
(
"message"
,
"error."
+
errorKey
);
parameters
.
put
(
"params"
,
entityName
);
return
parameters
;
}
}
ibzdict-util/src/main/java/cn/ibizlab/util/errors/CustomParameterizedException.java
0 → 100644
浏览文件 @
24c142ab
package
cn
.
ibizlab
.
util
.
errors
;
import
org.zalando.problem.AbstractThrowableProblem
;
import
java.util.HashMap
;
import
java.util.Map
;
import
static
org
.
zalando
.
problem
.
Status
.
BAD_REQUEST
;
public
class
CustomParameterizedException
extends
AbstractThrowableProblem
{
private
static
final
long
serialVersionUID
=
1L
;
private
static
final
String
PARAM
=
"param"
;
public
CustomParameterizedException
(
String
message
,
String
...
params
)
{
this
(
message
,
toParamMap
(
params
));
}
public
CustomParameterizedException
(
String
message
,
Map
<
String
,
Object
>
paramMap
)
{
super
(
ErrorConstants
.
PARAMETERIZED_TYPE
,
"处理发生异常"
,
BAD_REQUEST
,
null
,
null
,
null
,
toProblemParameters
(
message
,
paramMap
));
}
public
static
Map
<
String
,
Object
>
toParamMap
(
String
...
params
)
{
Map
<
String
,
Object
>
paramMap
=
new
HashMap
<>();
if
(
params
!=
null
&&
params
.
length
>
0
)
{
for
(
int
i
=
0
;
i
<
params
.
length
;
i
++)
{
paramMap
.
put
(
PARAM
+
i
,
params
[
i
]);
}
}
return
paramMap
;
}
public
static
Map
<
String
,
Object
>
toProblemParameters
(
String
message
,
Map
<
String
,
Object
>
paramMap
)
{
Map
<
String
,
Object
>
parameters
=
new
HashMap
<>();
parameters
.
put
(
"message"
,
message
);
parameters
.
put
(
"params"
,
paramMap
);
return
parameters
;
}
}
ibzdict-util/src/main/java/cn/ibizlab/util/errors/ErrorConstants.java
0 → 100644
浏览文件 @
24c142ab
package
cn
.
ibizlab
.
util
.
errors
;
import
java.net.URI
;
public
final
class
ErrorConstants
{
public
static
final
String
ERR_CONCURRENCY_FAILURE
=
"处理请求发生错误"
;
public
static
final
String
ERR_VALIDATION
=
"数据校验发生错误"
;
public
static
final
String
PROBLEM_BASE_URL
=
""
;
public
static
final
URI
DEFAULT_TYPE
=
URI
.
create
(
PROBLEM_BASE_URL
+
"/problem-with-message"
);
public
static
final
URI
CONSTRAINT_VIOLATION_TYPE
=
URI
.
create
(
PROBLEM_BASE_URL
+
"/constraint-violation"
);
public
static
final
URI
PARAMETERIZED_TYPE
=
URI
.
create
(
PROBLEM_BASE_URL
+
"/parameterized"
);
private
ErrorConstants
()
{
}
}
ibzdict-util/src/main/java/cn/ibizlab/util/errors/ExceptionTranslator.java
0 → 100644
浏览文件 @
24c142ab
package
cn
.
ibizlab
.
util
.
errors
;
import
org.springframework.dao.ConcurrencyFailureException
;
import
org.springframework.http.HttpHeaders
;
import
org.springframework.http.ResponseEntity
;
import
org.springframework.validation.BindingResult
;
import
org.springframework.web.bind.MethodArgumentNotValidException
;
import
org.springframework.web.bind.annotation.ControllerAdvice
;
import
org.springframework.web.bind.annotation.ExceptionHandler
;
import
org.springframework.web.context.request.NativeWebRequest
;
import
org.zalando.problem.DefaultProblem
;
import
org.zalando.problem.Problem
;
import
org.zalando.problem.ProblemBuilder
;
import
org.zalando.problem.Status
;
import
org.zalando.problem.spring.web.advice.ProblemHandling
;
import
org.zalando.problem.spring.web.advice.validation.ConstraintViolationProblem
;
import
javax.annotation.Nonnull
;
import
javax.annotation.Nullable
;
import
javax.servlet.http.HttpServletRequest
;
import
java.util.List
;
import
java.util.stream.Collectors
;
@ControllerAdvice
public
class
ExceptionTranslator
implements
ProblemHandling
{
@Override
public
ResponseEntity
<
Problem
>
process
(
@Nullable
ResponseEntity
<
Problem
>
entity
,
NativeWebRequest
request
)
{
if
(
entity
==
null
||
entity
.
getBody
()
==
null
)
{
return
entity
;
}
Problem
problem
=
entity
.
getBody
();
if
(!(
problem
instanceof
ConstraintViolationProblem
||
problem
instanceof
DefaultProblem
))
{
return
entity
;
}
ProblemBuilder
builder
=
Problem
.
builder
()
.
withType
(
Problem
.
DEFAULT_TYPE
.
equals
(
problem
.
getType
())
?
ErrorConstants
.
DEFAULT_TYPE
:
problem
.
getType
())
.
withStatus
(
problem
.
getStatus
())
.
withTitle
(
problem
.
getTitle
())
.
with
(
"path"
,
request
.
getNativeRequest
(
HttpServletRequest
.
class
).
getRequestURI
());
if
(
problem
instanceof
ConstraintViolationProblem
)
{
builder
.
with
(
"violations"
,
((
ConstraintViolationProblem
)
problem
).
getViolations
())
.
with
(
"message"
,
ErrorConstants
.
ERR_VALIDATION
);
return
new
ResponseEntity
<>(
builder
.
build
(),
entity
.
getHeaders
(),
entity
.
getStatusCode
());
}
else
{
builder
.
withCause
(((
DefaultProblem
)
problem
).
getCause
())
.
withDetail
(
problem
.
getDetail
())
.
withInstance
(
problem
.
getInstance
());
problem
.
getParameters
().
forEach
(
builder:
:
with
);
if
(!
problem
.
getParameters
().
containsKey
(
"message"
)
&&
problem
.
getStatus
()
!=
null
)
{
builder
.
with
(
"message"
,
"error.http."
+
problem
.
getStatus
().
getStatusCode
());
}
return
new
ResponseEntity
<>(
builder
.
build
(),
entity
.
getHeaders
(),
entity
.
getStatusCode
());
}
}
@Override
public
ResponseEntity
<
Problem
>
handleMethodArgumentNotValid
(
MethodArgumentNotValidException
ex
,
@Nonnull
NativeWebRequest
request
)
{
BindingResult
result
=
ex
.
getBindingResult
();
List
<
FieldErrorVM
>
fieldErrors
=
result
.
getFieldErrors
().
stream
()
.
map
(
f
->
new
FieldErrorVM
(
f
.
getObjectName
(),
f
.
getField
(),
f
.
getDefaultMessage
()))
.
collect
(
Collectors
.
toList
());
Problem
problem
=
Problem
.
builder
()
.
withType
(
ErrorConstants
.
CONSTRAINT_VIOLATION_TYPE
)
.
withTitle
(
ErrorConstants
.
ERR_VALIDATION
)
.
withStatus
(
defaultConstraintViolationStatus
())
.
with
(
"message"
,
ErrorConstants
.
ERR_VALIDATION
)
.
with
(
"fieldErrors"
,
fieldErrors
)
.
build
();
return
create
(
ex
,
problem
,
request
);
}
@ExceptionHandler
(
BadRequestAlertException
.
class
)
public
ResponseEntity
<
Problem
>
handleBadRequestAlertException
(
BadRequestAlertException
ex
,
NativeWebRequest
request
)
{
return
create
(
ex
,
request
,
createFailureAlert
(
ex
.
getEntityName
(),
ex
.
getErrorKey
(),
ex
.
getMessage
()));
}
@ExceptionHandler
(
ConcurrencyFailureException
.
class
)
public
ResponseEntity
<
Problem
>
handleConcurrencyFailure
(
ConcurrencyFailureException
ex
,
NativeWebRequest
request
)
{
Problem
problem
=
Problem
.
builder
()
.
withStatus
(
Status
.
CONFLICT
)
.
with
(
"message"
,
ErrorConstants
.
ERR_CONCURRENCY_FAILURE
)
.
build
();
return
create
(
ex
,
problem
,
request
);
}
public
static
HttpHeaders
createFailureAlert
(
String
entityName
,
String
errorKey
,
String
defaultMessage
)
{
HttpHeaders
headers
=
new
HttpHeaders
();
headers
.
add
(
"X-ibz-error"
,
"error."
+
errorKey
);
headers
.
add
(
"X-ibz-params"
,
entityName
);
return
headers
;
}
}
ibzdict-util/src/main/java/cn/ibizlab/util/errors/FieldErrorVM.java
0 → 100644
浏览文件 @
24c142ab
package
cn
.
ibizlab
.
util
.
errors
;
import
java.io.Serializable
;
public
class
FieldErrorVM
implements
Serializable
{
private
static
final
long
serialVersionUID
=
1L
;
private
final
String
objectName
;
private
final
String
field
;
private
final
String
message
;
public
FieldErrorVM
(
String
dto
,
String
field
,
String
message
)
{
this
.
objectName
=
dto
;
this
.
field
=
field
;
this
.
message
=
message
;
}
public
String
getObjectName
()
{
return
objectName
;
}
public
String
getField
()
{
return
field
;
}
public
String
getMessage
()
{
return
message
;
}
}
ibzdict-util/src/main/java/cn/ibizlab/util/errors/InternalServerErrorException.java
0 → 100644
浏览文件 @
24c142ab
package
cn
.
ibizlab
.
util
.
errors
;
import
org.zalando.problem.AbstractThrowableProblem
;
import
org.zalando.problem.Status
;
public
class
InternalServerErrorException
extends
AbstractThrowableProblem
{
public
InternalServerErrorException
(
String
message
)
{
super
(
ErrorConstants
.
DEFAULT_TYPE
,
message
,
Status
.
INTERNAL_SERVER_ERROR
);
}
}
ibzdict-util/src/main/java/cn/ibizlab/util/rest/AuthenticationController.java
浏览文件 @
24c142ab
...
@@ -5,15 +5,13 @@ import cn.ibizlab.util.security.AuthenticationInfo;
...
@@ -5,15 +5,13 @@ import cn.ibizlab.util.security.AuthenticationInfo;
import
cn.ibizlab.util.security.AuthenticationUser
;
import
cn.ibizlab.util.security.AuthenticationUser
;
import
cn.ibizlab.util.security.AuthorizationLogin
;
import
cn.ibizlab.util.security.AuthorizationLogin
;
import
cn.ibizlab.util.security.AuthTokenUtil
;
import
cn.ibizlab.util.security.AuthTokenUtil
;
import
cn.ibizlab.util.service.
IBZUSER
Service
;
import
cn.ibizlab.util.service.
AuthenticationUser
Service
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Qualifier
;
import
org.springframework.beans.factory.annotation.Qualifier
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.http.ResponseEntity
;
import
org.springframework.http.ResponseEntity
;
import
org.springframework.security.core.context.SecurityContextHolder
;
import
org.springframework.security.core.context.SecurityContextHolder
;
import
org.springframework.security.core.userdetails.UserDetails
;
import
org.springframework.security.core.userdetails.UserDetails
;
import
org.springframework.security.core.userdetails.UserDetailsService
;
import
org.springframework.util.DigestUtils
;
import
org.springframework.validation.annotation.Validated
;
import
org.springframework.validation.annotation.Validated
;
import
org.springframework.web.bind.annotation.*
;
import
org.springframework.web.bind.annotation.*
;
...
@@ -21,8 +19,6 @@ import org.springframework.web.bind.annotation.*;
...
@@ -21,8 +19,6 @@ import org.springframework.web.bind.annotation.*;
@RequestMapping
(
"/"
)
@RequestMapping
(
"/"
)
public
class
AuthenticationController
public
class
AuthenticationController
{
{
@Value
(
"${ibiz.auth.pwencry:false}"
)
private
boolean
pwencry
;
@Value
(
"${ibiz.jwt.header:Authorization}"
)
@Value
(
"${ibiz.jwt.header:Authorization}"
)
private
String
tokenHeader
;
private
String
tokenHeader
;
...
@@ -31,16 +27,12 @@ public class AuthenticationController
...
@@ -31,16 +27,12 @@ public class AuthenticationController
private
AuthTokenUtil
jwtTokenUtil
;
private
AuthTokenUtil
jwtTokenUtil
;
@Autowired
@Autowired
@Qualifier
(
"AuthenticationUserService"
)
private
AuthenticationUserService
userDetailsService
;
private
UserDetailsService
userDetailsService
;
@Autowired
private
IBZUSERService
userService
;
@PostMapping
(
value
=
"${ibiz.auth.path:v7/login}"
)
@PostMapping
(
value
=
"${ibiz.auth.path:v7/login}"
)
public
ResponseEntity
<
AuthenticationInfo
>
login
(
@Validated
@RequestBody
AuthorizationLogin
authorizationLogin
){
public
ResponseEntity
<
AuthenticationInfo
>
login
(
@Validated
@RequestBody
AuthorizationLogin
authorizationLogin
){
userService
.
resetByUsername
(
authorizationLogin
.
getUsername
());
user
Details
Service
.
resetByUsername
(
authorizationLogin
.
getUsername
());
final
AuthenticationUser
authuserdetail
=
(
AuthenticationUser
)
userDetailsService
.
loadUserByUsername
(
authorizationLogin
.
getUsername
());
final
AuthenticationUser
authuserdetail
=
userDetailsService
.
loadUserByLogin
(
authorizationLogin
.
getDomain
(),
authorizationLogin
.
getLoginname
(),
authorizationLogin
.
getPassword
());
// 生成令牌
// 生成令牌
final
String
token
=
jwtTokenUtil
.
generateToken
(
authuserdetail
);
final
String
token
=
jwtTokenUtil
.
generateToken
(
authuserdetail
);
// 返回 token
// 返回 token
...
@@ -58,7 +50,7 @@ public class AuthenticationController
...
@@ -58,7 +50,7 @@ public class AuthenticationController
authuserdetail
=
(
AuthenticationUser
)
userDetails
;
authuserdetail
=
(
AuthenticationUser
)
userDetails
;
}
}
else
{
else
{
authuserdetail
=
(
AuthenticationUser
)
userDetailsService
.
loadUserByUsername
(
userDetails
.
getUsername
());
authuserdetail
=
userDetailsService
.
loadUserByUsername
(
userDetails
.
getUsername
());
}
}
return
ResponseEntity
.
ok
().
body
(
authuserdetail
);
return
ResponseEntity
.
ok
().
body
(
authuserdetail
);
}
}
...
...
ibzdict-util/src/main/java/cn/ibizlab/util/security/AuthorizationTokenFilter.java
浏览文件 @
24c142ab
...
@@ -26,7 +26,7 @@ public class AuthorizationTokenFilter extends OncePerRequestFilter {
...
@@ -26,7 +26,7 @@ public class AuthorizationTokenFilter extends OncePerRequestFilter {
private
final
AuthTokenUtil
authTokenUtil
;
private
final
AuthTokenUtil
authTokenUtil
;
private
final
String
tokenHeader
;
private
final
String
tokenHeader
;
public
AuthorizationTokenFilter
(
@Qualifier
(
"AuthenticationUserService"
)
UserDetailsService
userDetailsService
,
AuthTokenUtil
authTokenUtil
,
@Value
(
"${ibiz.jwt.header:Authorization}"
)
String
tokenHeader
)
{
public
AuthorizationTokenFilter
(
AuthenticationUserService
UserDetailsService
userDetailsService
,
AuthTokenUtil
authTokenUtil
,
@Value
(
"${ibiz.jwt.header:Authorization}"
)
String
tokenHeader
)
{
this
.
userDetailsService
=
userDetailsService
;
this
.
userDetailsService
=
userDetailsService
;
this
.
authTokenUtil
=
authTokenUtil
;
this
.
authTokenUtil
=
authTokenUtil
;
this
.
tokenHeader
=
tokenHeader
;
this
.
tokenHeader
=
tokenHeader
;
...
...
ibzdict-util/src/main/java/cn/ibizlab/util/service/IBZUSERService.java
浏览文件 @
24c142ab
package
cn
.
ibizlab
.
util
.
service
;
package
cn
.
ibizlab
.
util
.
service
;
import
javax.annotation.Resource
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
com.baomidou.mybatisplus.extension.service.impl.ServiceImpl
;
import
cn.ibizlab.util.security.AuthenticationUser
;
import
org.springframework.cache.annotation.CacheEvict
;
import
org.springframework.cache.annotation.Cacheable
;
import
org.springframework.cglib.beans.BeanCopier
;
import
org.springframework.security.core.userdetails.UsernameNotFoundException
;
import
org.springframework.stereotype.Service
;
import
cn.ibizlab.util.mapper.IBZUSERMapper
;
import
cn.ibizlab.util.domain.IBZUSER
;
import
cn.ibizlab.util.domain.IBZUSER
;
import
org.springframework.util.StringUtils
;
import
com.baomidou.mybatisplus.extension.service.IService
;
import
com.baomidou.mybatisplus.extension.service.IService
;
/**
/**
...
@@ -19,11 +8,4 @@ import com.baomidou.mybatisplus.extension.service.IService;
...
@@ -19,11 +8,4 @@ import com.baomidou.mybatisplus.extension.service.IService;
*/
*/
public
interface
IBZUSERService
extends
IService
<
IBZUSER
>
{
public
interface
IBZUSERService
extends
IService
<
IBZUSER
>
{
@Cacheable
(
value
=
"ibzdict_users"
,
key
=
"'getByUsername:'+#p0"
)
}
AuthenticationUser
getByUsername
(
String
username
);
\ No newline at end of file
@CacheEvict
(
value
=
"ibzdict_users"
,
key
=
"'getByUsername:'+#p0"
)
void
resetByUsername
(
String
username
);
AuthenticationUser
createUserDetails
(
IBZUSER
user
);
}
\ No newline at end of file
ibzdict-util/src/main/java/cn/ibizlab/util/service/IBZUSERServiceImpl.java
浏览文件 @
24c142ab
package
cn
.
ibizlab
.
util
.
service
;
package
cn
.
ibizlab
.
util
.
service
;
import
javax.annotation.Resource
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
com.baomidou.mybatisplus.extension.service.impl.ServiceImpl
;
import
com.baomidou.mybatisplus.extension.service.impl.ServiceImpl
;
import
cn.ibizlab.util.security.AuthenticationUser
;
import
cn.ibizlab.util.security.AuthenticationUser
;
import
org.springframework.cache.annotation.CacheEvict
;
import
cn.ibizlab.util.errors.BadRequestAlertException
;
import
org.springframework.cache.annotation.Cacheable
;
import
cn.ibizlab.util.helper.CachedBeanCopier
;
import
org.springframework.cglib.beans.BeanCopier
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.context.annotation.Primary
;
import
org.springframework.security.core.userdetails.UsernameNotFoundException
;
import
org.springframework.security.core.userdetails.UsernameNotFoundException
;
import
org.springframework.stereotype.Service
;
import
org.springframework.stereotype.Service
;
import
cn.ibizlab.util.mapper.IBZUSERMapper
;
import
cn.ibizlab.util.mapper.IBZUSERMapper
;
import
cn.ibizlab.util.domain.IBZUSER
;
import
cn.ibizlab.util.domain.IBZUSER
;
import
org.springframework.util.DigestUtils
;
import
org.springframework.util.StringUtils
;
import
org.springframework.util.StringUtils
;
/**
/**
* 实体[IBZUSER] 服务对象接口实现
* 实体[IBZUSER] 服务对象接口实现
*/
*/
@Service
@Service
(
"IBZUSERService"
)
public
class
IBZUSERServiceImpl
extends
ServiceImpl
<
IBZUSERMapper
,
IBZUSER
>
implements
IBZUSERService
{
public
class
IBZUSERServiceImpl
extends
ServiceImpl
<
IBZUSERMapper
,
IBZUSER
>
implements
IBZUSERService
,
AuthenticationUserService
{
@Resource
@Value
(
"${ibiz.auth.pwencrymode:0}"
)
private
IBZUSERMapper
ibzuserMapper
;
private
int
pwencrymode
;
public
AuthenticationUser
getByUsername
(
String
username
){
@Override
public
AuthenticationUser
loadUserByUsername
(
String
username
)
{
if
(
StringUtils
.
isEmpty
(
username
))
if
(
StringUtils
.
isEmpty
(
username
))
throw
new
UsernameNotFoundException
(
"用户名为空"
);
throw
new
UsernameNotFoundException
(
"用户名为空"
);
QueryWrapper
<
IBZUSER
>
conds
=
new
QueryWrapper
<
IBZUSER
>();
QueryWrapper
<
IBZUSER
>
conds
=
new
QueryWrapper
<
IBZUSER
>();
String
[]
data
=
username
.
split
(
"[|]"
);
String
[]
data
=
username
.
split
(
"[|]"
);
String
loginname
=
""
;
String
loginname
=
""
;
String
domains
=
""
;
String
domains
=
""
;
if
(
data
.
length
>
0
)
if
(
data
.
length
>
0
)
loginname
=
data
[
0
].
trim
();
loginname
=
data
[
0
].
trim
();
if
(
data
.
length
>
1
)
if
(
data
.
length
>
1
)
domains
=
data
[
1
].
trim
();
domains
=
data
[
1
].
trim
();
if
(!
StringUtils
.
isEmpty
(
loginname
))
if
(!
StringUtils
.
isEmpty
(
loginname
))
conds
.
eq
(
"loginname"
,
loginname
);
conds
.
eq
(
"loginname"
,
loginname
);
if
(!
StringUtils
.
isEmpty
(
domains
))
if
(!
StringUtils
.
isEmpty
(
domains
))
conds
.
eq
(
"domains"
,
domains
);
conds
.
eq
(
"domains"
,
domains
);
IBZUSER
user
=
this
.
getOne
(
conds
);
IBZUSER
user
=
this
.
getOne
(
conds
);
if
(
user
==
null
)
if
(
user
==
null
)
{
{
throw
new
UsernameNotFoundException
(
"用户"
+
username
+
"未找到"
);
throw
new
UsernameNotFoundException
(
"用户"
+
username
+
"未找到"
);
}
}
else
else
{
{
user
.
setUsername
(
username
);
user
.
setUsername
(
username
);
return
createUserDetails
(
user
);
return
createUserDetails
(
user
);
}
}
@Override
public
AuthenticationUser
loadUserByLogin
(
String
username
,
String
password
){
AuthenticationUser
authuserdetail
=
loadUserByUsername
(
username
);
if
(
pwencrymode
==
1
)
password
=
DigestUtils
.
md5DigestAsHex
(
password
.
getBytes
());
else
if
(
pwencrymode
==
2
)
password
=
DigestUtils
.
md5DigestAsHex
(
String
.
format
(
"%1$s||%2$s"
,
username
,
password
).
getBytes
());
if
(!
authuserdetail
.
getPassword
().
equals
(
password
)){
throw
new
BadRequestAlertException
(
"用户名密码错误"
,
"IBZUSER"
,
username
);
}
}
}
return
authuserdetail
;
public
void
resetByUsername
(
String
username
)
}
{
}
@Override
public
AuthenticationUser
loadUserByLogin
(
String
domain
,
String
username
,
String
password
)
{
if
(!
StringUtils
.
isEmpty
(
domain
))
username
=
username
+
"|"
+
domain
;
return
loadUserByLogin
(
username
,
password
);
}
public
AuthenticationUser
createUserDetails
(
IBZUSER
user
)
{
public
void
resetByUsername
(
String
username
)
{
}
public
AuthenticationUser
createUserDetails
(
IBZUSER
user
)
{
AuthenticationUser
userdatail
=
new
AuthenticationUser
();
AuthenticationUser
userdatail
=
new
AuthenticationUser
();
BeanCopier
copier
=
BeanCopier
.
create
(
IBZUSER
.
class
,
AuthenticationUser
.
class
,
false
);
CachedBeanCopier
.
copy
(
user
,
userdatail
);
copier
.
copy
(
user
,
userdatail
,
null
);
return
userdatail
;
return
userdatail
;
}
}
}
}
\ No newline at end of file
\ No newline at end of file
ibzdict-util/src/main/java/cn/ibizlab/util/service/SimpleUserService.java
浏览文件 @
24c142ab
package
cn
.
ibizlab
.
util
.
service
;
package
cn
.
ibizlab
.
util
.
service
;
import
cn.ibizlab.util.security.AuthenticationUser
;
import
cn.ibizlab.util.security.AuthenticationUser
;
import
org.springframework.context.annotation.Primary
;
import
org.springframework.stereotype.Service
;
import
org.springframework.stereotype.Service
;
import
org.springframework.util.DigestUtils
;
import
org.springframework.util.StringUtils
;
/**
/**
* 实体[IBZUSER] 服务对象接口实现
* 实体[IBZUSER] 服务对象接口实现
*/
*/
@Service
@Primary
public
class
SimpleUserService
{
@Service
(
"SimpleUserService"
)
public
class
SimpleUserService
implements
AuthenticationUserService
{
public
AuthenticationUser
getByUsername
(
String
username
)
{
@Override
public
AuthenticationUser
loadUserByUsername
(
String
username
)
{
AuthenticationUser
user
=
new
AuthenticationUser
();
AuthenticationUser
user
=
new
AuthenticationUser
();
String
[]
data
=
username
.
split
(
"[|]"
);
String
loginname
=
username
;
String
domains
=
""
;
String
password
=
""
;
if
(
data
.
length
==
3
)
{
loginname
=
data
[
0
].
trim
();
domains
=
data
[
1
].
trim
();
password
=
data
[
2
].
trim
();
}
else
if
(
data
.
length
==
2
)
{
loginname
=
data
[
0
].
trim
();
password
=
data
[
1
].
trim
();
}
user
.
setUserid
(
DigestUtils
.
md5DigestAsHex
(
username
.
getBytes
()));
user
.
setUsercode
(
loginname
);
user
.
setUsername
(
username
);
user
.
setUsername
(
username
);
user
.
setLoginname
(
loginname
);
user
.
setPersonname
(
loginname
);
user
.
setDomain
(
domains
);
user
.
setPassword
(
password
);
user
.
setOrgid
(
domains
);
user
.
setOrgcode
(
domains
);
user
.
setOrgname
(
domains
);
return
user
;
return
user
;
}
}
@Override
public
AuthenticationUser
loadUserByLogin
(
String
username
,
String
password
)
{
password
=
DigestUtils
.
md5DigestAsHex
(
String
.
format
(
"%1$s||%2$s"
,
username
,
password
).
getBytes
());
AuthenticationUser
authuserdetail
=
loadUserByUsername
(
username
+
"|"
+
password
);
return
authuserdetail
;
}
@Override
public
AuthenticationUser
loadUserByLogin
(
String
domain
,
String
username
,
String
password
)
{
if
(!
StringUtils
.
isEmpty
(
domain
))
username
=
username
+
"|"
+
domain
;
return
loadUserByLogin
(
username
,
password
);
}
@Override
public
void
resetByUsername
(
String
username
)
{
}
}
}
编辑
预览
Markdown
格式
0%
请重试
or
添加新附件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录