Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
P
pica-cloud-account
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
1
合并请求
1
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
收起侧边栏
Close sidebar
动态
分支图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
com.pica.cloud.account
pica-cloud-account
提交
6f58dc27
提交
6f58dc27
编写于
3月 31, 2020
作者:
Peijun.zhao
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'dev-login-20200323' into 'release'
Dev login 20200323 reviewCoder by zhaopeijun See merge request
!15
上级
74b22cbe
e7a47d18
流水线
#23647
已失败 于阶段
in 0 second
变更
13
流水线
1
展开全部
隐藏空白字符变更
内嵌
并排
正在显示
13 个修改的文件
包含
379 行增加
和
49 行删除
+379
-49
pom.xml
server/pom.xml
+14
-1
Constants.java
...ica/cloud/account/account/server/constants/Constants.java
+9
-0
AccountBaseController.java
...ount/account/server/controller/AccountBaseController.java
+3
-0
AccountController.java
.../account/account/server/controller/AccountController.java
+9
-4
AutoCodeController.java
...account/account/server/controller/AutoCodeController.java
+26
-21
LoginController.java
...ud/account/account/server/controller/LoginController.java
+1
-0
AccountExceptionEnum.java
...ud/account/account/server/enums/AccountExceptionEnum.java
+6
-1
RcRepTypeEnum.java
...ica/cloud/account/account/server/enums/RcRepTypeEnum.java
+1
-0
JigsawCodeModel.java
...a/cloud/account/account/server/model/JigsawCodeModel.java
+63
-0
BaseRequest.java
...om/pica/cloud/account/account/server/req/BaseRequest.java
+20
-0
AuthCodeService.java
...cloud/account/account/server/service/AuthCodeService.java
+7
-1
AuthCodeServiceImpl.java
...ount/account/server/service/impl/AuthCodeServiceImpl.java
+172
-6
LoginServiceImpl.java
...account/account/server/service/impl/LoginServiceImpl.java
+48
-15
未找到文件。
server/pom.xml
浏览文件 @
6f58dc27
...
...
@@ -58,6 +58,7 @@
<groupId>
com.pica.cloud.foundation
</groupId>
<artifactId>
pica-cloud-service-starter
</artifactId>
<version>
1.2.6-SNAPSHOT
</version>
<!--<version>1.3.2.5</version>-->
<exclusions>
<exclusion>
<artifactId>
pica-cloud-redis
</artifactId>
...
...
@@ -167,7 +168,7 @@
<dependency>
<groupId>
com.pica.cloud.riskcontrol
</groupId>
<artifactId>
pica-cloud-riskcontrol-client
</artifactId>
<version>
1.0.
2
</version>
<version>
1.0.
3.1
</version>
</dependency>
<!-- apple identifyToken校验 -->
...
...
@@ -188,6 +189,18 @@
<scope>
test
</scope>
</dependency>
<dependency>
<groupId>
com.pica.cloud.foundation
</groupId>
<artifactId>
pica-cloud-proof-client
</artifactId>
<version>
1.0.0
</version>
<exclusions>
<exclusion>
<groupId>
io.swagger
</groupId>
<artifactId>
swagger-annotations
</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
...
...
server/src/main/java/com/pica/cloud/account/account/server/constants/Constants.java
浏览文件 @
6f58dc27
...
...
@@ -66,4 +66,13 @@ public class Constants {
/** 注册逻辑幂等处理缓存key */
public
static
final
String
REPEAT_REGISTER_PREFIX
=
"repeat-register—"
;
/** h5拼图缓存key */
public
static
final
String
JIGSAW_CODE_KEY
=
"jigsaw-code-{mobile}"
;
/** h5拼图缓存时长*/
public
static
final
int
JIGSAW_CODE_EXPIRE_SECONDS
=
60
;
/** 风控记录过数据 */
public
static
final
String
RC_RECORDED_DATA_KEY
=
"risk-{mobile}-{ip}"
;
}
server/src/main/java/com/pica/cloud/account/account/server/controller/AccountBaseController.java
浏览文件 @
6f58dc27
...
...
@@ -131,7 +131,10 @@ public abstract class AccountBaseController extends BaseController {
String
postData
=
JSON
.
toJSONString
(
picapSendMsgModel
);
logger
.
info
(
"sendMobileTo-mobile:{}, senderId-{}"
,
mobile
,
senderId
);
long
start
=
System
.
currentTimeMillis
();
String
jsonObj
=
HttpClientUtil
.
httpExecute
(
messageUrl
,
postData
);
long
end1
=
System
.
currentTimeMillis
();
logger
.
info
(
"sendMobileMessage-send message used {} million seconds"
,
end1
-
start
);
logger
.
info
(
"sendMobileTo-{}"
,
jsonObj
);
if
(
StringUtils
.
isEmpty
(
jsonObj
))
{
...
...
server/src/main/java/com/pica/cloud/account/account/server/controller/AccountController.java
浏览文件 @
6f58dc27
...
...
@@ -189,20 +189,23 @@ public class AccountController extends AccountBaseController {
@ApiOperation
(
"H5端一键登录功能,无需完善信息"
)
@PostMapping
(
"/login-register/v1"
)
// @RepeatForbidden(uniqueKey = "content") 当前版本存在性能问题 luo优化后上
public
PicaResponse
loginRegister
(
@RequestBody
EncryptEntity
entity
)
throws
Exception
{
BaseRequest
request
=
CryptoUtil
.
decrypt
(
entity
,
BaseRequest
.
class
);
this
.
checkMobilePhone
(
request
.
getMobile
());
AccountReq
req
=
new
AccountReq
();
req
.
setMobilePhone
(
request
.
getMobile
());
req
.
setPassword
(
null
);
//登录或注册,只能使用验证码
// 登录或注册,只能使用验证码
req
.
setPassword
(
null
);
req
.
setAuthCode
(
request
.
getAuthCode
());
req
.
setFlag
(
"0"
);
req
.
setUnionid
(
request
.
getUnionId
());
//判断账号是否已经存在
//
判断账号是否已经存在
Account
account
=
accountService
.
getByMobilePhone
(
req
.
getMobilePhone
());
if
(
account
!=
null
)
{
PicaResponse
response
=
this
.
login
(
req
);
//登录
// 登录
PicaResponse
response
=
this
.
login
(
req
);
if
(
response
.
getData
()
!=
null
)
{
LoginResult
result
=
new
LoginResult
();
result
.
setToken
(
response
.
getData
().
toString
());
...
...
@@ -210,7 +213,9 @@ public class AccountController extends AccountBaseController {
}
return
response
;
}
else
{
return
this
.
register
(
req
);
//注册
// 注册
PicaResponse
<
LoginResult
>
result
=
this
.
register
(
req
);
return
result
;
}
}
...
...
server/src/main/java/com/pica/cloud/account/account/server/controller/AutoCodeController.java
浏览文件 @
6f58dc27
...
...
@@ -107,12 +107,13 @@ public class AutoCodeController extends AccountBaseController {
// 验证码类型 0默认 1注册 2微信登录绑定手机 3修改手机
// 4重置密码 5忘记密码 7患者招募提交问卷(效验) 8Appe登录绑定手机
BaseRequest
request
=
CryptoUtil
.
decrypt
(
entity
,
BaseRequest
.
class
);
request
.
setSourceType
(
super
.
getSourceType
());
AccountUtils
.
checkMobilePhone
(
request
.
getMobile
());
if
(
request
.
getBizType
()
!=
null
&&
request
.
getBizType
().
equals
(
1
))
{
logger
.
info
(
"app-rcValidate-start"
);
// 调用风控接口
authCodeService
.
rcValidate
(
req
,
request
,
super
.
getDeviceInfo
());
authCodeService
.
rcValidate
(
req
,
request
,
super
.
getDeviceInfo
()
,
super
.
getSourceType
()
);
// 发送短信验证码
processSysCode
(
request
.
getMobile
(),
request
.
getFlag
());
return
PicaResponse
.
toResponse
();
...
...
@@ -128,32 +129,24 @@ public class AutoCodeController extends AccountBaseController {
@ApiOperation
(
"获取短信验证码,无需图形验证码,如h5端"
)
@PostMapping
(
value
=
"/H5/authCode"
)
public
PicaResponse
getH5AuthCode
(
@RequestBody
EncryptEntity
entity
,
HttpServletRequest
req
)
throws
Exception
{
// 如果该接口已关闭(缓存key存在),则直接返回
if
(
cacheClient
.
exists
(
Constants
.
AUTHCODE_H5_SWITCH_KEY
))
{
logger
.
info
(
"getH5AuthCode-interface-return"
);
throw
new
PicaWarnException
(
AccountExceptionEnum
.
PICA_H5_AUTH_CODE_INTERFACE_OFFED
.
getCode
(),
AccountExceptionEnum
.
PICA_H5_AUTH_CODE_INTERFACE_OFFED
.
getMessage
());
}
// 验证码类型 0默认 1注册 2微信登录绑定手机 3修改手机
// 4重置密码 5忘记密码 7患者招募提交问卷(效验) 8Appe登录绑定手机
BaseRequest
request
=
CryptoUtil
.
decrypt
(
entity
,
BaseRequest
.
class
);
request
.
setSourceType
(
super
.
getSourceType
());
AccountUtils
.
checkMobilePhone
(
request
.
getMobile
());
if
(
request
.
getBizType
()
!=
null
&&
request
.
getBizType
().
equals
(
1
))
{
logger
.
info
(
"h5-rcValidate-start"
);
// 调用风控接口
authCodeService
.
rcValidate
(
req
,
request
,
super
.
getDeviceInfo
());
// 发送短信验证码
processSysCode
(
request
.
getMobile
(),
request
.
getFlag
());
return
PicaResponse
.
toResponse
();
}
else
{
// h5(发送短信验证码)
processSysCode
(
request
.
getMobile
(),
request
.
getFlag
());
// 记录风控数据
// 拼图验证
int
recordData
=
authCodeService
.
validateJigsawCode
(
req
,
request
);
// 发送短信验证码
processSysCode
(
request
.
getMobile
(),
request
.
getFlag
());
if
(
recordData
!=
-
1
)
{
// 记录风控数据(记录是h5端)
authCodeService
.
recordRcData
(
req
,
request
,
super
.
getDeviceInfo
(
"device_ip"
));
return
PicaResponse
.
toResponse
();
}
return
PicaResponse
.
toResponse
();
}
/**
...
...
@@ -169,6 +162,7 @@ public class AutoCodeController extends AccountBaseController {
public
PicaResponse
<
String
>
getAuthCodeWithCaptcha
(
@RequestBody
EncryptEntity
entity
,
HttpServletRequest
req
)
throws
Exception
{
BaseRequest
request
=
CryptoUtil
.
decrypt
(
entity
,
BaseRequest
.
class
);
request
.
setSourceType
(
super
.
getSourceType
());
String
mobilePhone
=
request
.
getMobile
();
String
flag
=
request
.
getFlag
()
+
""
;
String
captchaToken
=
request
.
getCaptchaToken
();
...
...
@@ -197,7 +191,13 @@ public class AutoCodeController extends AccountBaseController {
return
PicaResponse
.
toResponse
(
StringUtils
.
EMPTY
);
}
@ApiOperation
(
"获取拼图码校验"
)
@PostMapping
(
"/jigsawCode"
)
public
PicaResponse
getJigsawCode
(
@RequestBody
EncryptEntity
entity
,
HttpServletRequest
req
)
throws
Exception
{
BaseRequest
request
=
CryptoUtil
.
decrypt
(
entity
,
BaseRequest
.
class
);
return
PicaResponse
.
toResponse
(
authCodeService
.
getJigsawCode
(
req
,
super
.
getSourceType
(),
request
.
getMobile
()));
}
@ApiOperation
(
"微信获取验证码"
)
@PostMapping
(
value
=
"/authCode/wechat"
)
...
...
@@ -253,6 +253,7 @@ public class AutoCodeController extends AccountBaseController {
* @param authCodeKeySecure
*/
private
void
processSendAuthCode
(
String
mobilePhone
,
Integer
flag
,
String
authCodeKeySecure
)
{
long
start
=
System
.
currentTimeMillis
();
String
authCode
=
CommonUtil
.
createValidateCode
();
String
message
=
"您的验证码是"
+
authCode
+
",在10分钟内有效。如非本人操作,请忽略本短信!"
;
Integer
accountIdByMobilePhone
=
accountService
.
getAccountIdByMobilePhone
(
mobilePhone
);
...
...
@@ -265,7 +266,11 @@ public class AutoCodeController extends AccountBaseController {
cacheClient
.
set
(
authCodeKeySecure
,
System
.
currentTimeMillis
(),
60
);
//处理验证码原子性的问题
cacheClient
.
set
(
RegisterCodeKeyUtils
.
getRegisterKey
(
mobilePhone
,
authCode
),
100
,
600
);
long
end1
=
System
.
currentTimeMillis
();
logger
.
info
(
"processSendAuthCode-1 used {} million seconds"
,
end1
-
start
);
super
.
sendMobileMessage
(
mobilePhone
,
message
,
senderId
);
long
end2
=
System
.
currentTimeMillis
();
logger
.
info
(
"processSendAuthCode-2 used {} million seconds"
,
end2
-
start
);
}
//获取验证码redis key
...
...
server/src/main/java/com/pica/cloud/account/account/server/controller/LoginController.java
浏览文件 @
6f58dc27
...
...
@@ -217,6 +217,7 @@ public class LoginController extends AccountBaseController {
@PostMapping
(
"/unifiedVerification"
)
public
PicaResponse
unifiedVerification
(
@RequestBody
EncryptEntity
entity
)
throws
Exception
{
BaseRequest
request
=
CryptoUtil
.
decrypt
(
entity
,
BaseRequest
.
class
);
request
.
setSourceType
(
super
.
getSourceType
());
loginService
.
preLoginValidate
(
request
);
return
PicaResponse
.
toResponse
();
}
...
...
server/src/main/java/com/pica/cloud/account/account/server/enums/AccountExceptionEnum.java
浏览文件 @
6f58dc27
...
...
@@ -47,9 +47,14 @@ public enum AccountExceptionEnum {
PICA_RC_BLACKLIST
(
"216538"
,
"发送成功"
),
PICA_RC_DAY_LIMIT
(
"216539"
,
"今日获取验证码次数已超过上限,请使用账户密码登录"
),
PICA_RC_60_SECOND_LIMIT
(
"216540"
,
"验证码发送频率过高,请{remainTime}秒后再试"
),
PICA_H5_AUTH_CODE_INTERFACE_OFFED
(
"216541"
,
"该功能已关闭"
),
PICA_MESSAGE_SERVICE_CALL_FAIL
(
"216542"
,
"短信发送失败"
),
PICA_BIND_WECHAT_FAIL
(
"216543"
,
"绑定微信失败"
),
PICA_CAP_CODE_ERROR
(
"216544"
,
"拼图验证失败"
),
PICA_CAP_GET_INVOKE_ERROR
(
"216545"
,
"拼图获取失败"
),
PICA_RC_BUSINESS_ERROR
(
"216546"
,
"参数格式错误"
),
PICA_MOBILE_NOT_REGIST_H5
(
"216547"
,
"该手机号尚未设置密码,设置密码请前往云鹊医APP,或使用其他方式登录。"
),
PICA_MOBILE_NOT_SETED_PASSWORD_H5
(
"216548"
,
"该手机号尚未设置密码,设置密码请前往云鹊医APP,或使用其他方式登录。"
),
PICA_PWD_MISMATCH_5_H5
(
"216549"
,
"该账号密码错误次数已达上限请24小时后再试,或请使用其他登录方式"
),
xxx_xxx
(
""
,
""
);
...
...
server/src/main/java/com/pica/cloud/account/account/server/enums/RcRepTypeEnum.java
浏览文件 @
6f58dc27
...
...
@@ -11,6 +11,7 @@ package com.pica.cloud.account.account.server.enums;
public
enum
RcRepTypeEnum
{
// 风控禁止发送
RC_ALLOW_SEND_MSG
(
"1"
,
"允许发送"
),
RC_SEND_FAIL
(
"2"
,
"发送失败"
),
RC_TRIGGER
(
"3"
,
"需要触发风控滑动验证"
),
// 账号、IP、设备在黑名单内,前端提示发送成功,后端不发送短信
...
...
server/src/main/java/com/pica/cloud/account/account/server/model/JigsawCodeModel.java
0 → 100644
浏览文件 @
6f58dc27
// Copyright 2016-2101 Pica.
package
com
.
pica
.
cloud
.
account
.
account
.
server
.
model
;
import
io.swagger.annotations.ApiModel
;
import
io.swagger.annotations.ApiModelProperty
;
/**
* @ClassName AuthCodeReq
* @Description h5拼图对象
* @Author Chongwen.jiang
* @Date 2020/3/23 13:29
* @ModifyDate 2020/3/23 13:29
* @Version 1.0
*/
@ApiModel
(
value
=
"JigsawCodeModel"
,
description
=
"h5拼图对象"
)
public
class
JigsawCodeModel
{
@ApiModelProperty
(
value
=
"背景图"
)
private
String
backImage
;
@ApiModelProperty
(
value
=
"滑动图"
)
private
String
slidingImage
;
@ApiModelProperty
(
value
=
"y坐标"
)
private
Integer
yHeight
;
@ApiModelProperty
(
value
=
"时间戳"
)
private
String
capCode
;
public
String
getBackImage
()
{
return
backImage
;
}
public
void
setBackImage
(
String
backImage
)
{
this
.
backImage
=
backImage
;
}
public
String
getSlidingImage
()
{
return
slidingImage
;
}
public
void
setSlidingImage
(
String
slidingImage
)
{
this
.
slidingImage
=
slidingImage
;
}
public
Integer
getyHeight
()
{
return
yHeight
;
}
public
void
setyHeight
(
Integer
yHeight
)
{
this
.
yHeight
=
yHeight
;
}
public
String
getCapCode
()
{
return
capCode
;
}
public
void
setCapCode
(
String
capCode
)
{
this
.
capCode
=
capCode
;
}
}
server/src/main/java/com/pica/cloud/account/account/server/req/BaseRequest.java
浏览文件 @
6f58dc27
...
...
@@ -46,6 +46,10 @@ public class BaseRequest {
private
String
appleId
;
@ApiModelProperty
(
"apple用户信息(json字符串)"
)
private
String
info
;
@ApiModelProperty
(
"capCode"
)
private
String
capCode
;
@ApiModelProperty
(
"滑动图片的x位置"
)
private
int
xPos
;
public
String
getCaptchaToken
()
{
return
captchaToken
;
...
...
@@ -206,4 +210,20 @@ public class BaseRequest {
public
void
setDevice_token
(
String
device_token
)
{
this
.
device_token
=
device_token
;
}
public
String
getCapCode
()
{
return
capCode
;
}
public
void
setCapCode
(
String
capCode
)
{
this
.
capCode
=
capCode
;
}
public
int
getxPos
()
{
return
xPos
;
}
public
void
setxPos
(
int
xPos
)
{
this
.
xPos
=
xPos
;
}
}
server/src/main/java/com/pica/cloud/account/account/server/service/AuthCodeService.java
浏览文件 @
6f58dc27
// Copyright 2016-2101 Pica.
package
com
.
pica
.
cloud
.
account
.
account
.
server
.
service
;
import
com.pica.cloud.account.account.server.model.JigsawCodeModel
;
import
com.pica.cloud.account.account.server.req.BaseRequest
;
import
javax.servlet.http.HttpServletRequest
;
...
...
@@ -15,8 +16,13 @@ import javax.servlet.http.HttpServletRequest;
*/
public
interface
AuthCodeService
{
void
rcValidate
(
HttpServletRequest
request
,
BaseRequest
baseRequest
,
String
deviceInfoStr
);
int
rcValidate
(
HttpServletRequest
request
,
BaseRequest
baseRequest
,
String
deviceInfoStr
,
Integer
sourceType
);
void
recordRcData
(
HttpServletRequest
req
,
BaseRequest
baseRequest
,
String
deviceIp
);
int
validateJigsawCode
(
HttpServletRequest
request
,
BaseRequest
req
);
JigsawCodeModel
getJigsawCode
(
HttpServletRequest
request
,
Integer
sourceType
,
String
mobile
);
}
server/src/main/java/com/pica/cloud/account/account/server/service/impl/AuthCodeServiceImpl.java
浏览文件 @
6f58dc27
此差异已折叠。
点击以展开。
server/src/main/java/com/pica/cloud/account/account/server/service/impl/LoginServiceImpl.java
浏览文件 @
6f58dc27
...
...
@@ -9,6 +9,7 @@ import com.pica.cloud.account.account.server.constants.Constants;
import
com.pica.cloud.account.account.server.entity.*
;
import
com.pica.cloud.account.account.server.enums.AccountExceptionEnum
;
import
com.pica.cloud.account.account.server.enums.AccountTypeEnum
;
import
com.pica.cloud.account.account.server.enums.SourceTypeEnum
;
import
com.pica.cloud.account.account.server.log.AccountLogEntityUtils
;
import
com.pica.cloud.account.account.server.log.AccountLogUtils
;
import
com.pica.cloud.account.account.server.mapper.*
;
...
...
@@ -122,6 +123,7 @@ public class LoginServiceImpl implements LoginService {
@Override
public
LoginResult
login
(
BaseRequest
request
)
{
String
mobile
=
request
.
getMobile
();
Integer
sourceType
=
request
.
getSourceType
();
String
encrypt
=
AESUtil
.
encryptV0
(
mobile
);
AccountInfoEntity
accountInfoEntity
=
accountInfoDetailMapper
.
selectByMobile
(
encrypt
);
logger
.
info
(
"bizType:{}, account not null:{}"
,
request
.
getBizType
(),
accountInfoEntity
!=
null
);
...
...
@@ -132,16 +134,26 @@ public class LoginServiceImpl implements LoginService {
request
.
getBizType
().
equals
(
1
))
{
// 新版-未设置密码
if
(
StringUtils
.
isEmpty
(
oldPwd
))
{
throw
new
PicaException
(
AccountExceptionEnum
.
PICA_PASSWORD_RULE_ERROR
.
getCode
(),
AccountExceptionEnum
.
PICA_PASSWORD_RULE_ERROR
.
getMessage
()
.
replace
(
"{mobile}"
,
mobile
));
if
(
sourceType
!=
null
&&
SourceTypeEnum
.
H5
.
getCode
().
equals
(
sourceType
))
{
throw
new
PicaWarnException
(
AccountExceptionEnum
.
PICA_MOBILE_NOT_SETED_PASSWORD_H5
.
getCode
(),
AccountExceptionEnum
.
PICA_MOBILE_NOT_SETED_PASSWORD_H5
.
getMessage
());
}
else
{
throw
new
PicaException
(
AccountExceptionEnum
.
PICA_PASSWORD_RULE_ERROR
.
getCode
(),
AccountExceptionEnum
.
PICA_PASSWORD_RULE_ERROR
.
getMessage
()
.
replace
(
"{mobile}"
,
mobile
));
}
}
else
{
// 判断账号是否已锁
logger
.
info
(
"new login failure:"
+
mobile
);
String
lockKey
=
Constants
.
ACCOUNT_LOCK_KEY
.
replace
(
"{mobile}"
,
mobile
);
if
(
redisClient
.
exists
(
lockKey
))
{
throw
new
PicaException
(
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5
.
getCode
(),
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5
.
getMessage
().
replace
(
"{mobile}"
,
mobile
));
if
(
sourceType
!=
null
&&
SourceTypeEnum
.
H5
.
getCode
().
equals
(
sourceType
))
{
throw
new
PicaException
(
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5_H5
.
getCode
(),
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5_H5
.
getMessage
());
}
else
{
throw
new
PicaException
(
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5
.
getCode
(),
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5
.
getMessage
().
replace
(
"{mobile}"
,
mobile
));
}
}
if
(
password
.
equals
(
oldPwd
))
{
...
...
@@ -158,8 +170,13 @@ public class LoginServiceImpl implements LoginService {
}
else
{
// 设置账号锁定24h
redisClient
.
set
(
lockKey
,
mobile
,
Constants
.
PWD_ERROR_NUM_SECONDS
);
throw
new
PicaException
(
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5
.
getCode
(),
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5
.
getMessage
().
replace
(
"{mobile}"
,
mobile
));
if
(
sourceType
!=
null
&&
SourceTypeEnum
.
H5
.
getCode
().
equals
(
sourceType
))
{
throw
new
PicaException
(
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5_H5
.
getCode
(),
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5_H5
.
getMessage
());
}
else
{
throw
new
PicaException
(
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5
.
getCode
(),
AccountExceptionEnum
.
PICA_PWD_MISMATCH_5
.
getMessage
().
replace
(
"{mobile}"
,
mobile
));
}
}
}
else
{
redisClient
.
set
(
errorKey
,
1
,
Constants
.
PWD_ERROR_NUM_SECONDS
);
...
...
@@ -181,10 +198,15 @@ public class LoginServiceImpl implements LoginService {
}
else
{
if
(
null
!=
request
.
getBizType
()
&&
request
.
getBizType
().
equals
(
1
))
{
// 新版-未注册
throw
new
PicaException
(
AccountExceptionEnum
.
PICA_PASSWORD_RULE_ERROR
.
getCode
(),
AccountExceptionEnum
.
PICA_PASSWORD_RULE_ERROR
.
getMessage
()
.
replace
(
"{mobile}"
,
mobile
));
if
(
sourceType
!=
null
&&
SourceTypeEnum
.
H5
.
getCode
().
equals
(
sourceType
))
{
throw
new
PicaWarnException
(
AccountExceptionEnum
.
PICA_MOBILE_NOT_REGIST_H5
.
getCode
(),
AccountExceptionEnum
.
PICA_MOBILE_NOT_REGIST_H5
.
getMessage
());
}
else
{
// 新版-未注册
throw
new
PicaException
(
AccountExceptionEnum
.
PICA_PASSWORD_RULE_ERROR
.
getCode
(),
AccountExceptionEnum
.
PICA_PASSWORD_RULE_ERROR
.
getMessage
()
.
replace
(
"{mobile}"
,
mobile
));
}
}
else
{
throw
new
PicaException
(
AccountExceptionEnum
.
PICA_NOT_REGISTER
.
getCode
(),
AccountExceptionEnum
.
PICA_NOT_REGISTER
.
getMessage
());
}
...
...
@@ -568,6 +590,7 @@ public class LoginServiceImpl implements LoginService {
public
void
preLoginValidate
(
BaseRequest
request
)
{
Integer
bizType
=
request
.
getBizType
();
String
mobile
=
request
.
getMobile
();
Integer
sourceType
=
request
.
getSourceType
();
if
(
null
==
bizType
)
{
logger
.
info
(
"bizType is null"
);
...
...
@@ -592,13 +615,23 @@ public class LoginServiceImpl implements LoginService {
// 手机号是否注册
AccountInfoEntity
accountInfo
=
accountInfoDetailMapper
.
selectByMobile
(
AESUtil
.
encryptV0
(
mobile
));
if
(
accountInfo
==
null
)
{
throw
new
PicaWarnException
(
AccountExceptionEnum
.
PICA_MOBILE_NOT_REGIST
.
getCode
(),
AccountExceptionEnum
.
PICA_MOBILE_NOT_REGIST
.
getMessage
().
replace
(
"{mobile}"
,
mobile
));
if
(
sourceType
!=
null
&&
SourceTypeEnum
.
H5
.
getCode
().
equals
(
sourceType
))
{
throw
new
PicaWarnException
(
AccountExceptionEnum
.
PICA_MOBILE_NOT_REGIST_H5
.
getCode
(),
AccountExceptionEnum
.
PICA_MOBILE_NOT_REGIST_H5
.
getMessage
());
}
else
{
throw
new
PicaWarnException
(
AccountExceptionEnum
.
PICA_MOBILE_NOT_REGIST
.
getCode
(),
AccountExceptionEnum
.
PICA_MOBILE_NOT_REGIST
.
getMessage
().
replace
(
"{mobile}"
,
mobile
));
}
}
// 手机号是否设置了密码
if
(
StringUtils
.
isEmpty
(
accountInfo
.
getPassword
()))
{
throw
new
PicaWarnException
(
AccountExceptionEnum
.
PICA_MOBILE_NOT_SETED_PASSWORD
.
getCode
(),
AccountExceptionEnum
.
PICA_MOBILE_NOT_SETED_PASSWORD
.
getMessage
().
replace
(
"{mobile}"
,
mobile
));
if
(
sourceType
!=
null
&&
SourceTypeEnum
.
H5
.
getCode
().
equals
(
sourceType
))
{
throw
new
PicaWarnException
(
AccountExceptionEnum
.
PICA_MOBILE_NOT_SETED_PASSWORD_H5
.
getCode
(),
AccountExceptionEnum
.
PICA_MOBILE_NOT_SETED_PASSWORD_H5
.
getMessage
());
}
else
{
throw
new
PicaWarnException
(
AccountExceptionEnum
.
PICA_MOBILE_NOT_SETED_PASSWORD
.
getCode
(),
AccountExceptionEnum
.
PICA_MOBILE_NOT_SETED_PASSWORD
.
getMessage
().
replace
(
"{mobile}"
,
mobile
));
}
}
}
...
...
写
预览
Markdown
格式
0%
请重试
or
附加一个文件
附加文件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录