南骏 池
2025-05-16 567fb8c8c0851f1ae24176d7414299a28696a276
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
using MES.Service.Models;
using NewPdaSqlServer.DB;
using NewPdaSqlServer.util;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using System.Collections;
using System.Data;
using System.Net;
using System.Net.Http.Headers;
using System.Text;
using System.Data.SqlClient;
using System.Data;
using static NewPdaSqlServer.Controllers.Warehouse.MesXkyController;
 
namespace NewPdaSqlServer.service.QC;
 
public class MesXkyService : RepositoryNoEntity
{
    /// <summary>
    /// 系统自动日志模板(用于携客云接口调用记录)
    /// </summary>
    private  string _logMessage = "【SysAuto】获取携客云送货单。";
    
    /// <summary>
    /// 请求报文缓存(存储序列化后的JSON请求内容)
    /// </summary>
    private string _requestJson = string.Empty;
    
    /// <summary>
    /// 动态响应对象(存储反序列化的携客云接口响应)
    /// </summary>
    private dynamic _responseData = new System.Dynamic.ExpandoObject();
    
    /// <summary>
    /// 接口执行时间戳(格式:yyyy-MM-dd HH:mm:ss)
    /// </summary>
    private string _executeTimestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
    
    /// <summary>
    /// 接口调用状态(0-失败 1-成功)
    /// </summary>
    private int sendStatus = 0;
 
    public dynamic XKY_GET_DHD(XKYGetDhdRequest entity)
    {
        try
        {
            string ErrorMsg = "";
            ApiCommonParam Apiparam = ApiCommonParam.NewApiCommon();
 
            _executeTimestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
            //string data_inserted = "{\r\n  \"startDate\": 1746759300000,\r\n  \"endDate\": 1746762300000,\r\n  \"erpCode\": \"GXF001\"\r\n}";
            string sendJson = JsonConvert.SerializeObject(entity);
            ArrayList SQLStringList = new ArrayList();
            // var client = new HttpClient();
            var url = "https://openapi.xiekeyun.com/delivery/getNoList.json";
            HttpClient httpClient = new HttpClient();
            httpClient.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
 
            _requestJson = "{\"commonParam\":" + JsonConvert.SerializeObject(Apiparam) + ",\"body\":" + sendJson + "}";
            byte[] postData = Encoding.UTF8.GetBytes(_requestJson);
 
            // 创建请求对象
            HttpWebRequest request = (HttpWebRequest)WebRequest.Create("https://openapi.xiekeyun.com/delivery/getNoList.json");
            request.Method = "POST";
            request.ContentType = "application/json";
            request.ContentLength = postData.Length;
 
            // 发送请求数据
            using (Stream stream = request.GetRequestStream())
            {
                stream.Write(postData, 0, postData.Length);
            }
 
            // 发送请求并获取响应
            HttpWebResponse response = (HttpWebResponse)request.GetResponse();
            using (Stream stream = response.GetResponseStream())
            using (StreamReader reader = new StreamReader(stream))
            {
                string result2 = reader.ReadToEnd();
 
                _responseData = JsonConvert.DeserializeObject(result2);
            }
 
 
            //// 新增日志记录(在返回响应前)
            //using (var conn = new SqlConnection(DbHelperSQL.strConn))
            //{
            //    using (var cmd = new SqlCommand("prc_log_create", conn))
            //    {
            //        try
            //        {
            //            conn.Open();
            //            cmd.CommandType = CommandType.StoredProcedure;
            //            SqlParameter[] logParams =
            //            {
            //                new("@edtUserGuid", SqlDbType.UniqueIdentifier) { Value = Guid.Parse("11111111-1111-1111-1111-111111111111") },
            //                new("@abtGuid", SqlDbType.UniqueIdentifier) { Value = DBNull.Value },
            //                new("@abtTable", SqlDbType.NVarChar, 40) { Value = "DELIVERY_NOTICE" },
            //                new("@detail", SqlDbType.NVarChar, 2500) { Value = "【SysAuto】获取携客云送货单。" },
            //                new("@hNo", SqlDbType.NVarChar, 100) { Value = "" },
            //                new("@SendJson", SqlDbType.NVarChar) { Value = json },
            //                new("@RtnJson", SqlDbType.NVarChar) { Value = JsonConvert.SerializeObject(responseJson) },
            //                new("@xkyBeginTime", SqlDbType.NVarChar) { Value = (entity.startDate/1000).ToString() },
            //                new("@xkyEndTime", SqlDbType.NVarChar) { Value = (entity.endDate/1000).ToString()},
            //                new("@sendStatus", SqlDbType.NVarChar) { Value = responseJson.result.ToString()},
            //                new("@executeTime", SqlDbType.NVarChar) { Value =  executeTime},
            //            };
 
            //            foreach (var param in logParams)
            //                cmd.Parameters.Add(param);
 
            //            cmd.ExecuteNonQuery();
            //        }
            //        catch (Exception logEx)
            //        {
            //            // 日志记录失败不中断主流程
            //            Console.WriteLine($"日志记录失败: {logEx.Message}");
            //        }
            //        finally
            //        {
            //            conn.Close();
            //        }
            //    }
            //}
 
            if (_responseData.result != 1)
                throw new ApplicationException(_responseData.errorMsg);
 
            sendStatus = _responseData.result;
            // 原120-131行替换为:
            if (ProcessDeliveryNotice(_responseData) > 0)
                sendStatus = 1;
            else
                sendStatus = 0;
 
            var logService = new LogService();
            logService.CreateLogI(
                db: Db,
                edtUserGuid: Guid.Parse("11111111-1111-1111-1111-111111111111"),
                abtGuid: null,
                abtTable: "DELIVERY_NOTICE",
                detail: _logMessage,
                orderNo: "",
                sendJson: _requestJson,
                rtnJson: JsonConvert.SerializeObject(_responseData),
                xkyBeginTime: (entity.startDate / 1000).ToString(),
                xkyEndTime: (entity.endDate / 1000).ToString(),
                sendStatus: sendStatus,
                executeTime: _executeTimestamp
            );
 
            return _responseData;
        }
        catch (Exception e)
        {
            var logService = new LogService();
            logService.CreateLogI(
                db: Db,
                edtUserGuid: Guid.Parse("11111111-1111-1111-1111-111111111111"),
                abtGuid: null,
                abtTable: "DELIVERY_NOTICE",
                detail: _logMessage,
                orderNo: "",
                sendJson: _requestJson,
                rtnJson: JsonConvert.SerializeObject(_responseData),
                xkyBeginTime: (entity.startDate / 1000).ToString(),
                xkyEndTime: (entity.endDate / 1000).ToString(),
                sendStatus: 0,
                executeTime: _executeTimestamp
            );
            throw new Exception(e.Message);
        }
 
    }
 
 
    //public dynamic GetXkyDHD(XKYGetDhdRequest entity)
    //{
 
    //   return XKY_GET_DHD(entity);
 
    //}
 
    //对获取到的携客云送货单做处理
    private int ProcessDeliveryNotice(dynamic responseJson)
    {
        List<DeliveryNotice> noticeList = JsonConvert.DeserializeObject<List<DeliveryNotice>>(responseJson.dataList.ToString());
        noticeList.ForEach(n => n.Id = Guid.NewGuid());
    
        var deliveryNos = noticeList.Select(n => n.DeliveryNo).Distinct().ToList();
        var noticeIds = noticeList.Select(n => n.Id).ToList(); // 保持GUID类型
 
        var result = 0;
        Db.Ado.UseTran(() =>
        {
            // 删除关联送货明细数据
            Db.Deleteable<DeliveryNoticeDetail>()
            .Where(d => noticeIds.Contains(Guid.Parse(d.Pid)))
              .ExecuteCommand();
 
            // 添加空值检查
            if (deliveryNos.Any())
            {
                //删除关联送货条码明细
                Db.Deleteable<TblBarcodeInformation>()
                  .Where(b => deliveryNos.Contains(b.DeliveryNo))
                  .ExecuteCommand();
 
                //删除送货单
                Db.Deleteable<DeliveryNotice>()
                  .Where(n => deliveryNos.Contains(n.DeliveryNo))
                  .ExecuteCommand();
            }
 
            // 批量插入优化
            result = Db.Fastest<DeliveryNotice>().BulkCopy(noticeList); 
        }, 
        ex => {
            // 增强异常信息
            _logMessage = _logMessage + $"数据库操作失败:{ex.Message}\n跟踪:{ex.StackTrace}";
            //throw new Exception($"数据库操作失败:{ex.Message}\n跟踪:{ex.StackTrace}");
        });
 
        return result;
    }
    
}