123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- package com.uas.eis;
- import com.uas.eis.dao.*;
- import com.uas.eis.entity.sf.*;
- import com.uas.eis.service.ERPService;
- import com.uas.eis.utils.*;
- import org.junit.Test;
- import org.junit.runner.RunWith;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.boot.test.context.SpringBootTest;
- import org.springframework.test.context.junit4.SpringRunner;
- import com.sf.csim.express.service.CallExpressServiceTools;
- import com.sf.csim.express.service.HttpClientUtil;
- import com.sf.csim.express.service.IServiceCodeStandard;
- import com.sf.csim.express.service.code.ExpressServiceCodeEnum;
- import java.io.UnsupportedEncodingException;
- import java.util.*;
- @RunWith(SpringRunner.class)
- @SpringBootTest(classes = {UasEisApplication.class})
- public class UasEisApplicationTests {
- @Autowired
- private BaseDao baseDao;
- @Autowired
- private ERPService erpService;
- /**
- 丰桥新沙箱测试顾客编码 Yg4Zf06w_sxZs3A5D
- 校验码 3Xdk1jqeG1Xod9nUXus8Op7DNOkchTnw
- **/
- private static final String CLIENT_CODE = "JYXKJWFFJ88E"; //此处替换为您在丰桥平台获取的顾客编码
- //此处替换为您在丰桥平台获取的校验码
- private static final String CHECK_WORD_PROD = "GgO0UoyQ5FssNLItii3olo63bQ80ErAE"; //生产校验码
- private static final String CHECK_WORD_BOX ="rMBhSYRa9OtUPkfX5mow01NlxDWtI411";//沙箱校验码
- //沙箱环境的地址 -PRO
- private static final String CALL_URL_BOX = "https://sfapi-sbox.sf-express.com/std/service";
- //生产环境的地址 -PRO
- private static final String CALL_URL_PROD = "https://sfapi.sf-express.com/std/service";
- @Test
- public void TestApi() throws UnsupportedEncodingException {
- /**ExpressServiceCodeEnum 对应速运类-快递APIs
- POSTServiceCodeEnum 对应速运类-驿站APIs
- YJTServiceCodeEnum 对应解决方案-医寄通APIs
- EPSServiceCodeEnum 对应解决方案-快递管家APIs
- HZTServiceCodeEnum 对应解决方案-函证通APIs 2022-2-24 新增
- 详情见code目录下枚举类,客户可自行修改引用的该类
- **/
- IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_CREATE_ORDER; //下订单
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_SEARCH_ORDER_RESP; //查订单
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_UPDATE_ORDER;//订单取消
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_FILTER_ORDER_BSP;//订单筛选
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_SEARCH_ROUTES;//查路由
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_GET_SUB_MAILNO;//子单号
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_QUERY_SFWAYBILL;//查运费
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_REGISTER_ROUTE;//注册路由
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_CREATE_REVERSE_ORDER;//退货下单
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_CANCEL_REVERSE_ORDER;//退货消单
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_WANTED_INTERCEPT;//截单转寄
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_QUERY_DELIVERTM;//时效标准及价格查询
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.COM_RECE_CLOUD_PRINT_WAYBILLS;//面单打印
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_UPLOAD_ROUTE;//路由上传
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_SEARCH_PROMITM;//预计派送时间查询
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_EXCE_CHECK_PICKUP_TIME;//揽件服务时间查询
- // IServiceCodeStandard standardService = ExpressServiceCodeEnum.EXP_RECE_VALIDATE_WAYBILLNO;//运单号合法性校验
- CallExpressServiceTools tools=CallExpressServiceTools.getInstance();
- Map<String, String> params = new HashMap<String, String>();
- String timeStamp = String.valueOf(System.currentTimeMillis());
- String msgData = tools.packageMsgData(standardService);
- SFCreatOrderReq sfOrder = new SFCreatOrderReq();
- sfOrder.setOrderId("SD24090018-2");
- sfOrder.setMonthlyCard("7551234567");
- // 1,寄件方信息 2,到件方信息
- List<SFContactInfo> contactInfoList = new ArrayList<>();
- SFContactInfo sendInfo = new SFContactInfo();
- sendInfo.setContactType(1);
- sendInfo.setCompany("深圳市佳毅兴科技有限公司");
- sendInfo.setContact("窦慧怡");
- sendInfo.setMobile("18128820006");
- sendInfo.setAddress("广东省深圳市宝安区大宝路51号新柯城业园1栋5楼");
- contactInfoList.add(sendInfo);
- SFContactInfo receiveInfo = new SFContactInfo();
- receiveInfo.setContactType(2);
- receiveInfo.setCompany("深圳市豪锦瑞科技有限公司");
- receiveInfo.setContact("刘洋");
- receiveInfo.setMobile("18688770976");
- receiveInfo.setAddress("深圳市宝安区71区万源商务大厦B栋606");
- contactInfoList.add(receiveInfo);
- sfOrder.setContactInfoList(contactInfoList);
- List<SFCargoDetail> cargoDetails = new ArrayList<>();
- sfOrder.setCargoDetails(cargoDetails);
- msgData = FlexJsonUtil.toJsonDeep(sfOrder);
- params.put("partnerID", CLIENT_CODE); // 顾客编码 ,对应丰桥上获取的clientCode
- params.put("requestID", UUID.randomUUID().toString().replace("-", ""));
- params.put("serviceCode",standardService.getCode());// 接口服务码
- params.put("timestamp", timeStamp);
- params.put("msgData", msgData);
- params.put("msgDigest", tools.getMsgDigest(msgData,timeStamp,CHECK_WORD_BOX));
- long startTime = System.currentTimeMillis();
- // System.out.println("====调用请求:" + params.get("msgData"));
- System.out.println("====调用实际请求:" + params);
- String result = HttpClientUtil.post(CALL_URL_BOX, params);
- System.out.println("====调用丰桥的接口服务代码:" + String.valueOf(standardService.getCode()) + " 接口耗时:"+ String.valueOf(System.currentTimeMillis()-startTime)+"====");
- System.out.println("===调用地址 ==="+CALL_URL_BOX);
- System.out.println("===顾客编码 ==="+CLIENT_CODE);
- System.out.println("===返回结果:" +result);
- // Map<String,Object> resData = JacksonUtil.fromJson(result);
- SFApiResp sfApiResp = FlexJsonUtil.fromJson(result, SFApiResp.class);
- if(sfApiResp!=null){
- if("A1000".equals(sfApiResp.getApiResultCode())){
- String apiResultData = sfApiResp.getApiResultData();
- SFCreatOrderResp sfApiRespData = FlexJsonUtil.fromJson(apiResultData, SFCreatOrderResp.class);
- if(sfApiRespData.isSuccess()){
- SFCreateOrder sfOrderResp = sfApiRespData.getMsgData();
- if(!CollectionUtil.isEmpty(sfOrderResp.getWaybillNoInfoList())){
- for (SFWaybillNoInfo sfWaybillNoInfoResp:sfOrderResp.getWaybillNoInfoList()){
- System.out.println("顺丰物流单号: ====="+sfWaybillNoInfoResp.getWaybillNo());
- }
- }
- }else {
- System.out.println("errorCode:"+sfApiRespData.getErrorCode()+"====errorMsg:"+sfApiRespData.getErrorMsg());
- }
- }else {
- System.out.println("code:"+sfApiResp.getApiResultCode()
- +"===apiResponseID:"+sfApiResp.getApiResponseID()
- +"===apiErrorMsg:"+sfApiResp.getApiErrorMsg());
- }
- }
- }
- @Test
- public void TestCreatSFOrder(){
- Map<String, Object> res = erpService.creatSFOrder("JYX_TEST", 50734826,"ADMIN");
- System.out.println("res==="+res.get("success")+":"+res.get("message"));
- }
- @Test
- public void TestCancelSFOrder(){
- Map<String, Object> res = erpService.cancelSFOrder("JYX_TEST", 50734826,"ADMIN");
- System.out.println("res==="+res.get("success")+":"+res.get("message"));
- }
- }
|