Commit 02073cf3 authored by 5359's avatar 5359

代码提交git

parent 45854c17
Pipeline #5827 canceled with stages
-- Create table
create table SIGN_INFO_HCLC_FACE
(
FACEAUTH_ID NUMBER not null,
OPEN_ID VARCHAR2(30) not null,
FACEAUTH_STATUS VARCHAR2(30),
URL VARCHAR2(2000),
SHORT_LINK VARCHAR2(2000),
RETURN_CODE VARCHAR2(30),
RETURN_MESSAGE VARCHAR2(2000),
OBJECT_VERSION_NUMBER NUMBER(38) default 1,
REQUEST_ID NUMBER(38) default -1,
PROGRAM_ID NUMBER(38) default -1,
CREATED_BY NUMBER(38) default -1,
CREATION_DATE TIMESTAMP(6) default CURRENT_TIMESTAMP,
LAST_UPDATED_BY NUMBER(38) default -1,
LAST_UPDATE_DATE TIMESTAMP(6) default CURRENT_TIMESTAMP,
LAST_UPDATE_LOGIN NUMBER(38) default -1,
FLOW_ID VARCHAR2(30)
);
-- Add comments to the columns
comment on column SIGN_INFO_HCLC_FACE.OPEN_ID
is '微信openid';
comment on column SIGN_INFO_HCLC_FACE.FACEAUTH_STATUS
is '人脸认证结果';
comment on column SIGN_INFO_HCLC_FACE.URL
is '认证地址原始链接';
comment on column SIGN_INFO_HCLC_FACE.SHORT_LINK
is '认证地址短连接';
comment on column SIGN_INFO_HCLC_FACE.FLOW_ID
is '认证流程Id';
-- Create/Recreate primary, unique and foreign key constraints
alter table SIGN_INFO_HCLC_FACE
add constraint SIGN_INFO_HCLC_FACE_PK primary key (FACEAUTH_ID)
using index ;
-- Create sequence
create sequence SIGN_INFO_HCLC_FACE_S
minvalue 1
maxvalue 9999999999999999999999999999
start with 10001
increment by 1
cache 20;
-- Create table
create table SIGN_INFO_HCLC
(
OPEN_ID VARCHAR2(30) not null,
ID_NO VARCHAR2(30) not null,
NAME VARCHAR2(200) not null,
MOBILE VARCHAR2(30) not null,
EMAIL VARCHAR2(30),
ORIGIN_ID VARCHAR2(30),
TITLE VARCHAR2(200),
ADDRESS VARCHAR2(300),
ACCOUNT_ID VARCHAR2(30),
FACEAUTH_STATUS VARCHAR2(30),
CTITYPE NUMBER,
AGENT_TYPE NUMBER,
AGENT_ID_NO VARCHAR2(30),
AGENT_NAME VARCHAR2(30),
LEGAL_ID_NO VARCHAR2(30),
LEGAL_NAME VARCHAR2(30),
OBJECT_VERSION_NUMBER NUMBER(38) default 1,
REQUEST_ID NUMBER(38) default -1,
PROGRAM_ID NUMBER(38) default -1,
CREATED_BY NUMBER(38) default -1,
CREATION_DATE TIMESTAMP(6) default CURRENT_TIMESTAMP,
LAST_UPDATED_BY NUMBER(38) default -1,
LAST_UPDATE_DATE TIMESTAMP(6) default CURRENT_TIMESTAMP,
LAST_UPDATE_LOGIN NUMBER(38) default -1
);
-- Add comments to the columns
comment on column SIGN_INFO_HCLC.OPEN_ID
is '微信openid';
comment on column SIGN_INFO_HCLC.ID_NO
is '身份证件号(组织机构号)';
comment on column SIGN_INFO_HCLC.NAME
is '用户名称(组织机构名称)';
comment on column SIGN_INFO_HCLC.MOBILE
is '手机号';
comment on column SIGN_INFO_HCLC.EMAIL
is '邮件';
comment on column SIGN_INFO_HCLC.ORIGIN_ID
is '原始用户id';
comment on column SIGN_INFO_HCLC.CTITYPE
is '用户类型(1-个人,2-法人)';
comment on column SIGN_INFO_HCLC.AGENT_TYPE
is '经办人类型(1-组织其他员工,2-法定代表人)';
comment on column SIGN_INFO_HCLC.AGENT_ID_NO
is '经办人身份证号码';
comment on column SIGN_INFO_HCLC.AGENT_NAME
is '经办人姓名';
comment on column SIGN_INFO_HCLC.LEGAL_ID_NO
is '法定代表人身份证号码';
comment on column SIGN_INFO_HCLC.LEGAL_NAME
is '法定代表人姓名';
-- Create/Recreate primary, unique and foreign key constraints
alter table SIGN_INFO_HCLC
add constraint SIGN_INFO_HCLC_PK primary key (OPEN_ID)
using index;
-- Create/Recreate indexes
create index SIGN_INFO_HCLC_N1 on SIGN_INFO_HCLC (ID_NO, OPEN_ID);
......@@ -225,6 +225,16 @@
${project.basedir}/src/main/webapp/WEB-INF/lib/aliyun-java-sdk-dysmsapi-1.0.0-SANPSHOT.jar
</systemPath>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>RELEASE</version>
</dependency>
<dependency>
<groupId>com.baidu.aip</groupId>
<artifactId>java-sdk</artifactId>
<version>4.12.0</version>
</dependency>
<!-- <dependency>
<groupId>com.hand</groupId>
<artifactId>hap-db</artifactId>
......
......@@ -212,7 +212,14 @@ public class SignHclcController extends BaseController {
dto.setCreateMessage("");
//注销经办人用户
map = signHclcService.deletePersonAccount(iRequest, dto);
//初始化经办人人脸识别信息
SignUserInfoHclc agentSignInfo = new SignUserInfoHclc();
agentSignInfo.setOpenId(dto.getOpenId());
agentSignInfo.setIdNo(dto.getAgentIdNo());
agentSignInfo.setMobile(dto.getMobile());
agentSignInfo.setName(dto.getAgentName());
agentSignInfo.setAccountId(dto.getAgentAccountId());
map = signHclcService.deletePersonAccount(iRequest, agentSignInfo);
if ("0".equalsIgnoreCase(map.get("code").toString()) || "40051667".equalsIgnoreCase(map.get("code").toString()) || "000003".equalsIgnoreCase(map.get("code").toString())) {
signHclcService.deleteByPrimaryKey(dto);
} else {
......@@ -301,4 +308,36 @@ public class SignHclcController extends BaseController {
@RequestBody(required = true) JSONObject params) {
return signHclcService.createSignFlows(createRequestContext(request), params);
}
/**
* 创建印章
*
* @param request
* @param dto 创建签署流程
* @return Map
*/
@ResponseBody
@RequestMapping(value = "/sign/seal/create", method = RequestMethod.POST)
public JSONObject createPersonSeal(HttpServletRequest request,
@RequestBody SignUserInfoHclc dto) {
JSONObject json = new JSONObject();
String sealId = signHclcService.createTemplateSeals(dto.getAccountId(), dto.getOpenId());
json.put("sealId", sealId);
return json;
}
// /**
// * 创建签署流程
// *
// * @param request
// * @param params 创建签署流程
// * @return Map
// */
// @ResponseBody
// @RequestMapping(value = "/sign/flows/cancel", method = RequestMethod.POST)
// public JSONObject cancelSignFlows(HttpServletRequest request,
// @RequestBody(required = true) JSONObject params) {
// return signHclcService.cancelSignFlows(createRequestContext(request), params);
// }
}
......@@ -50,6 +50,10 @@ public class SignUserInfoHclc extends BaseDTO {
private String authFlag; // 用户通过认证状态
private String dealerFlag; // 是否代理店
private String sealId; // 是否代理店
@Transient
private String attachmentId;//身份证附件id
......@@ -346,4 +350,20 @@ public class SignUserInfoHclc extends BaseDTO {
public void setAuthFlag(String authFlag) {
this.authFlag = authFlag;
}
public String getDealerFlag() {
return dealerFlag;
}
public void setDealerFlag(String dealerFlag) {
this.dealerFlag = dealerFlag;
}
public String getSealId() {
return sealId;
}
public void setSealId(String sealId) {
this.sealId = sealId;
}
}
......@@ -35,5 +35,9 @@ public interface ISignInfoHclcService extends IBaseService<SignUserInfoHclc>, Pr
JSONObject createSignFlows(IRequest requestContext, JSONObject params);
String createTemplateSeals(String accountId, String openId);
// JSONObject cancelSignFlows(IRequest requestContext, JSONObject params);
void postSignFlowsResult(IRequest iRequest, JSONObject params);
}
......@@ -47,7 +47,7 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
//用户认证接口信息
public static final String indivSysName = "HCLC_FACE_API";
public static final String tokenApiName = "getToken";
public static final String orgApiName = "orgAuthUrl";
public static final String orgApiName = "getOrgAuthUrl";
public static final String getOrgIdApiName = "getOrgByThirdId";
//电子签章接口信息
public static final String signatureSysName = "HCLC_ELECTRONIC_SIGNATURE";
......@@ -66,7 +66,7 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
Map<String, Object> mapOrgan = new HashMap<>();
if (Objects.isNull(info.getOpenId())) {
if (Objects.isNull(info.getOpenId()) || "undefined".equalsIgnoreCase(info.getOpenId())) {
logger.error("关键参数openId不存在,调用失败!");
mapOrgan.put("code", "1");
mapOrgan.put("message", "关键参数openId不存在,调用失败!");
......@@ -88,6 +88,9 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
accountStatus = "AGENT_ADD";
getUrlType = "AGENT";
} else {
signInfoHclc.setCtitype(2L);
signInfoHclc.setAgentType(info.getAgentType());
if ("Y".equalsIgnoreCase(signInfoHclc.getAuthFlag())) {
mapOrgan.put("code", "2");
mapOrgan.put("message", "机构认证已完成,无需重复验证!");
......@@ -95,7 +98,7 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
}
//移动端用户信息发生变更,需要注销e签宝账户,重新创建,并获取核验url
if (!signInfoHclc.getAgentIdNo().equalsIgnoreCase(info.getAgentIdNo()) || !signInfoHclc.getAgentName().equalsIgnoreCase(info.getAgentName()) || !signInfoHclc.getMobile().equalsIgnoreCase(info.getMobile())) {
if (!info.getAgentIdNo().equalsIgnoreCase(signInfoHclc.getAgentIdNo()) || !info.getAgentName().equalsIgnoreCase(signInfoHclc.getAgentName()) || !info.getMobile().equalsIgnoreCase(signInfoHclc.getMobile())) {
//e签宝账户不存在,需要创建e签宝账户
if (Objects.isNull(signInfoHclc.getAgentAccountId())) {
accountStatus = "AGENT_ADD";
......@@ -151,24 +154,48 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
if ("AGENT".equalsIgnoreCase(getUrlType)) {
//初始化经办人人脸识别信息
SignUserInfoHclc agentSignInfo = new SignUserInfoHclc();
agentSignInfo.setOpenId(signInfoHclc.getOpenId());
agentSignInfo.setIdNo(signInfoHclc.getAgentIdNo());
agentSignInfo.setMobile(signInfoHclc.getMobile());
agentSignInfo.setName(signInfoHclc.getAgentName());
agentSignInfo.setOpenId(info.getOpenId());
agentSignInfo.setIdNo(info.getAgentIdNo());
agentSignInfo.setMobile(info.getMobile());
agentSignInfo.setName(info.getAgentName());
agentSignInfo.setCtitype(signInfoHclc.getCtitype());
if (!"AGENT_EXISTS".equalsIgnoreCase(accountStatus)) {
//移动端用户信息发生变更,先注销e签宝用户
if ("AGENT_MODIFY".equalsIgnoreCase(accountStatus)) {
if (Objects.nonNull(signInfoHclc.getAccountId())) {
mapOrgan = deleteOrgansAccount(iRequest, signInfoHclc);
if (!"0".equalsIgnoreCase(mapOrgan.get("code").toString()) && !"40051667".equalsIgnoreCase(mapOrgan.get("code").toString())) {
return mapOrgan;
}
//注销成功
signInfoHclc.setAccountId("");
// signInfoHclc.setAuthAccountId("");
//重新设置机构用户信息
signInfoHclc.setIdNo(info.getIdNo());
signInfoHclc.setName(info.getName());
signInfoHclc.setLegalIdNo(info.getLegalIdNo());
signInfoHclc.setLegalName(info.getLegalName());
signInfoHclc.setOrgAuthId(null);
}
agentSignInfo.setAccountId(signInfoHclc.getAgentAccountId());
mapOrgan = iSignInfoHclcService.deletePersonAccount(iRequest, agentSignInfo);
//注销成功
if ("0".equalsIgnoreCase(mapOrgan.get("code").toString())) {
if ("0".equalsIgnoreCase(mapOrgan.get("code").toString()) || "40051667".equalsIgnoreCase(mapOrgan.get("code").toString())) {
agentSignInfo.setAccountId("");
signInfoHclc.setAgentAccountId("");
signInfoHclc.setAuthAgentAccountId("");
//重新设置经办人信息
signInfoHclc.setAgentIdNo(info.getAgentIdNo());
signInfoHclc.setAgentName(info.getAgentName());
if (signInfoHclc.getAgentType().compareTo(1L) == 0) {
signInfoHclc.setLegalIdNo(info.getLegalIdNo());
signInfoHclc.setLegalName(info.getLegalName());
}
signInfoHclc.setMobile(info.getMobile());
signInfoHclc.setAgentType(info.getAgentType());
signInfoHclc.setFaceAuthId(null);
......@@ -176,17 +203,22 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
}
//注销e签宝用户或者只创建e签宝账户
if (mapOrgan.size() == 0 || "0".equalsIgnoreCase(mapOrgan.get("code").toString())) {
if (mapOrgan.size() == 0 || "0".equalsIgnoreCase(mapOrgan.get("code").toString()) || "40051667".equalsIgnoreCase(mapOrgan.get("code").toString())) {
//创建e签宝账户
mapOrgan = iSignInfoHclcService.addPersonAccount(agentSignInfo);
//创建成功
if ("0".equalsIgnoreCase(mapOrgan.get("code").toString())) {
signInfoHclc.setAgentAccountId(mapOrgan.get("accountId").toString());
signInfoHclc.setSealId(mapOrgan.get("sealId").toString());
if ("AGENT_ADD".equalsIgnoreCase(accountStatus)) {
//重新设置经办人信息
signInfoHclc.setAgentIdNo(info.getAgentIdNo());
signInfoHclc.setAgentName(info.getAgentName());
if (signInfoHclc.getAgentType().compareTo(1L) == 0) {
signInfoHclc.setLegalIdNo(info.getLegalIdNo());
signInfoHclc.setLegalName(info.getLegalName());
}
signInfoHclc.setMobile(info.getMobile());
signInfoHclc.setAgentType(info.getAgentType());
}
......@@ -210,22 +242,22 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
//获取鉴权Token接口结果返回成功
if (Objects.nonNull(token)) {
agentSignInfo.setAccountId(signInfoHclc.getAgentAccountId());
// agentSignInfo.setAccountId(signInfoHclc.getAgentAccountId());
//获取身份验证公有云账户id
if (signInfoHclc.getAuthAgentAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAgentAccountId())) {
mapOrgan = iSignInfoHclcService.getByThirdId(agentSignInfo, token);
if ("0".equalsIgnoreCase(mapOrgan.get("code").toString())) {
signInfoHclc.setAuthAgentAccountId(mapOrgan.get("authAccountId").toString());
}
}
if (signInfoHclc.getAuthAgentAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAgentAccountId())) {
mapOrgan.put("code", "10");
mapOrgan.put("message", "获取验证公有云accountId失败,请检查!");
} else {
// //获取身份验证公有云账户id
// if (signInfoHclc.getAuthAgentAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAgentAccountId())) {
// mapOrgan = iSignInfoHclcService.getByThirdId(agentSignInfo, token);
// if ("0".equalsIgnoreCase(mapOrgan.get("code").toString())) {
// signInfoHclc.setAuthAgentAccountId(mapOrgan.get("authAccountId").toString());
// }
// }
agentSignInfo.setAuthAccountId(signInfoHclc.getAuthAgentAccountId());
// if (signInfoHclc.getAuthAgentAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAgentAccountId())) {
// mapOrgan.put("code", "10");
// mapOrgan.put("message", "获取验证公有云accountId失败,请检查!");
// } else {
//
// agentSignInfo.setAuthAccountId(signInfoHclc.getAuthAgentAccountId());
//设置经办人人脸验证成功跳转地址
agentSignInfo.setRedirectUrl(info.getRedirectUrl());
......@@ -236,7 +268,7 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
if ("0".equalsIgnoreCase(mapOrgan.get("code").toString())) {
signInfoHclc.setFaceAuthId(Long.valueOf(mapOrgan.get("faceAuthId").toString()));
}
}
// }
}
//获取鉴权Token接口结果返回失败
else {
......@@ -262,11 +294,12 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
mapOrgan.put("code", "10");
mapOrgan.put("message", "企业对公打款认证已完成,无需重复验证!");
return mapOrgan;
} else if ("AUTHING".equalsIgnoreCase(signInfoHclcOrg.getAuthStatus())) {
mapOrgan.put("code", "11");
mapOrgan.put("message", "企业对公打款认证中,请耐心等待认证结果!");
return mapOrgan;
}
// else if ("AUTHING".equalsIgnoreCase(signInfoHclcOrg.getAuthStatus())) {
// mapOrgan.put("code", "11");
// mapOrgan.put("message", "企业对公打款认证中,请耐心等待认证结果!");
// return mapOrgan;
// }
}
//e签宝账户不存在,需要新增
......@@ -315,9 +348,9 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
if ("ORG_MODIFY".equalsIgnoreCase(accountStatus)) {
mapOrgan = deleteOrgansAccount(iRequest, signInfoHclc);
//注销成功
if ("0".equalsIgnoreCase(mapOrgan.get("code").toString())) {
if ("0".equalsIgnoreCase(mapOrgan.get("code").toString()) || "40051667".equalsIgnoreCase(mapOrgan.get("code").toString())) {
signInfoHclc.setAccountId("");
signInfoHclc.setAuthAccountId("");
// signInfoHclc.setAuthAccountId("");
//重新设置机构用户信息
signInfoHclc.setIdNo(info.getIdNo());
signInfoHclc.setName(info.getName());
......@@ -328,7 +361,7 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
}
//创建e签宝账户
if (mapOrgan.size() == 0 || "0".equalsIgnoreCase(mapOrgan.get("code").toString())) {
if (mapOrgan.size() == 0 || "0".equalsIgnoreCase(mapOrgan.get("code").toString()) || "40051667".equalsIgnoreCase(mapOrgan.get("code").toString())) {
//初始化经办人人脸识别信息
SignUserInfoHclc ogrSignInfo = new SignUserInfoHclc();
ogrSignInfo.setAgentAccountId(signInfoHclc.getAgentAccountId());
......@@ -370,18 +403,18 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
if (Objects.nonNull(token)) {
//获取身份验证公有云账户id
if (signInfoHclc.getAuthAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAccountId())) {
mapOrgan = getByThirdId(signInfoHclc, token);
if ("0".equalsIgnoreCase(mapOrgan.get("code").toString())) {
signInfoHclc.setAuthAccountId(mapOrgan.get("authOrgAccountId").toString());
}
}
// //获取身份验证公有云账户id
// if (signInfoHclc.getAuthAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAccountId())) {
// mapOrgan = getByThirdId(signInfoHclc, token);
// if ("0".equalsIgnoreCase(mapOrgan.get("code").toString())) {
// signInfoHclc.setAuthAccountId(mapOrgan.get("authOrgAccountId").toString());
// }
// }
if (signInfoHclc.getAuthAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAccountId())) {
mapOrgan.put("code", "10");
mapOrgan.put("message", "获取验证公有云accountId失败,请检查!");
} else {
// if (signInfoHclc.getAuthAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAccountId())) {
// mapOrgan.put("code", "10");
// mapOrgan.put("message", "获取验证公有云accountId失败,请检查!");
// } else {
signInfoHclc.setRedirectUrl(info.getRedirectUrl());
//获取组织机构核身地址
......@@ -389,7 +422,7 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
if ("0".equalsIgnoreCase(mapOrgan.get("code").toString())) {
signInfoHclc.setOrgAuthId(Long.valueOf(mapOrgan.get("orgAuthId").toString()));
}
}
// }
} else {
mapOrgan.put("code", "2");
......@@ -417,7 +450,7 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
json1.put("notifyUrl", info.getNotifyUrl());
json1.put("redirectUrl", info.getRedirectUrl());
//个人认证基本信息
//企业/组织认证基本信息
JSONObject json2 = new JSONObject();
//组织机构名称
json2.put("name", info.getName());
......@@ -431,22 +464,31 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
json2.put("egalRepCertType", "INDIVIDUAL_CH_IDCARD");
//法定代表人姓名
json2.put("legalRepName", info.getLegalName());
//经办人姓名
json2.put("agentName", info.getAgentName());
//经办人身份证号
json2.put("agentIdNo", info.getAgentIdNo());
//法定代表人地区/国籍
json2.put("legalRepNationality", "");
// json2.put("legalRepNationality", "");
//经办人身份1 企业法定代表人;2 企业授权代理人
json2.put("operatorType", info.getAgentType());
//组织核验类型,“1”:三要素核验;“2”:四要素核验;不填为不指定核验类型
json2.put("verifyType", "2");
//认证配置信息
JSONObject json3 = new JSONObject();
String[] str = new String[]{"name", "certNo", "legalRepName", "legalRepCertNo", "agentName", "agentIdNo"};
json3.put("indivUneditableInfo", str);
JSONObject result = new JSONObject();
result.put("agentAccountId", info.getAuthAgentAccountId());
// result.put("agentAccountId", info.getAuthAgentAccountId());
result.put("authType", "ORG_BANK_TRANSFER");//组织机构对公账户打款认证
result.put("contextInfo", json1);
result.put("orgEntity", json2);
result.put("repeatIdentity", false);
result.put("configParams", json3);
// result.put("repeatIdentity", false);
JSONObject json = new JSONObject(result);
String param = json.toString();
// String param = json.toString();
//设置http请求head信息
Map<String, String> headInfo = new HashMap<String, String>();
......@@ -457,12 +499,12 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
try {
//初始化接口信息
String orgApiurl = iSignInfoHclcService.getApiUrl(indivSysName, orgApiName);
orgApiurl = orgApiurl.replace("{accountId}", info.getAuthAccountId());
// orgApiurl = orgApiurl.replace("{accountId}", info.getAuthAccountId());
logger.debug("upload url: {}", orgApiurl);
SignHclcUtils signHclcUtils1 = new SignHclcUtils();
//发送http请求
String stringResult = signHclcUtils1.postString(orgApiurl, param, headInfo);
String stringResult = signHclcUtils1.postString(orgApiurl, json, headInfo, signHclcUtils1.APPLICATION_JSON);
//解析返回结果
JSONObject jsonResult = JSONObject.parseObject(stringResult);
......@@ -476,6 +518,7 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
map.put("code", "0");
map.put("orgAuthId", signInfoHclcFace.getAuthId());
map.put("url", data.getString("url"));
map.put("AuthType", "ORG");
map.put("message", "获取url成功!");
} else {
map.put("code", jsonResult.getString("code"));
......@@ -546,7 +589,7 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
//发送http请求
SignHclcUtils signHclcUtils1 = new SignHclcUtils();
String stringResult = signHclcUtils1.postString(url, param, headInfo);
String stringResult = signHclcUtils1.postString(url, json, headInfo, signHclcUtils1.APPLICATION_JSON);
//解析返回结果
JSONObject jsonResult = JSONObject.parseObject(stringResult);
......@@ -583,7 +626,7 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
if (Objects.isNull(signInfoHclc.getAccountId()) || "".equalsIgnoreCase(signInfoHclc.getAccountId())) {
logger.debug("e签宝机构账户 accountId: {} 不存在,无需注销!", signInfoHclc.getAccountId());
map.put("code", "000012");
map.put("code", "40051667");
map.put("message", "e签宝机构账户不存在,无需注销!");
return map;
}
......@@ -614,11 +657,11 @@ public class OrganSignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHc
//发送http请求
SignHclcUtils signHclcUtils1 = new SignHclcUtils();
String stringResult = signHclcUtils1.postString(url, param, headInfo);
String stringResult = signHclcUtils1.postString(url, json, headInfo, signHclcUtils1.APPLICATION_JSON);
//解析返回结果
JSONObject jsonResult = JSONObject.parseObject(stringResult);
if ("0".equalsIgnoreCase(jsonResult.getString("errCode")) || "40051667".equalsIgnoreCase(map.get("code").toString())) {
if ("0".equalsIgnoreCase(jsonResult.getString("errCode")) || "40051667".equalsIgnoreCase(jsonResult.getString("errCode"))) {
map.put("code", "0");
map.put("message", "e签宝机构用户注销成功!");
} else {
......
......@@ -3,7 +3,6 @@ package com.hand.app.esignHclc.service.impl;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.hand.app.esign.service.ISignInfoService;
import com.hand.app.esign.utils.AlgorithmHelper;
import com.hand.app.esignHclc.dto.SignFlowsInfoHclc;
import com.hand.app.esignHclc.dto.SignUserAttachInfo;
......@@ -74,6 +73,10 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
private String apiKey;
@Value("${wx.image.path}")
private String imagePath;
@Value("${tsign.api.listenSignUrl}")
private String listenSignUrl;
@Value("${tsign.api.signRedirectUrl}")
private String signRedirectUrl;
private CloseableHttpClient httpClient;
......@@ -81,7 +84,7 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
//用户认证接口信息
public static final String indivSysName = "HCLC_FACE_API";
public static final String tokenApiName = "getToken";
public static final String indivApiName = "indivAuthUrl";
public static final String indivApiName = "getIndivAuthUrl";
public static final String getAccIdApiName = "getAccByThirdId";
//公众号接口信息
public static final String wxSysName = "wxgzh_hitachics";
......@@ -90,13 +93,16 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
public static final String hclcSysName = "HCL_UPLOAD_FILE";
public static final String hclcUpLoadApiName = "upload";
public static final String hclcDownloadApiName = "download";
public static final String signSendApiName = "SignSendApiName";
public static final String signFileDownApiName = "elecContractDownload";
//电子签章接口信息
public static final String signatureSysName = "HCLC_ELECTRONIC_SIGNATURE";
public static final String accountsApiName = "outerAccounts";
public static final String deleteApiName = "accountsDelete";
public static final String signatureUpLoadApiName = "fileUpload";
public static final String signFlowsApiName = "signFlows";
public static final String getUrlsApiName = "getSignFlowDocUrls";
public static final String getSignUrlsApiName = "getSignFlowDocUrls";
public static final String createSealsApiName = "createTemplateSeals";
private static final String HASH_ALGORITHM = "HmacSHA256";
......@@ -127,7 +133,7 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
Map<String, Object> map = new HashMap<>();
if (Objects.isNull(info.getOpenId())) {
if (Objects.isNull(info.getOpenId()) || "undefined".equalsIgnoreCase(info.getOpenId())) {
logger.error("关键参数openId不存在,调用失败!");
map.put("code", "000001");
map.put("message", "关键参数openId不存在,调用失败!");
......@@ -147,6 +153,7 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
signInfoHclc = this.insertSelective(iRequest, info);
accountStatus = "ADD";
} else {
signInfoHclc.setCtitype(1L);
if ("Y".equalsIgnoreCase(signInfoHclc.getAuthFlag())) {
map.put("code", "000002");
map.put("message", "人脸核身认证已完成,无需重复验证!");
......@@ -222,10 +229,17 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
//创建e签宝账户
if (map.size() == 0 || "0".equalsIgnoreCase(map.get("code").toString()) || "40051667".equalsIgnoreCase(map.get("code").toString())) {
map = addPersonAccount(signInfoHclc);
//初始化经办人人脸识别信息
SignUserInfoHclc signInfo = new SignUserInfoHclc();
signInfo.setOpenId(signInfoHclc.getOpenId());
signInfo.setIdNo(info.getIdNo());
signInfo.setMobile(info.getMobile());
signInfo.setName(info.getName());
map = addPersonAccount(signInfo);
//创建成功
if ("0".equalsIgnoreCase(map.get("code").toString())) {
signInfoHclc.setAccountId(map.get("accountId").toString());
signInfoHclc.setSealId(map.get("sealId").toString());
if ("ADD".equalsIgnoreCase(accountStatus)) {
//重新设置个人用户信息
signInfoHclc.setIdNo(info.getIdNo());
......@@ -251,18 +265,18 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
if (Objects.nonNull(token)) {
//获取身份验证公有云账户id
if (signInfoHclc.getAuthAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAccountId())) {
map = getByThirdId(signInfoHclc, token);
if ("0".equalsIgnoreCase(map.get("code").toString())) {
signInfoHclc.setAuthAccountId(map.get("authAccountId").toString());
}
}
// //获取身份验证公有云账户id
// if (signInfoHclc.getAuthAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAccountId())) {
// map = getByThirdId(signInfoHclc, token);
// if ("0".equalsIgnoreCase(map.get("code").toString())) {
// signInfoHclc.setAuthAccountId(map.get("authAccountId").toString());
// }
// }
if (signInfoHclc.getAuthAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAccountId())) {
map.put("code", "000010");
map.put("message", "获取验证公有云accountId失败,请检查!");
} else {
// if (signInfoHclc.getAuthAccountId() == null || "".equalsIgnoreCase(signInfoHclc.getAuthAccountId())) {
// map.put("code", "000010");
// map.put("message", "获取验证公有云accountId失败,请检查!");
// } else {
signInfoHclc.setRedirectUrl(info.getRedirectUrl());
//获取个人核身认证地址
map = getFaceUrlHttp(iRequest, signInfoHclc, token);
......@@ -270,7 +284,7 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
if ("0".equalsIgnoreCase(map.get("code").toString())) {
signInfoHclc.setFaceAuthId(Long.valueOf(map.get("faceAuthId").toString()));
}
}
// }
} else {
map.put("code", "000007");
......@@ -342,9 +356,9 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
result.put("contextInfo", json1);
result.put("indivInfo", json2);
result.put("configParams", json3);
result.put("repeatIdentity", true);
// result.put("repeatIdentity", true);
JSONObject json = new JSONObject(result);
String param = json.toString();
// String param = json.toString();
//设置http请求head信息
Map<String, String> headInfo = new HashMap<String, String>();
......@@ -354,12 +368,13 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
try {
//初始化接口url信息
String faceApiurl = getApiUrl(indivSysName, indivApiName).replace("{accountId}", info.getAuthAccountId());
logger.debug("upload url: {}", faceApiurl);
// String faceApiurl = getApiUrl(indivSysName, indivApiName).replace("{accountId}", info.getAuthAccountId());
String faceApiurl = getApiUrl(indivSysName, indivApiName);
logger.debug("get face api url: {}", faceApiurl);
//发送http请求
SignHclcUtils signHclcUtils1 = new SignHclcUtils();
String stringResult = signHclcUtils1.postString(faceApiurl, param, headInfo);
String stringResult = signHclcUtils1.postString(faceApiurl, json, headInfo, signHclcUtils1.APPLICATION_JSON);
//解析返回结果
JSONObject jsonResult = JSONObject.parseObject(stringResult);
......@@ -372,18 +387,19 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
map.put("code", "0");
map.put("faceAuthId", signInfoHclcFace.getAuthId());
map.put("AuthType", "FACE");
map.put("url", data.getString("url"));
map.put("message", "获取url成功!");
} else {
map.put("code", "8");
map.put("code", "000008");
map.put("message", "获取人脸核身认证url失败," + jsonResult.getString("message"));
}
signInfoHclcFace.setReturnCode(jsonResult.getString("code"));
signInfoHclcFace.setReturnMessage(jsonResult.getString("message"));
} catch (Exception e) {
map.put("code", "9");
map.put("code", "000009");
map.put("message", "访问e签宝人脸核身地址失败,请检查!");
signInfoHclcFace.setReturnCode("3");
signInfoHclcFace.setReturnCode("000009");
signInfoHclcFace.setReturnMessage(e.getMessage());
}
......@@ -409,11 +425,11 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
try {
//初始化接口url信息
String faceApiurl = getApiUrl(indivSysName, getAccIdApiName) + "?" + param;
logger.debug("get face api url: {}", faceApiurl);
String accIdApiurl = getApiUrl(indivSysName, getAccIdApiName) + "?" + param;
logger.debug("get accountId api url: {}", accIdApiurl);
//发送http请求
HttpResponse execute = HttpUtil.getJson(faceApiurl, headInfo);
HttpResponse execute = HttpUtil.getJson(accIdApiurl, headInfo);
int httpReponseCode;
String stringResult = null;
JSONObject responseBody = new JSONObject();
......@@ -436,16 +452,16 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
map.put("authAccountId", data.getString("accountId"));
map.put("message", "获取个人云账户成功!");
} else {
map.put("code", "8");
map.put("code", "000008");
map.put("message", "获取个人云账户失败," + jsonResult.getString("message"));
}
} else {
map.put("code", "10");
map.put("code", "000010");
map.put("message", "获取个人云账户发送网络请求失败,请检查个人云地址信息!");
}
} catch (Exception e) {
map.put("code", "9");
map.put("code", "000009");
map.put("message", e.getMessage());
}
......@@ -900,7 +916,6 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
public Map<String, Object> addPersonAccount(SignUserInfoHclc signInfoHclc) {
Map<String, Object> map = new HashMap<>();
//业务方交互上下文信息
JSONObject result = new JSONObject();
//银行卡号
......@@ -942,14 +957,19 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
//发送http请求
SignHclcUtils signHclcUtils1 = new SignHclcUtils();
String stringResult = signHclcUtils1.postString(url, param, headInfo);
String stringResult = signHclcUtils1.postString(url, json, headInfo, signHclcUtils1.APPLICATION_JSON);
//解析返回结果
JSONObject jsonResult = JSONObject.parseObject(stringResult);
if ("0".equalsIgnoreCase(jsonResult.getString("errCode"))) {
JSONObject data = jsonResult.getJSONObject("data");
//设置返回accountId
map.put("accountId", data.getString("accountId"));
String sealId = createTemplateSeals(data.getString("accountId"), signInfoHclc.getOpenId());
map.put("sealId", sealId);
map.put("code", "0");
map.put("message", "个人e签宝账户创建成功!");
} else {
......@@ -960,12 +980,62 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
} catch (Exception e) {
logger.error("create person account failed, msg:{}", e.getMessage());
map.put("code", "000006");
map.put("message", "个人e签宝账户创建成功失败," + e.getMessage());
map.put("message", "个人e签宝账户创建失败," + e.getMessage());
}
return map;
}
public String createTemplateSeals(String accountId, String openId) {
//业务方交互上下文信息
JSONObject result = new JSONObject();
//创建用户返回的天印签章系统的用户id
result.put("accountId", accountId);
//印章颜色
result.put("color", "BLACK");
//模板类型
result.put("templateType", "BORDERLESS");
//用户的唯一标识可以为客户业务系统内唯一标识
result.put("uniqueId", openId);
JSONObject json = new JSONObject(result);
String param = json.toString();
//获取HMAC加密后的X-timevale-signature签名信息
AlgorithmHelper algorithmHelper = new AlgorithmHelper();
String EncryptedString = algorithmHelper.getXtimevaleSignature(param, projectSecret, HASH_ALGORITHM, "UTF-8");
//设置http请求head信息
Map<String, String> headInfo = new HashMap<String, String>();
headInfo.put("x-timevale-project-id", projectId);
headInfo.put("x-timevale-signature", EncryptedString);
try {
//初始化接口信息
String url = getApiUrl(signatureSysName, createSealsApiName);
logger.debug("create seals url: {}", url);
//发送http请求
SignHclcUtils signHclcUtils1 = new SignHclcUtils();
String stringResult = signHclcUtils1.postString(url, json, headInfo, signHclcUtils1.APPLICATION_JSON);
//解析返回结果
JSONObject jsonResult = JSONObject.parseObject(stringResult);
if ("0".equalsIgnoreCase(jsonResult.getString("errCode"))) {
JSONObject data = jsonResult.getJSONObject("data");
return data.getString("sealId");
} else {
logger.error("create seals failed, errCode:{} ,msg:{}", jsonResult.getString("errCode"), jsonResult.getString("msg"));
return "-1";
}
} catch (Exception e) {
logger.error("create seals failed, msg:{}", e.getMessage());
return "-1";
}
}
public Map<String, Object> deletePersonAccount(IRequest iRequest, SignUserInfoHclc signInfoHclc) {
Map<String, Object> map = new HashMap<>();
......@@ -978,12 +1048,6 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
return map;
}
if (Objects.isNull(signInfoHclc.getAccountId())) {
logger.debug("e签宝个人账户不存在,无需注销!");
map.put("code", "000003");
map.put("message", "e签宝个人账户不存在,无需注销!");
return map;
}
String accountId = "";
......@@ -993,6 +1057,14 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
} else {
accountId = signInfoHclc.getAgentAccountId();
}
if (Objects.isNull(accountId) || "".equalsIgnoreCase(accountId)) {
logger.debug("e签宝个人账户不存在,无需注销!");
map.put("code", "40051667");
map.put("message", "e签宝个人账户不存在,无需注销!");
return map;
}
//业务方交互上下文信息
JSONObject result = new JSONObject();
//创建内部用户返回的天印签章系统的用户id
......@@ -1019,11 +1091,11 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
//发送http请求
SignHclcUtils signHclcUtils1 = new SignHclcUtils();
String stringResult = signHclcUtils1.postString(url, param, headInfo);
String stringResult = signHclcUtils1.postString(url, json, headInfo, signHclcUtils1.APPLICATION_JSON);
//解析返回结果
JSONObject jsonResult = JSONObject.parseObject(stringResult);
if ("0".equalsIgnoreCase(jsonResult.getString("errCode")) || "40051667".equalsIgnoreCase(map.get("code").toString())) {
if ("0".equalsIgnoreCase(jsonResult.getString("errCode")) || "40051667".equalsIgnoreCase(jsonResult.getString("errCode"))) {
map.put("code", "0");
map.put("message", "e签宝个人用户注销成功!");
} else {
......@@ -1049,49 +1121,101 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
//解析签署人信息集合,替换用户信息为accountId
JSONArray signers = params.getJSONArray("signers");
JSONArray signersNew = new JSONArray();
String initiatorAccountId = "";
// String initiatorAccountId = "";
for (int i = 0; i < signers.size(); i++) {
JSONObject json1 = signers.getJSONObject(i);
String idNo = json1.getString("idNo");
String name = json1.getString("name");
String role = json1.getString("role");
if ("HCLC".equalsIgnoreCase(role)) {
json1.put("accountId", "0d83cfe0-4d86-11ea-b71a-b8599f3574b6");
json1.put("authorizationOrganizeId", "f858b8e9-5c3a-11ea-8486-506b4bfdce3c");
} else {
SignUserInfoHclc signInfoHclc = new SignUserInfoHclc();
signInfoHclc.setAuthFlag("Y");
//代理店匹配用户名称
if ("AGENT".equalsIgnoreCase(role)) {
signInfoHclc.setName(name);
} else {
//代理店匹配用户名称
if (Objects.nonNull(idNo)) {
signInfoHclc.setIdNo(idNo);
signInfoHclc.setName(name);
}
List<SignUserInfoHclc> signInfoHclcs = signInfoHclcMapper.queryUserInfo(signInfoHclc);
if (signInfoHclcs.size() == 0) {
logger.error("create sign flows failed, account:{} is not defined in wx", name + idNo);
jsonResult.put("code", "2");
jsonResult.put("message", "创建签署流程失败,用户" + name + idNo + "在移动端未成功注册,请先注册!");
jsonResult.put("errCode", "2");
jsonResult.put("msg", "创建签署流程失败,用户" + name + idNo + "在移动端未完成实名认证,请先认证!");
return jsonResult;
} else {
signInfoHclc = signInfoHclcs.get(0);
json1.put("accountType", signInfoHclc.getCtitype());
json1.put("uniqueId", signInfoHclc.getOpenId());
json1.put("contactMobile", signInfoHclc.getMobile());
//用户类型是个人时
if (signInfoHclc.getCtitype().compareTo(1L) == 0) {
json1.put("accountId", signInfoHclc.getAccountId());
json1.put("uniqueId", signInfoHclc.getOpenId());
//用户类型是机构时
} else {
json1.put("accountId", signInfoHclc.getAgentAccountId());
json1.put("authorizationOrganizeId", signInfoHclc.getAccountId());
json1.put("uniqueId", signInfoHclc.getOpenId());
}
// //代理店设置发起人
// if ("AGENT".equalsIgnoreCase(role)) {
// initiatorAccountId = signInfoHclc.getAccountId();
// }
}
//代理店设置发起人
if ("AGENT".equalsIgnoreCase(role)) {
initiatorAccountId = signInfoHclc.getAccountId();
//判断文字签字印章自定义模板是否存在
if (Objects.nonNull(signInfoHclc.getSealId()) && !"-1".equalsIgnoreCase(signInfoHclc.getSealId())) {
//获取签署文档信息
JSONArray signDocDetails = json1.getJSONArray("signDocDetails");
JSONArray signDocDetailsNew = new JSONArray();
//解析签署文档信息
for (int j = 0; j < signDocDetails.size(); j++) {
JSONObject detail = signDocDetails.getJSONObject(j);
//获取签署位置信息
JSONArray signPos = detail.getJSONArray("signPos");
JSONArray signPosNew = new JSONArray();
for (int k = 0; k < signPos.size(); k++) {
JSONObject pos = signPos.getJSONObject(k);
//个人签字统一更换签字模板
if (signInfoHclc.getCtitype().compareTo(1L) == 0) {
pos.remove("sealId");
pos.put("sealId", signInfoHclc.getSealId());
} else {
//企业签字判断是否存在PERSON签字,更换签字模板
String signIdentity = pos.getString("signIdentity");
if ("PERSON".equalsIgnoreCase(signIdentity)) {
pos.remove("sealId");
pos.put("sealId", signInfoHclc.getSealId());
}
}
signPosNew.add(pos);
}
detail.remove("signPos");
detail.put("signPos", signPosNew);
signDocDetailsNew.add(detail);
}
json1.remove("signDocDetails");
json1.put("signDocDetails", signDocDetailsNew);
}
}
json1.put("accountType", "2");
json1.remove("idNo");
json1.remove("name");
json1.remove("role");
......@@ -1106,13 +1230,15 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
//第三方业务码
result.put("bizNo", params.get("bizNo"));
//签署回调通知地址
result.put("callbackUrl", params.get("callbackUrl"));
result.put("callbackUrl", listenSignUrl);
//流程备注
result.put("comments", params.get("comments"));
// //抄送人信息集合签署成功后通知抄送人
// result.put("copyViewers", params.get("copyViewers"));
//发起人用户id
result.put("initiatorAccountId", initiatorAccountId);
//发起人用户id,默认hclc发起
result.put("initiatorAccountId", "f858b8e9-5c3a-11ea-8486-506b4bfdce3c");
//签署完成重定向地址
result.put("redirectUrl", signRedirectUrl);
//流程文档信息集合
result.put("signDocs", params.get("signDocs"));
//签署人信息集合
......@@ -1120,6 +1246,9 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
//流程主题
result.put("subject", params.get("subject"));
//一键落章
result.put("signSceneNo", "QSCJ0001");
JSONObject json = new JSONObject(result);
String param = json.toString();
......@@ -1138,7 +1267,7 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
//初始化接口信息
String url = getApiUrl(signatureSysName, signFlowsApiName);
logger.debug("upload url: {}", url);
logger.debug("sign flows url: {}", url);
signFlowsInfoHclc.setContractNo(params.getString("bizNo"));
signFlowsInfoHclc.setSignAction("SIGN_CREATE");
......@@ -1149,7 +1278,7 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
//发送http请求
SignHclcUtils signHclcUtils1 = new SignHclcUtils();
String stringResult = signHclcUtils1.postString(url, param, headInfo);
String stringResult = signHclcUtils1.postString(url, json, headInfo, signHclcUtils1.APPLICATION_JSON);
//解析返回结果
jsonResult = JSONObject.parseObject(stringResult);
......@@ -1165,9 +1294,13 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
//解析返回签署信息集合,替换accountId为用户信息
JSONArray signUrls = data.getJSONArray("signUrls");
JSONArray signUrlsNew = new JSONArray();
for (int i = 0; i < signUrls.size(); i++) {
JSONObject signUrl = signUrls.getJSONObject(i);
//建机自己
if ("0d83cfe0-4d86-11ea-b71a-b8599f3574b6".equalsIgnoreCase(signUrl.getString("accountId"))) {
signUrl.put("name", "日立建机");
} else {
//根据uniqueId获取用户信息
SignUserInfoHclc signInfoHclc = new SignUserInfoHclc();
signInfoHclc.setOpenId(signUrl.getString("uniqueId"));
......@@ -1175,21 +1308,19 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
signUrl.put("idNo", signInfoHclc.getIdNo());
signUrl.put("name", signInfoHclc.getName());
}
signUrl.remove("accountId");
signUrl.remove("accountName");
signUrlsNew.add(signUrl);
}
jsonResult.remove("signUrls");
jsonResult.put("signUrls", signUrlsNew);
}
} catch (Exception e) {
logger.error("create sign flows failed, msg:{}", e.getMessage());
jsonResult.put("code", "4");
jsonResult.put("message", "创建签署流程失败," + e.getMessage());
jsonResult.put("errCode", "000004");
jsonResult.put("msg", "创建签署流程失败," + e.getMessage());
}
if (Objects.nonNull(signFlowsInfoHclc)) {
......@@ -1223,30 +1354,79 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
map = getSignFlowDocUrls(signFlowsInfoHclc.getSignFlowId());
params.remove("finishDocUrlBeans");
params.put("finishDocUrlBeans", map.get("signDocUrlList"));
//角色签署完成状态回调,替换用户信息
} else if ("SIGN_FLOW_UPDATE".equalsIgnoreCase(params.getString("action"))) {
JSONObject accountInfo = params.getJSONObject("accountInfo");
SignUserInfoHclc signUserInfoHclc = new SignUserInfoHclc();
//判断是否机构用户
if (Objects.isNull(accountInfo.getString("authOrgId")) || "".equalsIgnoreCase(accountInfo.getString("authOrgId"))) {
signUserInfoHclc.setAccountId(accountInfo.getString("accountId"));
} else {
signUserInfoHclc.setAccountId(accountInfo.getString("authOrgId"));
}
JSONObject accountInfoNew = new JSONObject();
if ("f858b8e9-5c3a-11ea-8486-506b4bfdce3c".equalsIgnoreCase(signUserInfoHclc.getAccountId())) {
accountInfoNew.put("ctino", "");
accountInfoNew.put("name", "日立建机");
} else {
//获取移动端用户信息
signUserInfoHclc = signInfoHclcMapper.selectOne(signUserInfoHclc);
accountInfoNew.put("ctino", signUserInfoHclc.getIdNo());
accountInfoNew.put("name", signUserInfoHclc.getName());
}
params.remove("accountInfo");
params.put("accountInfo", accountInfoNew);
}
try {
//初始化接口信息
String url = getApiUrl(hclcSysName, getUrlsApiName);
logger.debug("upload url: {}", url);
String url = getApiUrl(hclcSysName, signSendApiName);
logger.debug("sign flow url: {}", url);
String param = params.toString();
Map<String, String> headInfo = new HashMap<String, String>();
headInfo.put("Content-Type", "application/x-www-form-urlencoded");
JSONObject requestData = new JSONObject();
requestData.put("requestData", params.toString());
//发送http请求
SignHclcUtils signHclcUtils1 = new SignHclcUtils();
String stringResult = signHclcUtils1.postString(url, param, null);
String stringResult = signHclcUtils1.postString(url, requestData, headInfo, signHclcUtils1.APPLICATION_FORM_URLENCODED);
//解析返回结果
JSONObject jsonResult = JSONObject.parseObject(stringResult);
if ("0".equalsIgnoreCase(jsonResult.getString("code"))) {
if ("true".equalsIgnoreCase(jsonResult.getString("success"))) {
signFlowsInfoHclc.setSendFlag("Y");
iSignFlowsInfoHclcService.updateByPrimaryKey(iRequest, signFlowsInfoHclc);
} else {
logger.error("get sign flow doc urls failed, errCode:{} ,msg:{}", jsonResult.getString("errCode"), jsonResult.getString("msg"));
logger.error("post sign flow failed, errCode:{} ,msg:{}", jsonResult.getJSONObject("error").getString("code"), jsonResult.getJSONObject("error").getString("message"));
}
//签署终结状态回调,签署完成下载签署文件
if ("SIGN_FLOW_FINISH".equalsIgnoreCase(params.getString("action"))) {
//初始化签署文件下载接口信息
String signUrl = getApiUrl(hclcSysName, signFileDownApiName);
logger.debug("sign flow url: {}", url);
Map<String, String> downHeadInfo = new HashMap<String, String>();
headInfo.put("Content-Type", "application/x-www-form-urlencoded");
//发送http请求
String stringResult2 = signHclcUtils1.postString(signUrl, params, downHeadInfo, signHclcUtils1.APPLICATION_FORM_URLENCODED);
//解析返回结果
JSONObject jsonResult2 = JSONObject.parseObject(stringResult2);
if (!"true".equalsIgnoreCase(jsonResult2.getString("success"))) {
logger.error("down sign file failed, errCode:{} ,msg:{}", jsonResult2.getJSONObject("error").getString("code"), jsonResult2.getJSONObject("error").getString("message"));
}
}
} catch (Exception e) {
logger.error("get sign flow doc urls failed ,msg:{}", e.getMessage());
logger.error("post sign flow failed ,msg:{}", e.getMessage());
}
}
......@@ -1255,15 +1435,11 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
Map<String, Object> map = new HashMap<>();
//业务方交互上下文信息
JSONObject result = new JSONObject();
//银行卡号
result.put("signFlowId", signFlowId);
JSONObject json = new JSONObject(result);
String param = json.toString();
String param = "signFlowId=" + signFlowId + "&intranetFlag=Y";
//获取HMAC加密后的X-timevale-signature签名信息
AlgorithmHelper algorithmHelper = new AlgorithmHelper();
String EncryptedString = algorithmHelper.getXtimevaleSignature(param, projectSecret, HASH_ALGORITHM, "UTF-8");
String EncryptedString = algorithmHelper.getXtimevaleSignature("", projectSecret, HASH_ALGORITHM, "UTF-8");
//设置http请求head信息
Map<String, String> headInfo = new HashMap<String, String>();
......@@ -1273,12 +1449,12 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
try {
//初始化接口信息
String url = getApiUrl(signatureSysName, getUrlsApiName);
String url = getApiUrl(signatureSysName, getSignUrlsApiName);
logger.debug("upload url: {}", url);
//发送http请求
SignHclcUtils signHclcUtils1 = new SignHclcUtils();
String stringResult = signHclcUtils1.postString(url, param, headInfo);
String stringResult = signHclcUtils1.getStr(url, param, headInfo);
//解析返回结果
JSONObject jsonResult = JSONObject.parseObject(stringResult);
......@@ -1295,10 +1471,103 @@ public class SignInfoHclcServiceImpl extends BaseServiceImpl<SignUserInfoHclc> i
}
} catch (Exception e) {
logger.error("create person account failed, msg:{}", e.getMessage());
map.put("code", "1");
map.put("code", "000001");
map.put("message", "获取签署流程文档下载地址失败,请检查!" + e.getMessage());
}
return map;
}
// public JSONObject cancelSignFlows(IRequest requestContext, JSONObject params) {
//
// JSONObject jsonResult = new JSONObject();
//
//
// JSONObject result = new JSONObject();
// //第三方业务码
// result.put("bizNo", params.get("bizNo"));
// //作废原因
// result.put("reason", params.get("reason"));
// //原签署流程id
// result.put("signFlowId", params.get("signFlowId"));
//
// JSONObject json = new JSONObject(result);
// String param = json.toString();
//
// //获取HMAC加密后的X-timevale-signature签名信息
// AlgorithmHelper algorithmHelper = new AlgorithmHelper();
// String EncryptedString = algorithmHelper.getXtimevaleSignature(param, projectSecret, HASH_ALGORITHM, "UTF-8");
//
// //设置http请求head信息
// Map<String, String> headInfo = new HashMap<String, String>();
// headInfo.put("x-timevale-project-id", projectId);
// headInfo.put("x-timevale-signature", EncryptedString);
//
// SignFlowsInfoHclc signFlowsInfoHclc = new SignFlowsInfoHclc();
//
// try {
//
// //初始化接口信息
// String url = getApiUrl(signatureSysName, signFlowsApiName);
// logger.debug("sign flows url: {}", url);
//
// signFlowsInfoHclc.setContractNo(params.getString("bizNo"));
// signFlowsInfoHclc.setSignAction("SIGN_CANCEL");
// signFlowsInfoHclc.setStatus("5");
// signFlowsInfoHclc.setRequestClob(param);
// signFlowsInfoHclc = iSignFlowsInfoHclcService.insertSelective(requestContext, signFlowsInfoHclc);
//
//
// //发送http请求
// SignHclcUtils signHclcUtils1 = new SignHclcUtils();
// String stringResult = signHclcUtils1.postString(url, param, headInfo);
//
// //解析返回结果
// jsonResult = JSONObject.parseObject(stringResult);
// signFlowsInfoHclc.setResponseClob(stringResult);
// if (!"0".equalsIgnoreCase(jsonResult.getString("errCode"))) {
// logger.error("create sign flows failed, errCode:{} ,msg:{}", jsonResult.getString("errCode"), jsonResult.getString("msg"));
// } else {
//
// JSONObject data = jsonResult.getJSONObject("data");
// signFlowsInfoHclc.setSignFlowId(data.getString("signFlowId"));
// signFlowsInfoHclc.setReturnCode(jsonResult.getString("errCode"));
// signFlowsInfoHclc.setReturnMsg(jsonResult.getString("msg"));
//
// //解析返回签署信息集合,替换accountId为用户信息
// JSONArray signUrls = data.getJSONArray("signUrls");
// for (int i = 0; i < signUrls.size(); i++) {
// JSONObject signUrl = signUrls.getJSONObject(i);
//
// //建机自己
// if ("0d83cfe0-4d86-11ea-b71a-b8599f3574b6".equalsIgnoreCase(signUrl.getString("accountId"))) {
// signUrl.put("name", "日立建机");
// } else {
// //根据uniqueId获取用户信息
// SignUserInfoHclc signInfoHclc = new SignUserInfoHclc();
// signInfoHclc.setOpenId(signUrl.getString("uniqueId"));
// signInfoHclc = this.selectByPrimaryKey(requestContext, signInfoHclc);
//
// signUrl.put("idNo", signInfoHclc.getIdNo());
// signUrl.put("name", signInfoHclc.getName());
// }
//
//
// signUrl.remove("accountId");
// signUrl.remove("accountName");
//
// }
// }
//
// } catch (Exception e) {
// logger.error("create sign flows failed, msg:{}", e.getMessage());
// jsonResult.put("errCode", "000004");
// jsonResult.put("msg", "创建签署流程失败," + e.getMessage());
// }
//
// if (Objects.nonNull(signFlowsInfoHclc)) {
// iSignFlowsInfoHclcService.updateByPrimaryKey(requestContext, signFlowsInfoHclc);
// }
// return jsonResult;
// }
}
......@@ -10,11 +10,14 @@ import com.hand.app.esignHclc.dto.SignUserInfoHclc;
import com.alibaba.fastjson.JSONObject;
import org.apache.commons.codec.binary.Base64;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.message.BasicHeader;
import org.apache.http.message.BasicNameValuePair;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
......@@ -41,6 +44,8 @@ public class SignHclcUtils {
public static final String APP_ID = "18653557";
public static final String API_KEY = "VD5jNFLsuBQE4vvjTtQoKQtt";
public static final String SECRET_KEY = "Bx1O0kQ7W9YDprTOaLr2MPcPupsn7w7z";
public static final String APPLICATION_JSON = "application/json";
public static final String APPLICATION_FORM_URLENCODED = "application/x-www-form-urlencoded";
public SignHclcUtils() {
}
......@@ -63,24 +68,38 @@ public class SignHclcUtils {
* 向指定URL发送POST方法的请求
*
* @param urls 发送请求的URL
* @param json 请求参数,请求参数应该是 JSON 的形式。
* @param params 请求参数,请求参数应该是 JSON 的形式。
* @return URL 所代表远程资源的响应结果
*/
public String postString(String urls, String json, Map<String, String> headInfo) {
public String postString(String urls, JSONObject params, Map<String, String> headInfo, String contentType) {
HttpClient client = HttpClientBuilder.create().build();
HttpPost post = new HttpPost(urls);
post.setHeader("Content-Type", "application/json");
String result = "";
try {
StringEntity s = new StringEntity(json, "utf-8");
s.setContentEncoding(new BasicHeader("Content-Type", "application/json"));
if (Objects.nonNull(headInfo)) {
for (Map.Entry<String, String> entry : headInfo.entrySet()) {
post.setHeader(entry.getKey(), entry.getValue());
}
}
if (APPLICATION_JSON.equalsIgnoreCase(contentType)) {
String json = params.toString();
StringEntity s = new StringEntity(json, "utf-8");
s.setContentEncoding(new BasicHeader("Content-Type", APPLICATION_JSON));
post.setHeader("Content-Type", APPLICATION_JSON);
post.setEntity(s);
} else if (APPLICATION_FORM_URLENCODED.equalsIgnoreCase(contentType)) {
List<NameValuePair> nameValuePairList = new ArrayList<NameValuePair>();
for (String key : params.keySet()) {
nameValuePairList.add(new BasicNameValuePair(key, params.get(key).toString()));
}
UrlEncodedFormEntity formEntity = new UrlEncodedFormEntity(nameValuePairList, "utf-8");
formEntity.setContentType("application/x-www-form-urlencoded; charset=UTF-8");
post.setEntity(formEntity);
}
HttpResponse httpResponse = client.execute(post);
InputStream inStream = httpResponse.getEntity().getContent();
BufferedReader reader = new BufferedReader(new InputStreamReader(inStream, "utf-8"));
......@@ -106,6 +125,51 @@ public class SignHclcUtils {
}
}
// public String postFormUrlEncoded(String url, JSONObject params, Map<String, String> headInfo) {
// HttpClient httpClient = HttpClientBuilder.create().build();
// HttpPost post = new HttpPost(url);
// String result = "";
// try {
// if (Objects.nonNull(headInfo)) {
// for (Map.Entry<String, String> entry : headInfo.entrySet()) {
// post.setHeader(entry.getKey(), entry.getValue());
// }
// }
// if (params != null) {
// List<NameValuePair> nameValuePairList = new ArrayList<NameValuePair>();
// for (String key : params.keySet()) {
// nameValuePairList.add(new BasicNameValuePair(key, params.get(key).toString()));
// }
// UrlEncodedFormEntity formEntity = new UrlEncodedFormEntity(nameValuePairList, "utf-8");
// formEntity.setContentType("application/x-www-form-urlencoded; charset=UTF-8");
// post.setEntity(formEntity);
// }
//
// HttpResponse httpResponse = httpClient.execute(post);
// InputStream inStream = httpResponse.getEntity().getContent();
// BufferedReader reader = new BufferedReader(new InputStreamReader(inStream, "utf-8"));
// StringBuilder strber = new StringBuilder();
// String line = null;
//
// while ((line = reader.readLine()) != null) {
// strber.append(line + "\n");
// }
//
// inStream.close();
// result = strber.toString();
// if (httpResponse.getStatusLine().getStatusCode() == 200) {
// System.out.println("请求服务器成功");
// } else {
// System.out.println("请求服务端失败");
// }
//
// return result;
// } catch (Exception var12) {
// var12.printStackTrace();
// throw new RuntimeException(var12);
// }
// }
public String getJSON(String url) {
try {
URL thisurl = new URL(url);
......@@ -184,7 +248,7 @@ public class SignHclcUtils {
* @param param 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。
* @return URL 所代表远程资源的响应结果
*/
public static String getStr(String url, String param) {
public static String getStr(String url, String param, Map<String, String> headInfo) {
String result = "";
BufferedReader in = null;
try {
......@@ -196,6 +260,13 @@ public class SignHclcUtils {
connection.setRequestProperty("accept", "*/*");
connection.setRequestProperty("connection", "Keep-Alive");
connection.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
if (Objects.nonNull(headInfo)) {
for (Map.Entry<String, String> entry : headInfo.entrySet()) {
connection.setRequestProperty(entry.getKey(), entry.getValue());
}
}
// 建立实际的连接
connection.connect();
// 获取所有响应头字段
......@@ -236,7 +307,7 @@ public class SignHclcUtils {
try {
SignHclcUtils signHclcUtils = new SignHclcUtils();
String param = "appId=" + appId + "&secret=" + secret + "&grantType=client_credentials";
String stringResult = signHclcUtils.getStr(faceApiUrl, param);
String stringResult = signHclcUtils.getStr(faceApiUrl, param, null);
JSONObject json2 = JSONObject.parseObject(stringResult);
if ("0".equalsIgnoreCase(json2.getString("code"))) {
JSONObject data = json2.getJSONObject("data");
......
......@@ -27,6 +27,7 @@
<result column="AUTH_AGENT_ACCOUNT_ID" property="authAgentAccountId" jdbcType="VARCHAR"/>
<result column="ORG_ATTACHMENT_ID" property="orgAttachmentId" jdbcType="VARCHAR"/>
<result column="AUTH_FLAG" property="authFlag" jdbcType="VARCHAR"/>
<result column="SEAL_ID" property="sealId" jdbcType="VARCHAR"/>
</resultMap>
<select id="queryUserInfo" resultMap="BaseResultMap" parameterType="com.hand.app.esignHclc.dto.SignUserInfoHclc">
......@@ -34,19 +35,19 @@
from SIGN_USER_INFO_HCLC
<where>
<if test="openId != null">
and OPEN_ID = #{openId,jdbcType=DECIMAL}
and open_id = #{openId,jdbcType=DECIMAL}
</if>
<if test="idNo != null">
and ID_NO = #{idNo,jdbcType=VARCHAR}
and id_no = #{idNo,jdbcType=VARCHAR}
</if>
<if test="name != null">
and name = #{NAME,jdbcType=VARCHAR}
and name = #{name,jdbcType=VARCHAR}
</if>
<if test="accountId != null">
and nvl(ACCOUNT_ID,'N') = #{accountId,jdbcType=VARCHAR}
and nvl(account_id,'N') = #{accountId,jdbcType=VARCHAR}
</if>
<if test="authFlag != null">
and nvl(AUTH_FLAG,'N') = #{authFlag,jdbcType=VARCHAR}
and nvl(auth_flag,'N') = #{authFlag,jdbcType=VARCHAR}
</if>
</where>
order by account_id
......
......@@ -122,6 +122,10 @@ tsign.face.api.appId=4438798562
tsign.face.api.secret=4024c2b5e503a84da6d126fdc6f0da81
#认证结果通知地址
tsign.api.notifyUrl=http://101.133.225.167/core/api/public/listen/auth/result
#签署结果通知地址
tsign.api.listenSignUrl=http://101.133.225.167/core/api/public/listen/sign/flow
#签署完成跳转地址
tsign.api.signRedirectUrl=http://sign.hitachics.com/www/#/ElectronicContract
#微信公众号apiKey
wx.apiKey=handexinxi
#微信公众号接口地址
......
......@@ -10,19 +10,19 @@ redis.useSentinel=false
redis.ip=localhost
redis.port=6379
redis.db=10
#redis.password=123456
redis.db=7
db.jndiName=java:comp/env/jdbc/hls_support
db.jndiName=java:comp/env/jdbc/dr_app_dev
# db.type property is used for activiti
db.type=mysql
#db.type=oracle
#db.type=mysql
db.type=oracle
#db.type=mssql
#db.type=hana
mybatis.identity=JDBC
#mybatis.identity=SEQUENCE
#mybatis.identity=JDBC
mybatis.identity=SEQUENCE
# environment
env.code=SIT
......@@ -97,11 +97,10 @@ ureport.fileStoreDir=
wx.token=fdbiabwehuiv
#企业号
qy.wx.token=YDQFbrP4wAdA5TTSBxSCKk
qy.wx.encodingAESKey=RuGAoQ7DHt0GdV9OkCLqYbzNBhDbiuuUiUskeltdcYK
qy.wx.corpId=ww77bcfe6939a185fe
qy.wx.corpSecret=pj0kw409qsMX6DnWF6iUYwhCQOom5oE7B7sAgHazHX4
qy.wx.token=cjndksabebubcjd
qy.wx.encodingAESKey=z2W9lyOAR1XjY8mopEmiSqib0TlBZzCFiCLp6IdS2Iv
qy.wx.corpId=ww4ca7a88ea2843535
qy.wx.corpSecret=tE3QJtYf89IsdlF99wZyo_QKEbb7lRFsJuIiuk8YOJ8
## end
......@@ -110,21 +109,31 @@ domain=http://localhost:8070/core/
#set task size
thread.taskSize = 5
markImgPath = C:/Users/����/Desktop/test9.png
#esign dev
tsign.project.id=1111563517
tsign.project.secret=95439b0863c241c63a861b87d1e647b7
tsign.api.url=http://121.40.164.61:8080/tgmonitor/rest/app!getAPIInfo2
#esignHclc
tsign.project.id=1000029
tsign.project.secret=2e66a86bbc6fa9000d4a5f272cbc70e1
#e签宝地址
tsign.api.url=http://139.196.17.22:8035
#用户认证地址
tsign.face.api.url=https://smlopenapi.esign.cn
#用户认证用户
tsign.face.api.appId=4438798562
#用户认证密码
tsign.face.api.secret=4024c2b5e503a84da6d126fdc6f0da81
#认证结果通知地址
tsign.api.notifyUrl=http://101.133.225.167/core/api/public/listen/auth/result
#签署结果通知地址
tsign.api.listenSignUrl=http://101.133.225.167/core/api/public/listen/sign/flow
#签署完成跳转地址
tsign.api.signRedirectUrl=http://sign.hitachics.com/www/#/ElectronicContract
#微信公众号apiKey
wx.apiKey=handexinxi
#微信公众号接口地址
wx.apiHttpUrl=https://wxgzh.hitachics.com/hcs-public-server/internal/third/
#微信服务器图片保存中台路径
wx.image.path = D:\\app_dev\\apache-tomcat-app\\app_file
#esign
#tsign.project.id=1111565057
#tsign.project.secret=cf74f42ab268ae0b31ba2ee98e84bab5
#tsign.api.url=http://openapi.tsign.cn:8080/tgmonitor/rest/app!getAPIInfo2
#aliyun
aliyun.accessKeyId=LTAI4BKXkUQW1jVY
aliyun.accessKeySecret=TlaBwgHASAshVfPX6jMWgQahx9epse
face.check.enable=false
......
......@@ -10,19 +10,19 @@ redis.useSentinel=false
redis.ip=localhost
redis.port=6379
redis.db=10
#redis.password=123456
redis.db=7
db.jndiName=java:comp/env/jdbc/hls_support
db.jndiName=java:comp/env/jdbc/dr_app_dev
# db.type property is used for activiti
db.type=mysql
#db.type=oracle
#db.type=mysql
db.type=oracle
#db.type=mssql
#db.type=hana
mybatis.identity=JDBC
#mybatis.identity=SEQUENCE
#mybatis.identity=JDBC
mybatis.identity=SEQUENCE
# environment
env.code=SIT
......@@ -97,11 +97,10 @@ ureport.fileStoreDir=
wx.token=fdbiabwehuiv
#企业号
qy.wx.token=YDQFbrP4wAdA5TTSBxSCKk
qy.wx.encodingAESKey=RuGAoQ7DHt0GdV9OkCLqYbzNBhDbiuuUiUskeltdcYK
qy.wx.corpId=ww77bcfe6939a185fe
qy.wx.corpSecret=pj0kw409qsMX6DnWF6iUYwhCQOom5oE7B7sAgHazHX4
qy.wx.token=cjndksabebubcjd
qy.wx.encodingAESKey=z2W9lyOAR1XjY8mopEmiSqib0TlBZzCFiCLp6IdS2Iv
qy.wx.corpId=ww4ca7a88ea2843535
qy.wx.corpSecret=tE3QJtYf89IsdlF99wZyo_QKEbb7lRFsJuIiuk8YOJ8
## end
......@@ -110,21 +109,31 @@ domain=http://localhost:8070/core/
#set task size
thread.taskSize = 5
markImgPath = C:/Users/����/Desktop/test9.png
#esign dev
tsign.project.id=1111563517
tsign.project.secret=95439b0863c241c63a861b87d1e647b7
tsign.api.url=http://121.40.164.61:8080/tgmonitor/rest/app!getAPIInfo2
#esignHclc
tsign.project.id=1000029
tsign.project.secret=2e66a86bbc6fa9000d4a5f272cbc70e1
#e签宝地址
tsign.api.url=http://139.196.17.22:8035
#用户认证地址
tsign.face.api.url=https://smlopenapi.esign.cn
#用户认证用户
tsign.face.api.appId=4438798562
#用户认证密码
tsign.face.api.secret=4024c2b5e503a84da6d126fdc6f0da81
#认证结果通知地址
tsign.api.notifyUrl=http://101.133.225.167/core/api/public/listen/auth/result
#签署结果通知地址
tsign.api.listenSignUrl=http://101.133.225.167/core/api/public/listen/sign/flow
#签署完成跳转地址
tsign.api.signRedirectUrl=http://sign.hitachics.com/www/#/ElectronicContract
#微信公众号apiKey
wx.apiKey=handexinxi
#微信公众号接口地址
wx.apiHttpUrl=https://wxgzh.hitachics.com/hcs-public-server/internal/third/
#微信服务器图片保存中台路径
wx.image.path = D:\\app_dev\\apache-tomcat-app\\app_file
#esign
#tsign.project.id=1111565057
#tsign.project.secret=cf74f42ab268ae0b31ba2ee98e84bab5
#tsign.api.url=http://openapi.tsign.cn:8080/tgmonitor/rest/app!getAPIInfo2
#aliyun
aliyun.accessKeyId=LTAI4BKXkUQW1jVY
aliyun.accessKeySecret=TlaBwgHASAshVfPX6jMWgQahx9epse
face.check.enable=false
......
......@@ -10,19 +10,19 @@ redis.useSentinel=false
redis.ip=localhost
redis.port=6379
redis.db=10
#redis.password=123456
redis.db=7
db.jndiName=java:comp/env/jdbc/hls_support
db.jndiName=java:comp/env/jdbc/dr_app_dev
# db.type property is used for activiti
db.type=mysql
#db.type=oracle
#db.type=mysql
db.type=oracle
#db.type=mssql
#db.type=hana
mybatis.identity=JDBC
#mybatis.identity=SEQUENCE
#mybatis.identity=JDBC
mybatis.identity=SEQUENCE
# environment
env.code=SIT
......@@ -97,10 +97,10 @@ ureport.fileStoreDir=
wx.token=fdbiabwehuiv
#企业号
qy.wx.token=YDQFbrP4wAdA5TTSBxSCKk
qy.wx.encodingAESKey=RuGAoQ7DHt0GdV9OkCLqYbzNBhDbiuuUiUskeltdcYK
qy.wx.corpId=ww77bcfe6939a185fe
qy.wx.corpSecret=pj0kw409qsMX6DnWF6iUYwhCQOom5oE7B7sAgHazHX4
qy.wx.token=cjndksabebubcjd
qy.wx.encodingAESKey=z2W9lyOAR1XjY8mopEmiSqib0TlBZzCFiCLp6IdS2Iv
qy.wx.corpId=ww4ca7a88ea2843535
qy.wx.corpSecret=tE3QJtYf89IsdlF99wZyo_QKEbb7lRFsJuIiuk8YOJ8
## end
......@@ -109,21 +109,31 @@ domain=http://localhost:8070/core/
#set task size
thread.taskSize = 5
markImgPath = C:/Users/����/Desktop/test9.png
#esignHclc
tsign.project.id=1000029
tsign.project.secret=2e66a86bbc6fa9000d4a5f272cbc70e1
#e签宝地址
tsign.api.url=http://139.196.17.22:8035
#用户认证地址
tsign.face.api.url=https://smlopenapi.esign.cn
#用户认证用户
tsign.face.api.appId=4438798562
#用户认证密码
tsign.face.api.secret=4024c2b5e503a84da6d126fdc6f0da81
#认证结果通知地址
tsign.api.notifyUrl=http://101.133.225.167/core/api/public/listen/auth/result
#签署结果通知地址
tsign.api.listenSignUrl=http://101.133.225.167/core/api/public/listen/sign/flow
#签署完成跳转地址
tsign.api.signRedirectUrl=http://sign.hitachics.com/www/#/ElectronicContract
#微信公众号apiKey
wx.apiKey=handexinxi
#微信公众号接口地址
wx.apiHttpUrl=https://wxgzh.hitachics.com/hcs-public-server/internal/third/
#微信服务器图片保存中台路径
wx.image.path = D:\\app_dev\\apache-tomcat-app\\app_file
#esign dev
tsign.project.id=1111563517
tsign.project.secret=95439b0863c241c63a861b87d1e647b7
tsign.api.url=http://121.40.164.61:8080/tgmonitor/rest/app!getAPIInfo2
#esign
#tsign.project.id=1111565057
#tsign.project.secret=cf74f42ab268ae0b31ba2ee98e84bab5
#tsign.api.url=http://openapi.tsign.cn:8080/tgmonitor/rest/app!getAPIInfo2
#aliyun
aliyun.accessKeyId=LTAI4BKXkUQW1jVY
aliyun.accessKeySecret=TlaBwgHASAshVfPX6jMWgQahx9epse
face.check.enable=false
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment