Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
H
hls-support-rlwx
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
rl
hls-support-rlwx
Commits
81d8cd97
Commit
81d8cd97
authored
Aug 11, 2021
by
5359
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
中登网开发
parent
ab3d984d
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
161 additions
and
48 deletions
+161
-48
ZdwWsRequestsServiceImpl.java
.../zhongDengWang/service/impl/ZdwWsRequestsServiceImpl.java
+161
-48
No files found.
core/src/main/java/com/hand/app/zhongDengWang/service/impl/ZdwWsRequestsServiceImpl.java
View file @
81d8cd97
...
...
@@ -20,6 +20,7 @@ import com.hand.app.zhongDengWang.ws.login.WSLoginServiceService;
import
com.hand.app.zhongDengWang.dto.FndAtmAttachmentDto
;
import
com.hand.app.zhongDengWang.mapper.FndAtmAttachmentMapper
;
import
com.hand.hap.core.IRequest
;
import
com.hand.hap.lock.components.DatabaseLockProvider
;
import
com.hand.hap.system.dto.DTOStatus
;
import
com.rfp.sm.utils.SM2Utils
;
import
org.json.XML
;
...
...
@@ -28,10 +29,13 @@ import org.springframework.beans.factory.annotation.Value;
import
org.springframework.stereotype.Service
;
import
java.io.IOException
;
import
java.lang.reflect.InvocationTargetException
;
import
java.util.ArrayList
;
import
java.util.Date
;
import
java.util.List
;
import
java.util.Objects
;
import
java.util.concurrent.ExecutorService
;
import
java.util.concurrent.Executors
;
@Service
public
class
ZdwWsRequestsServiceImpl
implements
IZdwWsRequestsService
{
...
...
@@ -50,6 +54,13 @@ public class ZdwWsRequestsServiceImpl implements IZdwWsRequestsService {
FndAtmAttachmentMapper
fndAtmAttachmentMapper
;
@Autowired
FndZhongDengBatchMapper
fndZhongDengBatchMapper
;
@Autowired
private
DatabaseLockProvider
databaseLockProvider
;
/**
* Use private final lock objects to synchronize classes that may interact with untrusted code
*/
private
final
Object
lock
=
new
Object
();
@Value
(
"${zdw.login.clientKey}"
)
...
...
@@ -177,45 +188,14 @@ public class ZdwWsRequestsServiceImpl implements IZdwWsRequestsService {
/***
* 融资租赁-登记入口方法;
* @param
request
* @param
batchId
* @param
* @param
***/
public
JSONObject
initRegisterService
(
IRequest
request
,
Long
batchId
)
{
public
void
registerThread
(
IRequest
request
,
List
<
FndZhongDengBatch
>
fndZhongDengBatches
,
String
loginToken
)
{
JSONObject
resultJson
=
new
JSONObject
();
/*根据批次ID获取所有上报请求id*/
List
<
FndZhongDengBatch
>
fndZhongDengBatches
=
new
ArrayList
<>();
FndZhongDengBatch
fndZhongDengBatch
=
new
FndZhongDengBatch
();
fndZhongDengBatch
.
setBatchId
(
batchId
);
fndZhongDengBatches
=
fndZhongDengBatchMapper
.
select
(
fndZhongDengBatch
);
if
(
fndZhongDengBatches
.
size
()
==
0
)
{
resultJson
.
put
(
"code"
,
"000"
);
resultJson
.
put
(
"info"
,
"000"
);
return
resultJson
;
}
/*获取中登网登录loginToken*/
loginToken
=
getRegisterToken
();
/*返回结果loginToken解析,如果返回异常退出当前请求*/
if
(
loginToken
.
contains
(
"Error"
))
{
String
errorCode
=
"-1"
;
String
errorInfo
=
"-1"
;
if
(
errorCode
.
contains
(
":"
))
{
errorCode
=
loginToken
.
split
(
":"
)[
1
];
if
(
errorCode
.
contains
(
"_"
))
{
errorCode
=
loginToken
.
split
(
"_"
)[
0
];
errorInfo
=
loginToken
.
split
(
"_"
)[
1
];
}
}
resultJson
.
put
(
"code"
,
errorCode
);
resultJson
.
put
(
"info"
,
errorInfo
);
}
else
{
List
<
FndZhongDengLines
>
fndZhongDengLinesList
=
new
ArrayList
<>();
/*根据传入ids循环上报中登网*/
synchronized
(
lock
)
{
for
(
FndZhongDengBatch
batch
:
fndZhongDengBatches
)
{
FndZhongDengLines
fndZhongDengLines
=
new
FndZhongDengLines
();
...
...
@@ -223,14 +203,10 @@ public class ZdwWsRequestsServiceImpl implements IZdwWsRequestsService {
fndZhongDengLines
=
fndZhongDengLinesMapper
.
selectByPrimaryKey
(
fndZhongDengLines
);
if
(
Objects
.
nonNull
(
fndZhongDengLines
)
&&
"UPING"
.
equalsIgnoreCase
(
fndZhongDengLines
.
getUpStatus
()))
{
try
{
String
xmlFileContent
=
""
;
String
attachmentZipPath
=
""
;
try
{
String
registerResult
=
""
;
String
registerNumber
=
""
;
String
authorizationCode
=
""
;
String
error
=
""
;
org
.
json
.
JSONObject
returnJson
;
FndAtmAttachmentDto
fndAtmAttachmentDto
=
new
FndAtmAttachmentDto
();
fndAtmAttachmentDto
.
setAttachmentId
(
fndZhongDengLines
.
getAttachmentXmlId
());
...
...
@@ -249,9 +225,15 @@ public class ZdwWsRequestsServiceImpl implements IZdwWsRequestsService {
}
else
{
returns
=
"<feedback>\n<registertype>LR</registertype>\n<registerresult>001</registerresult>\n<registernumber>I0000001</registernumber>\n<authorizationcode>A0000001</authorizationcode>\n<errors>\n<error>\n"
+
resultJson
.
getString
(
"info"
)
+
"</error>\n</errors>\n</feedback>\n"
;
}
System
.
out
.
println
(
"dddd"
+
new
String
(
returns
));
/*解析接口返回结果*/
org
.
json
.
JSONObject
returnJson
;
returnJson
=
XML
.
toJSONObject
(
returns
);
String
registerResult
=
""
;
String
registerNumber
=
""
;
String
authorizationCode
=
""
;
String
error
=
""
;
registerResult
=
returnJson
.
getJSONObject
(
"feedback"
).
getString
(
"registerresult"
);
registerNumber
=
returnJson
.
getJSONObject
(
"feedback"
).
getString
(
"registernumber"
);
authorizationCode
=
returnJson
.
getJSONObject
(
"feedback"
).
getString
(
"authorizationcode"
);
...
...
@@ -271,23 +253,154 @@ public class ZdwWsRequestsServiceImpl implements IZdwWsRequestsService {
fndZhongDengLines
.
setUpDate
(
new
Date
());
fndZhongDengLines
.
set__status
(
DTOStatus
.
UPDATE
);
System
.
out
.
println
(
"dddd"
+
new
String
(
returns
)
);
}
catch
(
RuntimeException
e
)
{
e
.
printStackTrace
(
);
}
catch
(
Exception
e
)
{
// TODO Auto-generated catch block
e
.
printStackTrace
();
fndZhongDengLines
.
setUpStatus
(
"FAIL"
);
fndZhongDengLines
.
setReturnMsg
(
e
.
getMessage
());
}
fndZhongDengLinesList
.
add
(
fndZhongDengLines
);
}
}
if
(
fndZhongDengLinesList
.
size
()
>
0
)
{
fndZhongDengLinesService
.
batchUpdate
(
request
,
fndZhongDengLinesList
);
}
}
}
/***
* 融资租赁-登记入口方法;
* @param request
* @param batchId
***/
public
JSONObject
initRegisterService
(
IRequest
request
,
Long
batchId
)
{
JSONObject
resultJson
=
new
JSONObject
();
/*根据批次ID获取所有上报请求id*/
List
<
FndZhongDengBatch
>
fndZhongDengBatches
=
new
ArrayList
<>();
FndZhongDengBatch
fndZhongDengBatch
=
new
FndZhongDengBatch
();
fndZhongDengBatch
.
setBatchId
(
batchId
);
fndZhongDengBatches
=
fndZhongDengBatchMapper
.
select
(
fndZhongDengBatch
);
if
(
fndZhongDengBatches
.
size
()
==
0
)
{
resultJson
.
put
(
"code"
,
"000"
);
resultJson
.
put
(
"info"
,
"000"
);
return
resultJson
;
}
/*获取中登网登录loginToken*/
loginToken
=
getRegisterToken
();
/*返回结果loginToken解析,如果返回异常退出当前请求*/
if
(
loginToken
.
contains
(
"Error"
))
{
String
errorCode
=
"-1"
;
String
errorInfo
=
"-1"
;
if
(
errorCode
.
contains
(
":"
))
{
errorCode
=
loginToken
.
split
(
":"
)[
1
];
if
(
errorCode
.
contains
(
"_"
))
{
errorCode
=
loginToken
.
split
(
"_"
)[
0
];
errorInfo
=
loginToken
.
split
(
"_"
)[
1
];
}
}
resultJson
.
put
(
"code"
,
errorCode
);
resultJson
.
put
(
"info"
,
errorInfo
);
}
else
{
final
List
<
FndZhongDengBatch
>
fndZhongDengBatchList
=
fndZhongDengBatches
;
/*启用新线程进行异步处理中登网接口请求*/
ExecutorService
cachedThreadPool
=
Executors
.
newCachedThreadPool
();
cachedThreadPool
.
execute
(
new
Runnable
()
{
public
void
run
()
{
// do
try
{
registerThread
(
request
,
fndZhongDengBatchList
,
loginToken
);
}
catch
(
Exception
e
)
{
// TODO Auto-generated catch block
e
.
printStackTrace
();
}
}
});
/*关闭线程*/
cachedThreadPool
.
shutdown
();
// List<FndZhongDengLines> fndZhongDengLinesList = new ArrayList<>();
// /*根据传入ids循环上报中登网*/
// for (FndZhongDengBatch batch : fndZhongDengBatches) {
//
// FndZhongDengLines fndZhongDengLines = new FndZhongDengLines();
// fndZhongDengLines.setLineId(batch.getLineId());
// fndZhongDengLines = fndZhongDengLinesMapper.selectByPrimaryKey(fndZhongDengLines);
//
// if (Objects.nonNull(fndZhongDengLines) && "UPING".equalsIgnoreCase(fndZhongDengLines.getUpStatus())) {
// String xmlFileContent = "";
// String attachmentZipPath = "";
// try {
// String registerResult = "";
// String registerNumber = "";
// String authorizationCode = "";
// String error = "";
// org.json.JSONObject returnJson;
//
// FndAtmAttachmentDto fndAtmAttachmentDto = new FndAtmAttachmentDto();
// fndAtmAttachmentDto.setAttachmentId(fndZhongDengLines.getAttachmentXmlId());
// fndAtmAttachmentDto = fndAtmAttachmentMapper.selectByPrimaryKey(fndAtmAttachmentDto);
//
// /*解析xml文件内容*/
// xmlFileContent = new String(ClientUtils.getxmlFileContent(fndAtmAttachmentDto.getFilePath()));
//
// /*插入接口日志表*/
// if ("INIT".equalsIgnoreCase(fndZhongDengLines.getUpStage())) {
// resultJson = registerInit(fndZhongDengLines.getTypebz(), platformAuthCode, loginToken, fndAtmAttachmentDto.getFileName(), xmlFileContent, fndZhongDengLines.getLineId());
// }
// String returns = "";
// if ("0".equalsIgnoreCase(resultJson.getString("code"))) {
// returns = resultJson.getString("info");
// } else {
// returns = "<feedback>\n<registertype>LR</registertype>\n<registerresult>001</registerresult>\n<registernumber>I0000001</registernumber>\n<authorizationcode>A0000001</authorizationcode>\n<errors>\n<error>\n" + resultJson.getString("info") + "</error>\n</errors>\n</feedback>\n";
// }
//
// /*解析接口返回结果*/
// returnJson = XML.toJSONObject(returns);
// registerResult = returnJson.getJSONObject("feedback").getString("registerresult");
// registerNumber = returnJson.getJSONObject("feedback").getString("registernumber");
// authorizationCode = returnJson.getJSONObject("feedback").getString("authorizationcode");
//
// /*成功*/
// if (Objects.nonNull(registerResult) && "001".equalsIgnoreCase(registerResult)) {
// fndZhongDengLines.setRegisterNumber(registerNumber);
// fndZhongDengLines.setAuthorizationCode(authorizationCode);
// fndZhongDengLines.setUpStatus("SUCCESS");
// fndZhongDengLines.setReturnMsg("上报成功");
// /*失败*/
// } else {
// error = returnJson.getJSONObject("feedback").getString("errors");
// fndZhongDengLines.setUpStatus("FAIL");
// fndZhongDengLines.setReturnMsg(error);
// }
//
// fndZhongDengLines.setUpDate(new Date());
// fndZhongDengLines.set__status(DTOStatus.UPDATE);
//
// System.out.println("dddd" + new String(returns));
// } catch (Exception e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// fndZhongDengLines.setUpStatus("FAIL");
// fndZhongDengLines.setReturnMsg(e.getMessage());
// }
//
// fndZhongDengLinesList.add(fndZhongDengLines);
// }
//
// }
//
// if (fndZhongDengLinesList.size() > 0) {
// fndZhongDengLinesService.batchUpdate(request, fndZhongDengLinesList);
// }
resultJson
.
put
(
"code"
,
"000"
);
resultJson
.
put
(
"info"
,
"000"
);
...
...
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