xiaojiao
2026-03-23 f02d3a8ffc05a10a64859b2a16d5d43c8abb0fb9
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
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
using HslCommunication;
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection.Metadata;
using System.Text;
using System.Threading;
using WIDESEA_Common;
using WIDESEA_Common.CutomerModel;
using WIDESEA_Common.LogEnum;
using WIDESEA_Common.TaskEnum;
using WIDESEA_Common.Tools;
using WIDESEA_Core.Utilities;
using WIDESEA_Entity.DomainModels;
using WIDESEA_Services;
using WIDESEA_Services.IRepositories;
using WIDESEA_Services.Repositories;
using WIDESEA_Services.Services;
using WIDESEA_WCS.WCSClient;
 
namespace WIDESEA_WCS.Jobs.ConveyorLine.OutboundArea
{
    public partial class OutboundAreaDispatch
    {
        /// <summary>
        /// 出库的层
        /// </summary>
        private static List<string> OutboundStationLayerNo = new List<string>() { "60101", "60102", "60103", "60104", "60105", "60106", "60107" };
        /// <summary>
        /// 入库托盘申请站台
        /// </summary>
        private static string ReInboundRequestStationNo = "90101";
        //出库站台交互
        //private static string OutboundStationNo = "90201";
        //提升机编号
        private static string hoisterResultNo = "90100";
        /// <summary>
        /// 出库区调度
        /// </summary>
        /// <param name="taskWCSinfoRepository"></param>
        /// <param name="client"></param>
        public static string currentModel = "Inbound";
        static int flag = 0;
        // 压装台缓存位字典
        public static Dictionary<string, string> PlatformDict = new Dictionary<string, string>
        {
            ["70101"] = "80101",
            ["70103"] = "80103",
            ["70104"] = "80104",
            ["70106"] = "80106"
        };
        // 出库区域校准缓存架校准 
        public static void OutboundAreaJZ(IDt_TaskWCSinfoRepository taskWCSinfoRepository, IDt_TaskRGVinfoRepository taskRGVinfoRepository, PLCClient client)
        {
            // 出库区的出库任务 到缓存架子了 就要把任务号和托盘号写入到对应层的缓存架
            List<Dt_TaskWCSinfo> executingTasks = taskWCSinfoRepository.Find(r => (
            r.wcstask_state == TaskState.TaskState_Box_Out_RGV_Finished.ToString() ||
            r.wcstask_state == TaskState.TaskState_Empty_Out_RGV_Finished.ToString())
            && endStationNo.Contains(r.wcstask_endPoint)).ToList();
            foreach (var item in executingTasks)
            {
                bool LoadSleep = bool.Parse(client.ReadValue(CLineInfoDBName.R_Line_LoadSleep.ToString(), item.wcstask_startPoint.ToString()).ToString());
                int ReadNumber = int.Parse(client.ReadValue(CLineInfoDBName.R_Line_TaskNumber.ToString(), item.wcstask_startPoint.ToString()).ToString());
                int ReadBarcode = int.Parse(client.ReadValue(CLineInfoDBName.R_Line_Barcode.ToString(), item.wcstask_startPoint.ToString()).ToString());
                if (LoadSleep && (ReadNumber == 0 || ReadBarcode == 0))
                {
                    //写入托盘条码
                    bool writeTaskNumber = client.WriteValue(CLineInfoDBName.W_Line_TaskNumber.ToString(), item.wcstask_startPoint, item.wcstask_taskNumber);
                    bool writeBarcode = client.WriteValue(CLineInfoDBName.W_Line_Barcode.ToString(), item.wcstask_startPoint, item.wcstask_barcode);
                }
            }
 
            foreach (var item in OutboundStationLayerNo)
            {
                bool LoadSleep = bool.Parse(client.ReadValue(CLineInfoDBName.R_Line_LoadSleep.ToString(), item.ToString()).ToString());
                int ReadNumber = int.Parse(client.ReadValue(CLineInfoDBName.R_Line_TaskNumber.ToString(), item.ToString()).ToString());
                int ReadBarcode = int.Parse(client.ReadValue(CLineInfoDBName.R_Line_Barcode.ToString(), item.ToString()).ToString());
 
                Dt_TaskWCSinfo dt_TaskWCSinfo = taskWCSinfoRepository.Find(r =>
                r.wcstask_type == TaskType.TaskType_Empty_Pallet_Inbound.ToString()
                && r.wcstask_state == TaskState.TaskState_Assigned.ToString()
                && r.wcstask_startPoint == 90101.ToString()
                && r.wcstask_endPoint == item
                && r.wcstask_barcode == ReadBarcode.ToString()
                && r.wcstask_taskNumber == ReadNumber
                ).FirstOrDefault();
 
                if (LoadSleep && dt_TaskWCSinfo != null)
                {
                    // 证明货物已经到了缓存架 但任务状态没有改变 还是新建状态 就要改为 TaskState.TaskState_Empty_In_PLC_Finished.ToString()
                    dt_TaskWCSinfo.wcstask_state = TaskState.TaskState_Empty_In_PLC_Finished.ToString();
                    taskWCSinfoRepository.Update(dt_TaskWCSinfo, true);
                    string str = $"出库区域 空托盘回库 托盘都到缓存架子 但任务状态没变 {DateTime.Now}【{dt_TaskWCSinfo.wcstask_state}】,托盘号:{dt_TaskWCSinfo.wcstask_barcode},任务号:{dt_TaskWCSinfo.wcstask_taskNumber}";
                    LogRecord.WriteLog(LogEnum.Errer, str.ToString());
                }
            }
 
            // 这里要写一个 有一些托盘已经出到外面去了 但状态还是提升机运行中 导致后面的发不出去
            Dt_TaskWCSinfo OutTask = taskWCSinfoRepository.Find(r =>
            r.wcstask_state == TaskState.TaskState_HoisterExecuting.ToString()
            && endStationNo.Contains(r.wcstask_endPoint)
            ).FirstOrDefault();
            if (OutTask != null)
            {
                double secondsPassend = (DateTime.Now - OutTask.wcstask_dispatcherTime.Value).TotalSeconds;
                if (secondsPassend > 38) // 如果大于38秒 还没用提升机完成 就要手动
                {
                    string state = TaskState.TaskState_Box_Out_Line_Executing.ToString();
                    if (OutTask.wcstask_type == TaskType.TaskType_Empty_Pallet_Outbound.ToString())
                    {
                        state = TaskState.TaskState_Empty_Out_Line_Executing.ToString();
                    }
                    OutTask.wcstask_state = state;
                    OutTask.wcstask_dispatcherTime = DateTime.Now;
                    taskWCSinfoRepository.Update(OutTask, true);
                    string str = $"出库区 出库 提升机已经内的托盘已经出去 但状态还是提升机执行中... {DateTime.Now},托盘号:{OutTask.wcstask_barcode},任务号:{OutTask.wcstask_taskNumber}";
                    LogRecord.WriteLog(LogEnum.Errer, str.ToString());
                }
            }
 
        }
        public static void OutboundAreaDispathAction(IDt_TaskWCSinfoRepository taskWCSinfoRepository, IDt_TaskRGVinfoRepository taskRGVinfoRepository, PLCClient client)
        {
            try
            {
                //出库完成
                OutboundCompleteAction(taskWCSinfoRepository, client);  //压装出库口任务完成
 
                //生成可下发的RGV任务,至缓存口
                List<Dt_TaskWCSinfo> executingTask = taskWCSinfoRepository.Find(r => r.wcstask_state != TaskState.TaskState_Assigned.ToString()
                 && endStationNo.Contains(r.wcstask_endPoint));
                // 这里要写一个逻辑,就是我获取的任务,只有对应的站台为空,我才能下发,这样改的话,空托盘入库也要改
                if (executingTask.Count < 8)    //小于8,则可生成去这边的任务
                {
                    //直接将任务添加到AGV任务
                    Dt_TaskWCSinfo outboundTask = GetOutboundTask(taskWCSinfoRepository, client);
                    if (null != outboundTask)
                    {
                        //查找是否有该托盘条码任务,如果没有则进行添加RGV任务
                        Dt_TaskRGVinfo rgvInfo = taskRGVinfoRepository.FindFirst(r => r.rgvtask_barCode == outboundTask.wcstask_barcode
                        && r.rgvtask_wcsTaskNumber == outboundTask.wcstask_taskNumber);
 
                        if (null == rgvInfo)
                        {
                            string rgvTaskType = RGVTaskType.RgvTaskType_Inbound.ToString();
                            if (outboundTask.wcstask_type.Equals(TaskType.TaskType_Box_Pallet_Outbound.ToString())
                                || outboundTask.wcstask_type.Equals(TaskType.TaskType_Empty_Pallet_Outbound.ToString()))
                                rgvTaskType = RGVTaskType.RgvTaskType_Outbound.ToString();
 
                            rgvInfo = GetRGVTask(taskRGVinfoRepository, outboundTask, rgvTaskType);
                            taskRGVinfoRepository.Add(rgvInfo, true);
 
                            outboundTask.wcstask_state = TaskState.TaskState_RGV_Received.ToString();
                            taskWCSinfoRepository.Update(outboundTask, x => x.wcstask_state, true);
                        }
                    }
                }
 
                //缓存口(缓存架)至输送线
                OutboundCZ_PLC(taskWCSinfoRepository, taskRGVinfoRepository, client);
 
                //空托入库申请(生成了空托入库任务)
                InboundRequestAction(taskWCSinfoRepository, taskRGVinfoRepository, client);
 
                //空托到缓存口(缓存架)
                ReInboundKTP(taskWCSinfoRepository, client);
 
                //空托入库口,生成RGV任务,进行入库
                RGV_InboundKTP(taskWCSinfoRepository, taskRGVinfoRepository, client);
 
 
            }
            catch (Exception ex)
            {
                WriteLog.Info("OutboundArea").Write($"{DateTime.Now}出库区域调度失败:{ex.Message}", "OutboundArea");
            }
        }
        public static bool WriteRGVState(PLCClient client, bool value)
        {
            client.WriteValue(CLineInfoDBName.W_System_RGVState.ToString(), value);
            string rel = string.Empty;
            for (int i = 0; i < 50; i++)
            {
                rel = client.ReadValue(CLineInfoDBName.W_System_RGVState.ToString()).ToString();
                if (value == bool.Parse(rel))
                    break;
                else
                {
                    client.WriteValue(CLineInfoDBName.W_System_RGVState.ToString(), value);
                    Thread.Sleep(88);
                }
            }
            rel = client.ReadValue(CLineInfoDBName.W_System_RGVState.ToString()).ToString();
            if (value != bool.Parse(rel))
                Console.Out.WriteLine($"{DateTime.Now}写入车存储中{value}失败.");
 
            return bool.Parse(rel);
        }
        /// <summary>
        /// 查询是否有可出的出库任务
        /// </summary>
        /// <param name="taskWCSinfoRepository"></param>
        /// <param name="client"></param>
        /// <returns></returns>
        public static Dt_TaskWCSinfo GetOutboundTask(IDt_TaskWCSinfoRepository taskWCSinfoRepository, PLCClient client)
        {
            Dt_TaskWCSinfo wcsInfo = null;
 
            List<Dt_TaskWCSinfo> listTask = taskWCSinfoRepository.Find(r => r.wcstask_state == TaskState.TaskState_Assigned.ToString() &&
          (r.wcstask_type == TaskType.TaskType_Box_Pallet_Outbound.ToString() || r.wcstask_type == TaskType.TaskType_Empty_Pallet_Outbound.ToString())
          && endStationNo.Contains(r.wcstask_endPoint)).OrderBy(r => r.wcstask_createTime).ToList();//
 
            foreach (var item in listTask.GroupBy(r => r.wcstask_endPoint))
            {
                Dt_TaskWCSinfo wcsTask = item.OrderBy(r => r.wcstask_createTime).FirstOrDefault();
                if (null != wcsTask)
                {
                    //判断压装台是否有货  也就是判断80101那边
                    bool yzflag = bool.Parse(client.ReadValue(CLineInfoDBName.R_Line_LoadSleep.ToString(), PlatformDict[wcsTask.wcstask_endPoint]).ToString());
                    bool yznoflag = bool.Parse(client.ReadValue(CLineInfoDBName.R_Line_NoLoadSleep.ToString(), PlatformDict[wcsTask.wcstask_endPoint]).ToString());
                    if (yzflag || !yznoflag)
                        continue;
 
                    //判断缓存架是否有货 
                    bool flag = bool.Parse(client.ReadValue(CLineInfoDBName.R_Line_LoadSleep.ToString(), wcsTask.wcstask_startPoint).ToString());
                    bool noflag = bool.Parse(client.ReadValue(CLineInfoDBName.R_Line_NoLoadSleep.ToString(), wcsTask.wcstask_startPoint).ToString());
                    if (flag || !noflag)
                        continue;
 
                    //同一层有执行中的任务不添加
                    //Dt_TaskWCSinfo executingTask = taskWCSinfoRepository.FindFirst(r => 
                    //(r.wcstask_startPoint == wcsTask.wcstask_startPoint || r.wcstask_endPoint == wcsTask.wcstask_endPoint)
                    //&& (r.wcstask_state == TaskState.TaskState_RGV_Received.ToString() || r.wcstask_state == TaskState.TaskState_HoisterExecuting.ToString()));
                    //if (null != executingTask)
                    //    continue;
                    // 肖佼 将上面修改成下面
                    Dt_TaskWCSinfo executingTask = taskWCSinfoRepository.FindFirst(r =>
                    (r.wcstask_startPoint == wcsTask.wcstask_startPoint)
                    && (r.wcstask_state == TaskState.TaskState_RGV_Received.ToString()));
                    if (null != executingTask)
                        continue;
 
                    List<Dt_TaskWCSinfo> listTarget = taskWCSinfoRepository.Find(r => r.wcstask_endPoint == wcsTask.wcstask_endPoint &&
                    r.wcstask_state != TaskState.TaskState_Assigned.ToString());
 
                    string barcode = client.ReadValue(CLineInfoDBName.R_Line_Barcode.ToString(), wcsTask.wcstask_endPoint).ToString();
 
                    if (string.IsNullOrEmpty(barcode) || "0".Equals(barcode))
                    {
                        if (null != listTarget && listTarget.Count > 1)
                            continue;
                        else
                        {
                            wcsInfo = wcsTask;
                            break;
                        }
                    }
                    else
                    {
                        if (null != listTarget && listTarget.Count > 0)
                            continue;
                        else
                        {
                            wcsInfo = wcsTask;
                            break;
                        }
                    }
                }
            }
            return wcsInfo;
        }
 
 
        public static Dt_TaskRGVinfo GetRGVTask(IDt_TaskRGVinfoRepository taskRGVinfoRepository, Dt_TaskWCSinfo wcsTask, string rgvTaskType)
        {
            Dt_TaskRGVinfo rgvInfo = new Dt_TaskRGVinfo();
            rgvInfo.rgvtask_taskId = GetTaskNumber.GetRgvTaskNumber(taskRGVinfoRepository).ToString();
            rgvInfo.rgvtask_taskType = rgvTaskType;
            rgvInfo.rgvtask_taskStatus = RGVTaskState.RgvTaskState_Wait_Send.ToString();
            rgvInfo.rgvtask_priorityCode = wcsTask.wcstask_grade.ToString();
            rgvInfo.rgvtask_startNode = wcsTask.wcstask_startLocation;
            rgvInfo.rgvtask_endNode = wcsTask.wcstask_endLocation;
            rgvInfo.rgvtask_wcsTaskNumber = wcsTask.wcstask_taskNumber;
            rgvInfo.rgvtask_barCode = wcsTask.wcstask_barcode;
            rgvInfo.rgvtask_creator = wcsTask.wcstask_creator;
            rgvInfo.rgvtask_msgTime = DateTime.Now;
            rgvInfo.rgvtask_areaCode = "OutboundArea";
            return rgvInfo;
        }
 
        // 只用一个字典:Key=托盘号,Value=Tuple<锁对象, 最后使用时间>
        // Tuple<object, DateTime>:Item1=锁对象,Item2=最后使用时间
        private static readonly Dictionary<string, Tuple<object, DateTime>> BarcodeLockDict = new Dictionary<string, Tuple<object, DateTime>>();
        private static readonly object GlobalLock = new object(); // 保护字典的全局锁
        private const int ExpireMinutes = 1; // 过期时间:1分钟
 
        /// <summary>
        /// 获取托盘号专属锁(单字典+1分钟过期+懒清理)
        /// </summary>
        private static object GetBarcodeLock(string barcode)
        {
 
            lock (GlobalLock) // 全局锁保护字典操作
            {
                // ========== 第一步:懒清理(每次获取锁时,清理超过1分钟的闲置托盘号) ==========
                var expiredBarcodes = BarcodeLockDict
                    .Where(kv => (DateTime.Now - kv.Value.Item2).TotalMinutes > ExpireMinutes)
                    .Select(kv => kv.Key)
                    .ToList();
 
                foreach (var expiredBarcode in expiredBarcodes)
                {
                    BarcodeLockDict.Remove(expiredBarcode);
                }
 
                // ========== 第二步:处理当前托盘号的锁和时间 ==========
                if (!BarcodeLockDict.ContainsKey(barcode))
                {
                    // 无该托盘号:新增锁对象+当前时间
                    BarcodeLockDict[barcode] = Tuple.Create(new object(), DateTime.Now);
                }
                // 返回当前托盘号的锁对象
                return BarcodeLockDict[barcode].Item1;
            }
        }
 
        public static void InboundRequestAction(IDt_TaskWCSinfoRepository taskWCSinfoRepository, IDt_TaskRGVinfoRepository taskRGVinfoRepository, PLCClient client)
        {
            try
            {
                int R_Line_PLCDispatch = int.Parse(client.ReadValue(CLineInfoDBName.W_Line_PLCDispatch.ToString(), ReInboundRequestStationNo).ToString());
                bool load = bool.Parse(client.ReadValue(CLineInfoDBName.R_Line_LoadSleep.ToString(), ReInboundRequestStationNo).ToString());
                if (R_Line_PLCDispatch == 1 && load)
                {
                    string barcode = client.ReadValue(CLineInfoDBName.R_Line_Barcode.ToString(), ReInboundRequestStationNo).ToString();
 
                    if (!string.IsNullOrEmpty(barcode) && !"0".Equals(barcode))
                    {
                        if (int.Parse(barcode) < 800000 || int.Parse(barcode) > 890000)
                        {
                            return;
                        }
                        object barcodeLock = GetBarcodeLock(barcode);
                        lock (barcodeLock)
                        {
                            Dt_TaskWCSinfo IsTask = taskWCSinfoRepository.FindFirst(x => x.wcstask_barcode == barcode
                            && (x.wcstask_type == TaskType.TaskType_Empty_Pallet_Outbound.ToString() || x.wcstask_type == TaskType.TaskType_Box_Pallet_Outbound.ToString())
                            && (x.wcstask_state == TaskState.TaskState_Box_Out_Line_Executing.ToString() || x.wcstask_state == TaskState.TaskState_Empty_Out_Line_Executing.ToString())
                            && (endStationNo.Contains(x.wcstask_endPoint)));
                            if (IsTask != null)
                            {
                                // 这里要加一个判断,如果拿回来的空托盘是800001,但是我有一条这个托盘的任务是800001还没有到指定的压装台,所以我要完成这个任务
                                // 在此完成该空托出库任务
                                WebResponseContent content = taskWCSinfoRepository.DbContextBeginTransaction(() =>
                                {
                                    //上报WMS任务完成
                                    content = WMSApi.TellWmsTaskFinished(IsTask.wcstask_barcode,IsTask.wcstask_backUp_2);
                                    if (content.Status)
                                    {
                                        //移动任务到历史表
                                        Dt_TaskWCSinfo_HtyRepository taskWCSinfo_HtyRepository = new Dt_TaskWCSinfo_HtyRepository(taskWCSinfoRepository.DbContext);
                                        IsTask.wcstask_state = TaskState.TaskState_Finished.ToString();
                                        CommonFunction.AddWcsTaskToHistory(IsTask, taskWCSinfoRepository, taskWCSinfo_HtyRepository);
                                    }
                                    else
                                        throw new Exception($"{DateTime.Now}上报WMS任务完成出错,原因:【{content.Message}】");
 
                                    return content;
                                });
                                string str = string.Empty;
                                if (content.Status)
                                    str = $" {DateTime.Now}上报WMS出库完成成功,【手动干扰出库没有到达指定压装台点位,手动拿回90101】【TaskState_ConveyorLineExecuting】,托盘号:{IsTask.wcstask_barcode},任务号:{IsTask.wcstask_taskNumber}";
                                else
                                    str = $" {DateTime.Now}上报WMS出库完成失败【手动干扰出库没有到达指定压装台点位,手动拿回90101】【TaskState_ConveyorLineExecuting】,托盘号:{IsTask.wcstask_barcode},任务号:{IsTask.wcstask_taskNumber}";
 
                                WriteLog.Info(IsTask.wcstask_endPoint).Write(str, IsTask.wcstask_endPoint);
                                LogRecord.WriteLog(LogEnum.Errer, str.ToString());
                            }
 
                            Dt_TaskWCSinfo wcsInfo = taskWCSinfoRepository.FindFirst(r => r.wcstask_barcode == barcode);
                            if (null == wcsInfo)
                            {
                                //获取车轴出库
                                List<Dt_TaskWCSinfo> executingTask = taskWCSinfoRepository.Find(r => (r.wcstask_type.Equals(TaskType.TaskType_Box_Pallet_Outbound.ToString()) ||
                                    r.wcstask_type.Equals(TaskType.TaskType_Empty_Pallet_Outbound.ToString())) && endStationNo.Contains(r.wcstask_endPoint));
 
                                //获取有多少条出库的任务
                                int LineExecucount = executingTask.Count(x => x.wcstask_state == TaskState.TaskState_Box_Out_Line_Executing.ToString()
                                || x.wcstask_state == TaskState.TaskState_Empty_Out_Line_Executing.ToString());
                                if (LineExecucount >= 8)
                                {
                                    //判断是否有对应层的出库任务,
                                    //申请入库任务
                                    WebResponseContent content = WMSApi.PostInboundRequstToWMS(barcode);
                                    if (content.Status)
                                    {
                                        //WmsTaskInfo wmsTask = JsonConvert.DeserializeObject<WmsTaskInfo>(content.Data.ToString());
                                        //wcsInfo = CommonFunction.AddWCSEmptyInboundTask(wmsTask, taskWCSinfoRepository);
                                        //taskWCSinfoRepository.Add(wcsInfo, true);
                                        //client.WriteValue(CLineInfoDBName.W_Line_PLCDispatch.ToString(), ReInboundRequestStationNo, 2);
                                        try
                                        {
                                            WmsTaskInfo wmsTask = JsonConvert.DeserializeObject<WmsTaskInfo>(content.Data.ToString());
                                            wcsInfo = CommonFunction.AddWCSEmptyInboundTask(wmsTask, taskWCSinfoRepository);
                                            taskWCSinfoRepository.Add(wcsInfo, true);
                                        }
                                        catch (Exception)
                                        {
                                            string str = $"这里可能是出现了并发的情况托盘码 在添加的时候拦截的【{wcsInfo.wcstask_barcode}】" +
                                                         $"任务号【{wcsInfo.wcstask_taskNumber}】,任务状态:【{wcsInfo.wcstask_state}】";
                                            LogRecord.WriteLog(LogEnum.Errer, str.ToString());
                                            //throw;
                                        }
                                    }
                                    else
                                    {
                                        if (content.Message.Contains("当前托盘号已存在库里"))
                                        {
                                            client.WriteValue(CLineInfoDBName.W_Line_PLCDispatch.ToString(), ReInboundRequestStationNo, 4);
                                        }
                                        throw new Exception("入库申请失败:" + content.Message);
                                    }
                                }
                                else
                                {
                                    //判断有多少条在缓存架的
                                    int RGV_Finishedcount = executingTask.Count(x => 
                                    x.wcstask_state != TaskState.TaskState_Box_Out_Line_Executing.ToString()
                                    && x.wcstask_state != TaskState.TaskState_Empty_Out_Line_Executing.ToString()
                                    && x.wcstask_state != TaskState.TaskState_Assigned.ToString());
 
                                    if (RGV_Finishedcount == 0)
                                    {
                                        // 核心:获取当前托盘号的专属锁,同一托盘号串行处理
                                        //申请入库任务
                                        WebResponseContent content = WMSApi.PostInboundRequstToWMS(barcode);
                                        if (content.Status)
                                        {
                                            try
                                            {
                                                WmsTaskInfo wmsTask = JsonConvert.DeserializeObject<WmsTaskInfo>(content.Data.ToString());
                                                wcsInfo = CommonFunction.AddWCSEmptyInboundTask(wmsTask, taskWCSinfoRepository);
                                                taskWCSinfoRepository.Add(wcsInfo, true);
                                            }
                                            catch (Exception)
                                            {
                                                string str = $"这里可能是出现了并发的情况托盘码,在添加的时候拦截的【{wcsInfo.wcstask_barcode}】" +
                                                             $"任务号【{wcsInfo.wcstask_taskNumber}】,任务状态:【{wcsInfo.wcstask_state}】";
                                                LogRecord.WriteLog(LogEnum.Errer, str.ToString());
                                                //throw;
                                            }
                                        }
                                        else
                                        {
                                            if (content.Message.Contains("当前托盘号已存在库里"))
                                            {
                                                client.WriteValue(CLineInfoDBName.W_Line_PLCDispatch.ToString(), ReInboundRequestStationNo, 4);
                                            }
                                            else if (content.Message.Contains("暂无货位可分配"))
                                            {
 
                                            }
                                            else 
                                            {
                                                throw new Exception("入库申请失败:" + content.Message);
                                            }
                                            
                                        }
                                    }
                                }
                            }
                            else
                            {
                                string str = $"这里可能是出现了并发的情况托盘码 在查询的时候拦截的【{wcsInfo.wcstask_barcode}】" +
                                        $"任务号【{wcsInfo.wcstask_taskNumber}】,任务状态:【{wcsInfo.wcstask_state}】";
                                LogRecord.WriteLog(LogEnum.Errer, str.ToString());
                            }
                        }
                    }
                    else
                    {
                        throw new Exception("入库申请失败:读取到的空托盘条码为空,读取内容:" + barcode);
                    }
                }
            }
            catch (Exception ex)
            {
                client.WriteValue(CLineInfoDBName.W_Line_PLCDispatch.ToString(), ReInboundRequestStationNo, 3);
                Console.Out.WriteLine(DateTime.Now + ex.Message);
            }
        }
    }
}