1、封装阿里健康入参和返回 设计成通用方式后面再加个新接口比较方便

2、供应商增加码上放心企业信息增加阿里健康需要的信息
3、提供一个方法新增这个供应商的code阿里健康关联的所有关联关系存储
dev_unify
qiuyt 11 months ago
parent 6188451289
commit 634775a6c8

@ -220,7 +220,7 @@
<dependency> <dependency>
<groupId>cn.hutool</groupId> <groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId> <artifactId>hutool-all</artifactId>
<version>5.8.18</version> <version>5.8.33</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>com.belerweb</groupId> <groupId>com.belerweb</groupId>
@ -393,6 +393,13 @@
<artifactId>easyexcel</artifactId> <artifactId>easyexcel</artifactId>
<version>2.2.10</version> <version>2.2.10</version>
</dependency> </dependency>
<dependency>
<groupId>com.anthony</groupId>
<artifactId>alicode</artifactId>
<version>1.0</version>
<scope>system</scope>
<systemPath>${pom.basedir}/src/main/resources/lib/alicode-1.0.jar</systemPath>
</dependency>
</dependencies> </dependencies>
<build> <build>

@ -1,6 +1,7 @@
package com.glxp.api.controller.sup; package com.glxp.api.controller.sup;
import cn.hutool.core.bean.BeanUtil; import cn.hutool.core.bean.BeanUtil;
import cn.hutool.http.HttpUtil;
import com.github.pagehelper.PageInfo; import com.github.pagehelper.PageInfo;
import com.glxp.api.annotation.AuthRuleAnnotation; import com.glxp.api.annotation.AuthRuleAnnotation;
import com.glxp.api.annotation.Log; import com.glxp.api.annotation.Log;
@ -12,16 +13,22 @@ import com.glxp.api.dto.DictDto;
import com.glxp.api.entity.auth.*; import com.glxp.api.entity.auth.*;
import com.glxp.api.entity.purchase.CustomerContactEntity; import com.glxp.api.entity.purchase.CustomerContactEntity;
import com.glxp.api.entity.system.CompanyEntity; import com.glxp.api.entity.system.CompanyEntity;
import com.glxp.api.req.alihealth.AlihealthKytGetentinfoReqeust;
import com.glxp.api.req.auth.CustomerInfoFilterRequest; import com.glxp.api.req.auth.CustomerInfoFilterRequest;
import com.glxp.api.req.system.DeleteRequest; import com.glxp.api.req.system.DeleteRequest;
import com.glxp.api.res.PageSimpleResponse; import com.glxp.api.res.PageSimpleResponse;
import com.glxp.api.res.alihealth.AlihealthKytGetentinfoResponse;
import com.glxp.api.res.alihealth.AlihealthKytSinglerelationResponse;
import com.glxp.api.service.auth.AuthAdminService; import com.glxp.api.service.auth.AuthAdminService;
import com.glxp.api.service.auth.AuthRoleAdminService; import com.glxp.api.service.auth.AuthRoleAdminService;
import com.glxp.api.service.auth.CustomerInfoService; import com.glxp.api.service.auth.CustomerInfoService;
import com.glxp.api.service.purchase.CustomerContactService; import com.glxp.api.service.purchase.CustomerContactService;
import com.glxp.api.service.system.CompanyService; import com.glxp.api.service.system.CompanyService;
import com.glxp.api.util.alihealth.AlihealthUtils;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.BeanUtils; import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.validation.BindingResult; import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.PostMapping;
@ -32,6 +39,7 @@ import javax.annotation.Resource;
import javax.validation.Valid; import javax.validation.Valid;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Map;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@RestController @RestController
@ -50,7 +58,10 @@ public class CustomerController {
private AuthAdminService authAdminService; private AuthAdminService authAdminService;
@Resource @Resource
private AuthRoleAdminService authRoleAdminService; private AuthRoleAdminService authRoleAdminService;
@Resource
private AlihealthUtils alihealthUtils;
@Value("${ALIHEALTH_URL:http://gw.api.taobao.com/router/rest}")
private String alihealthUrl;
@AuthRuleAnnotation("") @AuthRuleAnnotation("")
@GetMapping("/spms/customer/list") @GetMapping("/spms/customer/list")
public BaseResponse filterCustomers(CustomerInfoFilterRequest customerFilterRequest) { public BaseResponse filterCustomers(CustomerInfoFilterRequest customerFilterRequest) {
@ -207,5 +218,33 @@ public class CustomerController {
return ResultVOUtils.success("删除成功"); return ResultVOUtils.success("删除成功");
} }
@AuthRuleAnnotation("")
@PostMapping("salewarehouse/customer/restAssuredOnCodeAdd")
@Log(title = "客户信息-码上放心企业信息修改", businessType = BusinessType.UPDATE)
public BaseResponse restAssuredOnCodeAdd(@RequestBody CustomerInfoEntity customerInfoEntity) {
AlihealthKytGetentinfoResponse alihealthKytGetentinfoResponse =null;
try {
AlihealthKytGetentinfoReqeust alihealthKytGetentinfoReqeust = new AlihealthKytGetentinfoReqeust();
alihealthKytGetentinfoReqeust.setApp_key(customerInfoEntity.getAppKey());
alihealthKytGetentinfoReqeust.setEnt_name(customerInfoEntity.getCustomerName());
Map map = alihealthUtils.disposeSign(alihealthKytGetentinfoReqeust,customerInfoEntity.getAppSecret());
String json = HttpUtil.get(alihealthUrl,map);
alihealthKytGetentinfoResponse =new AlihealthKytGetentinfoResponse(json);
}catch (Exception e){
return ResultVOUtils.error("阿里健康接口调用失败===请检查key和密文");
}
if(StringUtils.isNotEmpty(alihealthKytGetentinfoResponse.getMsg_info())
&& alihealthKytGetentinfoResponse.getMsg_info().equals("调用成功")
){
customerInfoEntity.setRefEntId(alihealthKytGetentinfoResponse.getRef_ent_id());
customerInfoService.updateCustomerInfo(customerInfoEntity);
}else {
return ResultVOUtils.error("阿里健康接口调用失败==="+alihealthKytGetentinfoResponse.getMsg_info());
}
return ResultVOUtils.success("码上放心企业信息修改成功");
}
} }

@ -0,0 +1,20 @@
package com.glxp.api.controller.test;
import com.glxp.api.common.res.BaseResponse;
import com.glxp.api.util.alihealth.AlihealthUtils;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
@RestController
public class TestCodeController {
@Resource
private AlihealthUtils alihealthUtils;
@PostMapping("/test")
public BaseResponse test() {
return alihealthUtils.relCodeInsert("73157692795424", "88979920013901715365");
}
}

@ -4,13 +4,14 @@ import com.glxp.api.entity.auth.AliKeyEntity;
import com.glxp.api.entity.system.CompanyEntity; import com.glxp.api.entity.system.CompanyEntity;
import com.glxp.api.req.auth.FilterCompanyRequest; import com.glxp.api.req.auth.FilterCompanyRequest;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List; import java.util.List;
@Mapper @Mapper
public interface CompanyDao { public interface CompanyDao {
CompanyEntity findCompany(String CustomerId); CompanyEntity findCompany(@Param("customerId") String CustomerId);
CompanyEntity findCompanyByName(String companyName); CompanyEntity findCompanyByName(String companyName);

@ -18,5 +18,8 @@ public class CustomerInfoEntity {
private int userMax; private int userMax;
private String companyName; private String companyName;
private String appKey;
private String appSecret;
private String refEntId;
} }

@ -76,4 +76,8 @@ public class CompanyEntity {
private String auditStatusList; private String auditStatusList;
private String alihealthAppKey;
private String alihealthAppSecret;
private String alihealthRefEntId;
} }

@ -0,0 +1,57 @@
package com.glxp.api.req.alihealth;
import lombok.Data;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
*
*/
@Data
public class AlihealthKytCommonParametersReqeust {
/**
* API
*/
private String method;
/**
* key
*/
private String app_key;
/**
*
*/
private String session;
/**
*
*/
private String timestamp;
/**
*
*/
private String v;
/**
*
*/
private String sign_method;
/**
*
*/
private String sign;
/**
*
*/
private String format;
// /**
// * 精简开关
// */
// private boolean simplify;
public AlihealthKytCommonParametersReqeust(){
this.timestamp = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
this.v = "2.0";
this.sign_method = "md5";
this.format = "json";
}
}

@ -0,0 +1,11 @@
package com.glxp.api.req.alihealth;
import lombok.Data;
@Data
public class AlihealthKytGetentinfoReqeust extends AlihealthKytCommonParametersReqeust {
private String ent_name;
public AlihealthKytGetentinfoReqeust(){
this.setMethod("alibaba.alihealth.drug.kyt.getentinfo");
}
}

@ -0,0 +1,14 @@
package com.glxp.api.req.alihealth;
import lombok.Data;
@Data
public class AlihealthKytSinglerelationReqeust extends AlihealthKytCommonParametersReqeust {
private String ref_ent_id;
private String des_ref_ent_id;
private String code;
public AlihealthKytSinglerelationReqeust(){
this.setMethod("alibaba.alihealth.drug.kyt.singlerelation");
}
}

@ -0,0 +1,19 @@
package com.glxp.api.res.alihealth;
import cn.hutool.json.JSONObject;
import com.alibaba.fastjson.JSONArray;
import lombok.Data;
import org.apache.poi.ss.formula.functions.T;
import java.util.Map;
@Data
public class AlihealthKytCommonParametersResponse {
private String msg_code;
private String msg_info;
private String response_success;
}

@ -0,0 +1,47 @@
package com.glxp.api.res.alihealth;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.json.JSONArray;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import lombok.Data;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.BeanUtils;
import java.util.Objects;
@Data
public class AlihealthKytGetentinfoResponse extends AlihealthKytCommonParametersResponse{
private String ent_id;
private String network_type;
private String ref_ent_id;
public AlihealthKytGetentinfoResponse(String json) {
// 初始化请求的值
cn.hutool.json.JSONObject jsonObject = JSONUtil.parseObj(json);
JSONObject jsonObjectResult = null;
for (String s : jsonObject.keySet()) {
jsonObjectResult = jsonObject.getJSONObject(s).getJSONObject("result");
}
AlihealthKytCommonParametersResponse alihealthKytCommonParametersResponse = JSONUtil.toBean(jsonObjectResult.toString(),
AlihealthKytCommonParametersResponse.class);
BeanUtils.copyProperties(alihealthKytCommonParametersResponse,this);
if(StringUtils.isNotEmpty(this.getMsg_info())
&& this.getMsg_info().equals("调用成功")
){
this.disposeResult(jsonObjectResult);
}
}
public void disposeResult(JSONObject jsonObjectResult){
JSONObject jsonObjectModel = jsonObjectResult.getJSONObject("model");
if (!Objects.isNull(jsonObjectModel)) {
this.setEnt_id(jsonObjectModel.getStr("ent_id"));
this.setNetwork_type(jsonObjectModel.getStr("network_type"));
this.setRef_ent_id(jsonObjectModel.getStr("ref_ent_id"));
}
}
}

@ -0,0 +1,148 @@
package com.glxp.api.res.alihealth;
import cn.hutool.Hutool;
import cn.hutool.http.HttpUtil;
import cn.hutool.json.JSONArray;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import com.baomidou.mybatisplus.annotation.TableField;
import com.glxp.api.entity.collect.RelCodeBatch;
import com.glxp.api.entity.collect.RelCodeDetail;
import com.taobao.api.TaobaoObject;
import com.taobao.api.internal.mapping.ApiField;
import com.taobao.api.internal.mapping.ApiListField;
import com.taobao.api.response.AlibabaAlihealthDrugtraceTopLsydQueryRelationResponse;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import org.apache.commons.lang3.StringUtils;
import org.apache.poi.ss.formula.functions.T;
import org.springframework.beans.BeanUtils;
import java.io.Serializable;
import java.util.*;
@Data
public class AlihealthKytSinglerelationResponse extends AlihealthKytCommonParametersResponse{
private JSONObject base_infos_d_t_o;
private String code;
private JSONObject code_active_info_d_t_o;
private JSONObject code_relation_list;
private String is_smallest;
private JSONObject pkg_info_d_t_o;
private JSONObject produce_info_list;
public AlihealthKytSinglerelationResponse(String json) {
// 初始化请求的值
cn.hutool.json.JSONObject jsonObject = JSONUtil.parseObj(json);
JSONObject jsonObjectResult = null;
for (String s : jsonObject.keySet()) {
jsonObjectResult = jsonObject.getJSONObject(s).getJSONObject("result");
}
AlihealthKytCommonParametersResponse alihealthKytCommonParametersResponse = JSONUtil.toBean(jsonObjectResult.toString(),
AlihealthKytCommonParametersResponse.class);
BeanUtils.copyProperties(alihealthKytCommonParametersResponse,this);
if(StringUtils.isNotEmpty(this.getMsg_info())
&& this.getMsg_info().equals("调用成功")
){
this.disposeResult(jsonObjectResult);
}
}
public void disposeResult(JSONObject jsonObjectResult){
JSONArray jsonArray = jsonObjectResult.getJSONObject("model_list").getJSONArray("code_relation_dto");
JSONObject codeRelationDto = (JSONObject) jsonArray.get(0);
if (!Objects.isNull(codeRelationDto)) {
this.setBase_infos_d_t_o(codeRelationDto.getJSONObject("base_infos_d_t_o"));
this.setCode(codeRelationDto.getStr("code"));
this.setCode_active_info_d_t_o(codeRelationDto.getJSONObject("code_active_info_d_t_o"));
this.setCode_relation_list(codeRelationDto.getJSONObject("code_relation_list"));
this.setIs_smallest(codeRelationDto.getStr("is_smallest"));
this.setPkg_info_d_t_o(codeRelationDto.getJSONObject("pkg_info_d_t_o"));
this.setProduce_info_list(codeRelationDto.getJSONObject("produce_info_list"));
}
}
public RelCodeBatch disposeRelCodeBatch(String customerId){
JSONArray jsonArrayBaseInfoDto = this.getBase_infos_d_t_o().getJSONObject("base_info_list").getJSONArray("base_info_dto");
JSONObject jsonObject = (JSONObject) jsonArrayBaseInfoDto.get(0);
RelCodeBatch relCodeBatch = new RelCodeBatch();
List<Map<String, String>> jsonArray = (List) this.getCode_relation_list().get("code_info");
Integer oneLevelCount = 0;
Integer twoLevelCount = 0;
Integer threeLevelCount = 0;
String parentCode = null;
if (jsonArray != null && jsonArray.size() > 0) {
parentCode = jsonArray.get(0).get("parent_code");
relCodeBatch.setCurCode(parentCode);
for (Map<String, String> map : jsonArray) {
switch (map.get("code_level")) {
case "1":
oneLevelCount++;
break;
case "2":
twoLevelCount++;
break;
case "3":
threeLevelCount++;
break;
}
}
}
// relCodeBatch.setId();
relCodeBatch.setProductCode(parentCode);
relCodeBatch.setSubTypeNo(jsonObject.getStr("relation_type"));
relCodeBatch.setCascadeRatio(jsonObject.getStr("pkg_ratio"));
relCodeBatch.setPackageSpec(jsonObject.getStr("pkg_spec"));
// relCodeBatch.setComment();
relCodeBatch.setBatchNo(jsonObject.getStr("produce_batch_no"));
relCodeBatch.setMadeDate(jsonObject.getStr("produce_date"));
relCodeBatch.setValidateDate(jsonObject.getStr("exprie_date"));
relCodeBatch.setWorkShop(jsonObject.getStr("exprie_date"));
// relCodeBatch.setLineName();
relCodeBatch.setLineManager(jsonObject.getStr("oper_ic_name"));
// relCodeBatch.setCreateTime();
// relCodeBatch.setCreateUser();
relCodeBatch.setUpdateTime(new Date());
relCodeBatch.setUpdateUser(customerId);
relCodeBatch.setUploadFlagUp(1);
relCodeBatch.setUploadFlagDown(1);
relCodeBatch.setParentCode(null);
// relCodeBatch.setErpId();
relCodeBatch.setOneLevelCount(oneLevelCount);
relCodeBatch.setTwoLevelCount(twoLevelCount);
relCodeBatch.setThreeLevelCount(threeLevelCount);
return relCodeBatch;
}
public List<RelCodeDetail> disposeRelRodeDetailList(Integer batchIdFk) {
List<RelCodeDetail> list = new ArrayList<>();
List<Map<String, String>> jsonArray = (List) this.getCode_relation_list().get("code_info");
if (jsonArray != null && jsonArray.size() > 0) {
for (Map<String, String> map : jsonArray) {
if (!Objects.isNull(map)) {
RelCodeDetail relCodeDetail = new RelCodeDetail();
relCodeDetail.setCurCode(map.get("code"));
relCodeDetail.setPackLayer(Integer.valueOf(map.get("code_level")));
relCodeDetail.setParentCode(map.get("parent_code"));
Integer flag = null;
switch (map.get("status")) {
case "I":
flag = 1;
break;
case "O":
flag = 0;
break;
}
relCodeDetail.setFlag(flag);
relCodeDetail.setBatchIdFk(batchIdFk);
list.add(relCodeDetail);
}
}
}
return list;
}
}

@ -0,0 +1,191 @@
package com.glxp.api.util.alihealth;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.http.HttpUtil;
import cn.hutool.json.JSONUtil;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.glxp.api.common.res.BaseResponse;
import com.glxp.api.common.util.ResultVOUtils;
import com.glxp.api.dao.collect.RelCodeDetailMapper;
import com.glxp.api.entity.auth.CustomerInfoEntity;
import com.glxp.api.entity.collect.RelCodeBatch;
import com.glxp.api.entity.collect.RelCodeDetail;
import com.glxp.api.req.alihealth.AlihealthKytCommonParametersReqeust;
import com.glxp.api.req.alihealth.AlihealthKytGetentinfoReqeust;
import com.glxp.api.req.alihealth.AlihealthKytSinglerelationReqeust;
import com.glxp.api.res.alihealth.AlihealthKytCommonParametersResponse;
import com.glxp.api.res.alihealth.AlihealthKytGetentinfoResponse;
import com.glxp.api.res.alihealth.AlihealthKytSinglerelationResponse;
import com.glxp.api.service.auth.CustomerInfoService;
import com.glxp.api.service.collect.RelCodeBatchService;
import com.glxp.api.service.collect.RelCodeDetailService;
import com.taobao.api.Constants;
import com.taobao.api.internal.util.StringUtils;
import com.taobao.api.response.AlibabaAlihealthDrugtraceTopLsydQueryRelationResponse;
import io.swagger.models.auth.In;
import org.apache.poi.ss.formula.functions.T;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Transactional;
import javax.annotation.Resource;
import javax.crypto.Mac;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.io.IOException;
import java.security.GeneralSecurityException;
import java.security.MessageDigest;
import java.text.SimpleDateFormat;
import java.util.*;
import static com.taobao.api.internal.util.TaobaoUtils.byte2hex;
@Component
public class AlihealthUtils {
@Resource
private CustomerInfoService customerInfoService;
@Resource
private AlihealthUtils alihealthUtils;
@Resource
private RelCodeDetailService relCodeDetailService;
@Resource
private RelCodeBatchService relCodeBatchService;
@Value("${ALIHEALTH_URL:http://gw.api.taobao.com/router/rest}")
private String alihealthUrl;
// public static void main(String[] args) {
//
// alihealthKytSinglerelationReqeust.setSign(sign);
// String ss = HttpUtil.get("http://gw.api.taobao.com/router/rest",BeanUtil.beanToMap(alihealthKytSinglerelationReqeust));
// AlihealthKytSinglerelationResponse alihealthKytSinglerelationResponse = new AlihealthKytSinglerelationResponse(ss);
// System.out.println(ss);
// System.out.println(alihealthKytSinglerelationResponse);
//
//// AlibabaAlihealthDrugtraceTopLsydQueryRelationResponse alibabaAlihealthDrugtraceTopLsydQueryRelationResponse
//
// }
@Transactional(rollbackFor = Exception.class)
public BaseResponse relCodeInsert(String customerId , String code){
CustomerInfoEntity customerInfoEntity = customerInfoService.selectById(customerId);
AlihealthKytSinglerelationResponse alihealthKytGetentinfoResponse = null;
if(customerInfoEntity != null){
try {
AlihealthKytSinglerelationReqeust alihealthKytSinglerelationReqeust =new AlihealthKytSinglerelationReqeust();
alihealthKytSinglerelationReqeust.setRef_ent_id(customerInfoEntity.getRefEntId());
alihealthKytSinglerelationReqeust.setDes_ref_ent_id(customerInfoEntity.getRefEntId());
alihealthKytSinglerelationReqeust.setCode(code);
alihealthKytSinglerelationReqeust.setApp_key(customerInfoEntity.getAppKey());
Map map = alihealthUtils.disposeSign(alihealthKytSinglerelationReqeust,customerInfoEntity.getAppSecret());
String json = HttpUtil.get(alihealthUrl,map);
alihealthKytGetentinfoResponse =new AlihealthKytSinglerelationResponse(json);
}catch (Exception e){
return ResultVOUtils.error("阿里健康接口调用失败===请检查厂商的key和密文是否对");
}
}
if(org.apache.commons.lang3.StringUtils.isNotEmpty(alihealthKytGetentinfoResponse.getMsg_info())
&& alihealthKytGetentinfoResponse.getMsg_info().equals("调用成功")
){
RelCodeBatch relCodeBatch = alihealthKytGetentinfoResponse.disposeRelCodeBatch( customerId);
RelCodeBatch relCodeBatchOne = relCodeBatchService.getOne(new QueryWrapper<RelCodeBatch>().eq("productCode",relCodeBatch.getProductCode())
.last("limit 1")
);
if(Objects.isNull(relCodeBatchOne)){
relCodeBatch.setCreateUser(customerId);
relCodeBatch.setCreateTime(new Date());
relCodeBatchService.save(relCodeBatch);
}else {
relCodeBatchService.update(relCodeBatch,new QueryWrapper<RelCodeBatch>().eq("productCode",relCodeBatch.getProductCode()));
}
Integer id = Objects.isNull(relCodeBatch.getId()) ? relCodeBatchOne.getId() :relCodeBatch.getId();
// 进行查询
List<RelCodeDetail> list = alihealthKytGetentinfoResponse.disposeRelRodeDetailList(id);
if(list!=null && list.size()>0){
List curCodeList = new ArrayList();
for (RelCodeDetail relCodeDetail : list) {
curCodeList.add(relCodeDetail.getCurCode());
}
relCodeDetailService.remove(new QueryWrapper<RelCodeDetail>().in("curCode",curCodeList));
relCodeDetailService.saveBatch(list);
}
}else {
return ResultVOUtils.error("阿里健康接口调用失败==="+alihealthKytGetentinfoResponse.getMsg_info());
}
return ResultVOUtils.success("码关联关系获取成功");
}
public Map disposeSign(AlihealthKytCommonParametersReqeust alihealthKytCommonParametersReqeust, String secret){
Map map = BeanUtil.beanToMap(alihealthKytCommonParametersReqeust);
String sign;
try {
sign = new AlihealthUtils().signTopRequest(map, secret, "md5");
alihealthKytCommonParametersReqeust.setSign(sign);
return BeanUtil.beanToMap(alihealthKytCommonParametersReqeust);
} catch (IOException e) {
}
return null;
}
public String signTopRequest(Map<String, String> params, String secret, String signMethod) throws IOException {
// 第一步:检查参数是否已经排序
String[] keys = params.keySet().toArray(new String[0]);
Arrays.sort(keys);
// 第二步:把所有参数名和参数值串在一起
StringBuilder query = new StringBuilder();
if (Constants.SIGN_METHOD_MD5.equals(signMethod)) { //签名的摘要算法可选值为hmacmd5hmac-sha256
query.append(secret);
}
for (String key : keys) {
String value = params.get(key);
if (StringUtils.areNotEmpty(key, value)) {
query.append(key).append(value);
}
}
// 第三步使用MD5/HMAC加密
byte[] bytes;
if (Constants.SIGN_METHOD_HMAC.equals(signMethod)) {
bytes = encryptHMAC(query.toString(), secret);
} else {
query.append(secret);
bytes = encryptMD5(query.toString());
}
// 第四步:把二进制转化为大写的十六进制(正确签名应该为32大写字符串此方法需要时使用)
return byte2hex(bytes);
}
public byte[] encryptHMAC(String data, String secret) throws IOException {
byte[] bytes = null;
try {
SecretKey secretKey = new SecretKeySpec(secret.getBytes(Constants.CHARSET_UTF8), "HmacMD5");
Mac mac = Mac.getInstance(secretKey.getAlgorithm());
mac.init(secretKey);
bytes = mac.doFinal(data.getBytes(Constants.CHARSET_UTF8));
} catch (GeneralSecurityException gse) {
throw new IOException(gse.toString());
}
return bytes;
}
public byte[] encryptMD5(String data) throws IOException {
return encryptMD5(data.getBytes(Constants.CHARSET_UTF8));
}
public byte[] encryptMD5(byte[] data) throws IOException {
byte[] bytes = null;
try {
MessageDigest md = MessageDigest.getInstance("MD5");
bytes = md.digest(data);
} catch (GeneralSecurityException gse) {
throw new IOException(gse.toString());
}
return bytes;
}
}

@ -95,6 +95,10 @@
<if test="roleId != null">roleId=#{roleId},</if> <if test="roleId != null">roleId=#{roleId},</if>
<if test="userMax != null">userMax=#{userMax},</if> <if test="userMax != null">userMax=#{userMax},</if>
<if test="companyName != null">companyName=#{companyName},</if> <if test="companyName != null">companyName=#{companyName},</if>
<if test="appKey != null">appKey=#{appKey},</if>
<if test="appSecret != null">appSecret=#{appSecret},</if>
<if test="refEntId != null">refEntId=#{refEntId},</if>
</set> </set>
WHERE customerId=#{customerId} WHERE customerId=#{customerId}
</update> </update>

@ -6,9 +6,10 @@
<select id="findCompany" parameterType="java.lang.String" <select id="findCompany" parameterType="java.lang.String"
resultType="com.glxp.api.entity.system.CompanyEntity"> resultType="com.glxp.api.entity.system.CompanyEntity">
SELECT * SELECT * ,b.appKey as alihealthAppKey,b.appSecret as alihealthAppSecret,b.refEntId as alihealthRefEntId
FROM sup_company FROM sup_company a left join
where customerId = #{CustomerId} customer_info b on a.customerId = b.customerId
where a.customerId = #{customerId}
</select> </select>

@ -1197,3 +1197,13 @@ CALL Pro_Temp_ColumnWork('sync_data_set', 'drugDataTask',
CALL Pro_Temp_ColumnWork('sys_custom_config_detail', 'isImport', CALL Pro_Temp_ColumnWork('sys_custom_config_detail', 'isImport',
' tinyint NULL DEFAULT NULL COMMENT ''是否常用搜索01''', ' tinyint NULL DEFAULT NULL COMMENT ''是否常用搜索01''',
1); 1);
CALL Pro_Temp_ColumnWork('customer_info', 'appKey',
' appKey varchar(255) DEFAULT NULL COMMENT ''应用Key''',
1);
CALL Pro_Temp_ColumnWork('customer_info', 'appSecret',
' appSecret varchar(255) DEFAULT NULL COMMENT ''应用密文''',
1);
CALL Pro_Temp_ColumnWork('customer_info', 'refEntId',
' refEntId varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT ''接口调用企业的唯一标识''',
1);

Loading…
Cancel
Save