schangxiang@126.com
2025-09-29 682eba0aaf922e69dfafe05fb6c1bbdbf3a0e04a
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
using iWareCc.Properties;
using iWareCommon.Utils;
using iWareDataCore.ORM;
using iWareDataCore.TASK.EnumType;
using iWareLog.LOG.EnumType;
using iWareLog.ORM;
using iWareLog.Report.Helper;
using iWareLog.Report.Service;
using Newtonsoft.Json;
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
 
namespace iWareCc
{
    /// <summary>
    /// MES出入库数据传输(真正的MES)-线程
    /// </summary>
    public class mesDataTranfficForRealMesThread
    {
        //public static LogType _logType = LogType.mesDataTranfficForRealMes;
        public static async void Handler()
        {
            while (true)
            {
                try
                {
                    Thread.Sleep(5000);
 
                    List<InOutStorageDetailResultForMes> sendMesData = InOutService.GetInstance().GetInOutStorageDetailListForMes();
 
                    if (sendMesData.Count > 0)
                    {
                        //SystemWarningMsg.msg_mesDataTranfficForRealMes = $"{MyExtend.MsgTimeStr()},要推送{sendMesData.Count()}条!";
                        foreach (var itemTask in sendMesData)
                        {
                            using (DbModelLog mod = new DbModelLog())
                            {
                                try
                                {
                                    ApiResponse<string> ret = null;
                                    itemTask.Timestamp = DateTime.Now;//发送时间戳实时
 
                                    //转换
                                    var str_OccurrenceTime = "";
                                    if (itemTask.OccurrenceTime != null)
                                    {
                                        str_OccurrenceTime = ((DateTime)itemTask.OccurrenceTime).ToString("yyyy-MM-dd HH:mm:ss");
                                    }
                                    R_InOutStorageDetailResultForMes r = new R_InOutStorageDetailResultForMes()
                                    {
                                        BusinessFlag = itemTask.BusinessFlag.ToString(),
                                        Code = itemTask.Code,
                                        IssueProjectNo = itemTask.IssueProjectNo,
                                        PlaceCode = itemTask.PlaceCode,
                                        SerialNo = itemTask.SerialNo,
                                        Timestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
                                        OccurrenceTime = str_OccurrenceTime,
                                    };
 
                                    ret = PushMesHandler.Mes_InStockSend(r);
 
                                    //查找对象
                                    var db_itemTask = mod.InOutStorageDetails.Where(x => x.id == itemTask.Id).FirstOrDefault();
                                    //SystemWarningMsg.msg_mesDataTranfficForRealMes = $"{MyExtend.MsgTimeStr()},已推送结束,返回:{JsonConvert.SerializeObject(ret)}";
                                    if (ret.Success)
                                    {
                                        db_itemTask.isSendToMes = (int)EIsSendToMes.推送成功;//推送成功
                                        db_itemTask.isSendToMesStr = "成功";
                                    }
                                    else
                                    {
                                        db_itemTask.isSendToMes = (int)EIsSendToMes.待推送;//待推送
                                        db_itemTask.isSendToMesStr = "失败";
                                    }
                                    db_itemTask.SendToMesTime = DateTime.Now;
                                    db_itemTask.MesRet = ret.Message;
                                    db_itemTask.SendToMesCount = (db_itemTask.SendToMesCount ?? 0) + 1;
                                    if (db_itemTask.isSendToMes == (int)EIsSendToMes.待推送 && db_itemTask.SendToMesCount > 100)
                                    {
                                        db_itemTask.isSendToMes = (int)EIsSendToMes.强制完成;//表示强制推送成功
                                        db_itemTask.isSendToMesStr = "强制成功";
                                    }
                                    mod.SaveChanges();
 
                                }
                                catch (Exception ex)
                                {
                                    LogTextHelper.WriteLine(Resources.LogDir + @"/MES出入库数据传输/" + "mesDataTranfficForRealMesThread", "MES出入库数据传输异常:{0}", JsonConvert.SerializeObject(ex));
                                    //LogTextHelper.WriteLog(Resources.LogDir, this.ToString(), "Handle", ex.Message);
                                    //SystemWarningMsg.msg_mesDataTranfficForRealMes = $"{MyExtend.MsgTimeStr()},推送给MES数据异常:" + JsonConvert.SerializeObject(ex);
                                    //Log4NetHelper.WriteErrorLog(_logType, //SystemWarningMsg.msg_mesDataTranfficForRealMes, ex);
                                }
                            }
                        }
                    }
                }
                catch (Exception ex)
                {
                    LogTextHelper.WriteLine(Resources.LogDir + @"/MES出入库数据传输/" + "mesDataTranfficForRealMesThread", "(外部)MES出入库数据传输异常:{0}", JsonConvert.SerializeObject(ex));
                    //SystemWarningMsg.msg_mesDataTranfficForRealMes = $"{MyExtend.MsgTimeStr()},数据要推送给MES出现异常:" + ex.Message;
                    //Log4NetHelper.WriteErrorLog(_logType, //SystemWarningMsg.msg_mesDataTranfficForRealMes, ex);
                }
            }
        }
    }
}