From 2c1a6f5df6ca8938e5e71b4c51e0e8315cf7f45a Mon Sep 17 00:00:00 2001
From: tjx <t2856754968@163.com>
Date: 星期二, 25 十一月 2025 11:13:43 +0800
Subject: [PATCH] 新增企业微信的接口

---
 src/test/java/com/gs/xky/XkyApplicationTests.java |  162 +++++++++++++++++++++++------------------------------
 1 files changed, 70 insertions(+), 92 deletions(-)

diff --git a/src/test/java/com/gs/xky/XkyApplicationTests.java b/src/test/java/com/gs/xky/XkyApplicationTests.java
index 695790a..1e4295a 100644
--- a/src/test/java/com/gs/xky/XkyApplicationTests.java
+++ b/src/test/java/com/gs/xky/XkyApplicationTests.java
@@ -1,12 +1,7 @@
 package com.gs.xky;
 
-import com.gs.xky.config.ApiResponse;
-import com.gs.xky.config.BodyParam;
-import com.gs.xky.config.DataAcquisitionConfiguration;
-import com.gs.xky.config.XkyCommonParam;
-import com.gs.xky.dto.BarcodeDeliveryNo;
-import com.gs.xky.dto.XkyDetail;
-import com.gs.xky.service.*;
+import com.gs.xky.service.VwCjScSjTsBbService;
+import com.gs.xky.service.WorkWXService;
 import org.junit.jupiter.api.Test;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.test.context.SpringBootTest;
@@ -19,107 +14,90 @@
 
 
     @Autowired
-    private XkyService xkyService;
+    private VwCjScSjTsBbService vwCjScSjTsBbService;
 
     @Autowired
-    private ApiService apiService;
+    private WorkWXService workWXService;
 
-    @Autowired
-    private MesStaffService staffService;
-
-    @Autowired
-    private DeliveryNoticeService deliveryNoticeService;
-
-    @Autowired
-    private TblBarcodeInformationService barcodeInformationService;
-
+    /**
+     * 娴嬭瘯瀵煎嚭鐢熶骇鏁版嵁骞跺彂閫侀拤閽夋秷鎭�
+     * 鍔熻兘锛氭煡璇W_CJ_SC_SJ_TS_BB琛ㄦ暟鎹� -> 瀵煎嚭Excel -> 鍙戦�侀拤閽夋枃浠舵秷鎭�
+     */
     @Test
-    void contextLoads() throws IOException {
+    void testExportAndSendProductionData() throws Exception {
+        System.out.println("=== 寮�濮嬫祴璇曞鍑虹敓浜ф暟鎹苟鍙戦�侀拤閽� ===");
 
-        xkyService.GetSaveDetail();
+        try {
+            boolean result = vwCjScSjTsBbService.exportAndSendToDingtalk();
+
+            if (result) {
+                System.out.println("鉁� 鐢熶骇鏁版嵁瀵煎嚭骞跺彂閫佹垚鍔�");
+                System.out.println("  - 鏁版嵁宸蹭粠 VW_CJ_SC_SJ_TS_BB 琛ㄦ煡璇�");
+                System.out.println("  - Excel 鏂囦欢宸茬敓鎴愬苟淇濆瓨鍒� D:\\BIFile\\");
+                System.out.println("  - 閽夐拤鏂囦欢娑堟伅宸插彂閫�");
+            } else {
+                System.out.println("鉁� 鐢熶骇鏁版嵁瀵煎嚭鎴栧彂閫佸け璐�");
+            }
+        } catch (Exception e) {
+            System.out.println("鉁� 瀵煎嚭骞跺彂閫佹椂鍙戠敓寮傚父: " + e.getMessage());
+            e.printStackTrace();
+        }
+
+        System.out.println("=== 娴嬭瘯缁撴潫 ===");
     }
 
+    /**
+     * 娴嬭瘯鑾峰彇浼佷笟寰俊access_token
+     * 鍔熻兘锛氳皟鐢ㄤ紒涓氬井淇PI鑾峰彇access_token
+     */
     @Test
-    void cs() throws IOException {
-        XkyCommonParam param = XkyCommonParam.GetInit();
+    void testGetWorkWXAccessToken() {
+        System.out.println("=== 寮�濮嬫祴璇曡幏鍙栦紒涓氬井淇ccess_token ===");
 
-        // 鍒涘缓 BodyParam 瀵硅薄骞惰祴鍊�
-        BodyParam bodyParam = new BodyParam();
+        try {
+            String accessToken = workWXService.getAccessToken();
 
-        bodyParam.setErpCode(DataAcquisitionConfiguration.TEST_ERP_CODE);
-        bodyParam.setDeliveryNo("22250403DE7H");
+            if (accessToken != null && !accessToken.isEmpty()) {
+                System.out.println("鉁� 鎴愬姛鑾峰彇浼佷笟寰俊access_token");
+                System.out.println("  - access_token: " + accessToken);
+                System.out.println("  - token闀垮害: " + accessToken.length());
+            } else {
+                System.out.println("鉁� 鑾峰彇鐨刟ccess_token涓虹┖");
+            }
+        } catch (IOException e) {
+            System.out.println("鉁� 鑾峰彇access_token澶辫触: " + e.getMessage());
+            e.printStackTrace();
+        }
 
-        param.setBody(bodyParam);
-
-        ApiResponse<XkyDetail> detail = apiService.sendListRequest(param, XkyDetail.class, "https://openapi.xiekeyun.com/delivery/getDetail.json");
-
-        XkyDetail deliveryNo = detail.getData();
-        deliveryNoticeService.saveDeliveryNotice(deliveryNo);
-        List<BarcodeDeliveryNo> barcodeDeliveryNos = GetBarcodeInformation(deliveryNo.getDeliveryNo());
-        barcodeInformationService.SaveBarcodeInformation(barcodeDeliveryNos, deliveryNo.getDeliveryNo());
-
-        deliveryNoticeService.callPdaReceiptBtn("閫佽揣鍗曠鏀禰BTNOK[PL017[" + deliveryNo.getDeliveryNo(), "");
+        System.out.println("=== 娴嬭瘯缁撴潫 ===");
     }
 
-    private List<BarcodeDeliveryNo> GetBarcodeInformation(String deliveryNo) throws IOException {
-        XkyCommonParam param = XkyCommonParam.GetInit();
-
-        // 鍒涘缓 BodyParam 瀵硅薄骞惰祴鍊�
-        BodyParam bodyParam = new BodyParam();
-
-        bodyParam.setErpCode(DataAcquisitionConfiguration.TEST_ERP_CODE);
-        bodyParam.setDeliveryNo(deliveryNo);
-
-        param.setBody(bodyParam);
-
-
-        ApiResponse<BarcodeDeliveryNo> noList = apiService.sendListRequest(param, BarcodeDeliveryNo.class, "https://openapi.xiekeyun.com/barcode/byDeliveryNo.json");
-
-        return noList.getDataList();
-    }
-
+    /**
+     * 娴嬭瘯鑾峰彇浼佷笟寰俊鐢ㄦ埛鍒楄〃
+     * 鍔熻兘锛氳皟鐢ㄤ紒涓氬井淇PI鑾峰彇鎵�鏈夌敤鎴风殑userid鍜岄儴闂ㄤ俊鎭�
+     */
     @Test
-    void cs1() throws IOException {
-//        DingTalkParam dingTalkParam = new DingTalkParam(0);
-//
-//        DingTalkResponse<EmployeeInfo> employeeInfoDingTalkResponse = apiService.sendListRequest(dingTalkParam, EmployeeInfo.class, "http://192.168.1.64/eHR/eHRExternalService/Service.ashx");
-//
-//        //閫犳ⅵ鑰咃紙娴欐睙锛夌鎶�鏈夐檺鍏徃 cUnitName
-//        //http://192.168.1.64/eHR
-//        List<EmployeeInfo> collect = employeeInfoDingTalkResponse.getData().stream().filter(s -> "閫犳ⅵ鑰咃紙娴欐睙锛夌鎶�鏈夐檺鍏徃".equals(s.getCUnitName())).collect(Collectors.toList());
-//        System.out.println(collect.size());
-//
-//        List<List<EmployeeInfo>> partition = ListUtil.partition(collect, 500);
-//
-//        partition.forEach(list -> {
-//            staffService.SaveStaff(list);
-//        });
+    void testGetWorkWXUserList() {
+        System.out.println("=== 寮�濮嬫祴璇曡幏鍙栦紒涓氬井淇$敤鎴峰垪琛� ===");
 
-    }
+        try {
+            List<WorkWXService.DeptUser> userList = workWXService.getUserList();
 
+            if (userList != null && !userList.isEmpty()) {
+                System.out.println("鉁� 鎴愬姛鑾峰彇浼佷笟寰俊鐢ㄦ埛鍒楄〃");
+                System.out.println("  - 鐢ㄦ埛鎬绘暟: " + userList.size());
+                System.out.println("  - 鍓�5鏉℃暟鎹�:");
+                userList.stream().limit(5).forEach(user -> {
+                    System.out.println("    * userid: " + user.getUserid() + ", department: " + user.getDepartment());
+                });
+            } else {
+                System.out.println("鉁� 鑾峰彇鐨勭敤鎴峰垪琛ㄤ负绌�");
+            }
+        } catch (IOException e) {
+            System.out.println("鉁� 鑾峰彇鐢ㄦ埛鍒楄〃澶辫触: " + e.getMessage());
+            e.printStackTrace();
+        }
 
-    @Test
-    void cs2() throws IOException {
-//        DingTalkParam dingTalkParam = new DingTalkParam(1);
-//
-//        DingTalkResponse<EmployeeInfo> employeeInfoDingTalkResponse = apiService.sendListRequest(dingTalkParam, EmployeeInfo.class, "http://192.168.1.64/eHR/eHRExternalService/Service.ashx");
-//
-//        //閫犳ⅵ鑰咃紙娴欐睙锛夌鎶�鏈夐檺鍏徃 cUnitName
-//        //http://192.168.1.64/eHR
-//        List<EmployeeInfo> collect = employeeInfoDingTalkResponse.getData().stream().filter(s -> "閫犳ⅵ鑰咃紙娴欐睙锛夌鎶�鏈夐檺鍏徃".equals(s.getCUnitName())).collect(Collectors.toList());
-//        System.out.println(collect.size());
-//
-//        List<List<EmployeeInfo>> partition = ListUtil.partition(collect, 100);
-//
-//        partition.forEach(list -> {
-//            staffService.UpdateStaff(list);
-//        });
-
-    }
-
-    @Test
-    void cs3() throws IOException {
-        String str = "{\"state\":\"500\",\"msg\":\"{\\\"Result\\\":{\\\"ResponseStatus\\\":{\\\"ErrorCode\\\":500,\\\"IsSuccess\\\":false,\\\"Errors\\\":[{\\\"FieldName\\\":null,\\\"Message\\\":\\\"鏄庣粏淇℃伅绗�1琛岀殑鐢熶骇閫氱煡鍗曞�间负:銆�127147銆戜笉瀛樺湪锛沑\\\r\\\\n\\\",\\\"DIndex\\\":0}],\\\"SuccessEntitys\\\":[],\\\"SuccessMessages\\\":[],\\\"MsgCode\\\":11},\\\"Id\\\":\\\"\\\",\\\"Number\\\":\\\"\\\",\\\"NeedReturnData\\\":[{}]}}\"}";
-
+        System.out.println("=== 娴嬭瘯缁撴潫 ===");
     }
 }
\ No newline at end of file

--
Gitblit v1.9.3