Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
J
jiwei-api
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
马天浩
jiwei-api
Commits
e5722c66
Commit
e5722c66
authored
Aug 13, 2020
by
matianhao
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[纪委接口] <update> 请求秘钥存入redis;接口返回签名错误时重新获取秘钥
parent
4dea01bd
Changes
6
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
929 additions
and
6 deletions
+929
-6
pom.xml
pom.xml
+7
-0
Constants.java
src/main/java/com/mth/requestsecret/constant/Constants.java
+31
-0
RequestController.java
...a/com/mth/requestsecret/controller/RequestController.java
+1
-1
RequestSecretSchedulerTask.java
...h/requestsecret/scheduler/RequestSecretSchedulerTask.java
+8
-1
RestTemlateService.java
...ava/com/mth/requestsecret/service/RestTemlateService.java
+27
-4
RedisUtils.java
src/main/java/com/mth/requestsecret/util/RedisUtils.java
+855
-0
No files found.
pom.xml
View file @
e5722c66
...
...
@@ -45,6 +45,13 @@
<artifactId>
lombok
</artifactId>
<version>
1.18.12
</version>
</dependency>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-data-redis
</artifactId>
<version>
2.3.0.RELEASE
</version>
</dependency>
<dependency>
<groupId>
com.alibaba.cloud
</groupId>
<artifactId>
spring-cloud-starter-alibaba-nacos-discovery
</artifactId>
...
...
src/main/java/com/mth/requestsecret/constant/Constants.java
0 → 100644
View file @
e5722c66
package
com
.
mth
.
requestsecret
.
constant
;
/**
* @author MaTianHao
* @date 2020/8/13
*/
public
class
Constants
{
// redis存储请求秘钥key值
//-----------------------------------
/**
* 数据局接口
*/
public
static
final
String
SJJ_REQUEST_SECRET_PREFIX
=
"sjj.request.secret"
;
/**
* 招必得接口
*/
public
static
final
String
ZBD_REQUEST_SECRET_PREFIX
=
"zbd.request.secret"
;
// 数据局接口返回响应码
//-----------------------------------
/**
* 成功:00
*/
public
static
final
String
RESPONSE_CODE_00
=
"00"
;
/**
* sign参数错误:14
*/
public
static
final
String
RESPONSE_CODE_14
=
"14"
;
}
src/main/java/com/mth/requestsecret/controller/RequestController.java
View file @
e5722c66
...
...
@@ -16,7 +16,7 @@ import org.springframework.web.bind.annotation.RestController;
* @date 2020/7/13
*/
@RestController
public
class
RequestController
extends
BaseController
{
public
class
RequestController
{
@Autowired
RestTemlateService
restTemlateService
;
...
...
src/main/java/com/mth/requestsecret/scheduler/RequestSecretSchedulerTask.java
View file @
e5722c66
package
com
.
mth
.
requestsecret
.
scheduler
;
import
com.alibaba.fastjson.JSONObject
;
import
com.mth.requestsecret.constant.Constants
;
import
com.mth.requestsecret.util.DSLUtils
;
import
com.mth.requestsecret.util.MD5Utils
;
import
com.mth.requestsecret.util.RedisUtils
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.context.annotation.Configuration
;
...
...
@@ -33,6 +35,9 @@ public class RequestSecretSchedulerTask implements SchedulingConfigurer {
@Autowired
private
RestTemplate
restTemplate
;
@Autowired
RedisUtils
redisUtil
;
@Value
(
"${DATA_API_ADDRESS}"
)
private
String
pathUrl
;
...
...
@@ -75,7 +80,7 @@ public class RequestSecretSchedulerTask implements SchedulingConfigurer {
/**
* 获取请求秘钥
*/
p
rivate
void
getRequestSecret
()
{
p
ublic
void
getRequestSecret
()
{
String
url
=
pathUrl
+
"/interface/public/service/risen-inte/reTokenByKey.action"
+
"?appKey={appKey}&sign={sign}&requestTime={requestTime}"
;
...
...
@@ -100,6 +105,8 @@ public class RequestSecretSchedulerTask implements SchedulingConfigurer {
requestSecretEndTime
=
Long
.
parseLong
(
datas
.
getString
(
"requestSecretEndTime"
));
refreshSecret
=
datas
.
getString
(
"refreshSecret"
);
refreshSecretEndTime
=
Long
.
parseLong
(
datas
.
getString
(
"refreshSecretEndTime"
));
// 保存请求秘钥至redis
redisUtil
.
set
(
Constants
.
SJJ_REQUEST_SECRET_PREFIX
,
requestSecret
);
}
}
...
...
src/main/java/com/mth/requestsecret/service/RestTemlateService.java
View file @
e5722c66
package
com
.
mth
.
requestsecret
.
service
;
import
com.alibaba.fastjson.JSONObject
;
import
com.mth.requestsecret.scheduler.RequestSecretSchedulerTask
;
import
com.mth.requestsecret.util.DSLUtils
;
import
com.mth.requestsecret.util.MD5Utils
;
import
com.mth.requestsecret.util.RedisUtils
;
import
lombok.extern.slf4j.Slf4j
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Value
;
...
...
@@ -13,6 +15,9 @@ import org.springframework.web.client.RestTemplate;
import
java.util.Date
;
import
static
com
.
mth
.
requestsecret
.
constant
.
Constants
.
RESPONSE_CODE_14
;
import
static
com
.
mth
.
requestsecret
.
constant
.
Constants
.
SJJ_REQUEST_SECRET_PREFIX
;
/**
* @author fyl
* @version v1.0
...
...
@@ -27,6 +32,12 @@ public class RestTemlateService {
@Autowired
private
RestTemplate
restTemplate
;
@Autowired
private
RedisUtils
redisUtil
;
@Autowired
private
RequestSecretSchedulerTask
schedulerTask
;
@Value
(
"${DATA_API_ADDRESS}"
)
private
String
pathUrl
;
...
...
@@ -42,12 +53,15 @@ public class RestTemlateService {
// 请求时间
String
requestTime
=
DSLUtils
.
dateToLong
(
new
Date
())
+
""
;
// redis中获取秘钥
String
requestSecret
=
redisUtil
.
get
(
SJJ_REQUEST_SECRET_PREFIX
);
log
.
info
(
"redis中请求秘钥:{}"
,
requestSecret
);
// 签名字符串
String
signStr
=
appKey
+
RequestSecretSchedulerTask
.
requestSecret
+
requestTime
;
String
signStr
=
appKey
+
requestSecret
+
requestTime
;
// 组装请求参数
paramMap
.
add
(
"appKey"
,
appKey
);
paramMap
.
add
(
"sign"
,
MD5Utils
.
encoderByMd5
(
signStr
));
paramMap
.
add
(
"requestTime"
,
requestTime
);
paramMap
.
set
(
"appKey"
,
appKey
);
paramMap
.
set
(
"sign"
,
MD5Utils
.
encoderByMd5
(
signStr
));
paramMap
.
set
(
"requestTime"
,
requestTime
);
// 日志记录
log
.
info
(
"纪委api:{}"
,
apiMethod
);
...
...
@@ -60,6 +74,15 @@ public class RestTemlateService {
HttpEntity
<
MultiValueMap
<
String
,
Object
>>
request
=
new
HttpEntity
<>(
paramMap
,
headers
);
ResponseEntity
<
String
>
responseEntity
=
restTemplate
.
exchange
(
url
.
toString
(),
HttpMethod
.
POST
,
request
,
String
.
class
);
log
.
info
(
"api response:{}"
,
responseEntity
);
// 接口返回码
String
code
=
JSONObject
.
parseObject
(
responseEntity
.
getBody
()).
getString
(
"code"
);
// 如果返回签名错误,则重新获取秘钥,重新发送请求
if
(
RESPONSE_CODE_14
.
equals
(
code
))
{
schedulerTask
.
getRequestSecret
();
return
commonSendRequest
(
paramMap
,
apiMethod
);
}
return
responseEntity
;
}
}
\ No newline at end of file
src/main/java/com/mth/requestsecret/util/RedisUtils.java
0 → 100644
View file @
e5722c66
This diff is collapsed.
Click to expand it.
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