hutongqing
2024-08-26 569e91c63636345391f741df049c9374a141a434
WIDESEAWCS_Server/WIDESEAWCS_Communicator/Siemens/SiemensS7Communicator.cs
@@ -151,11 +151,11 @@
                    for (int i = 0; i < 5; i++)
                    {
                        T readValue = Read<T>(address);
                        logMsg += $"【{Name}】PLC写入后读取数据,地址:【{address}】,读取的数据:【{value}】{Environment.NewLine}";
                        logMsg += $"【{Name}】PLC写入后读取数据,地址:【{address}】,读取的数据:【{readValue}】{Environment.NewLine}";
                        obj = readValue;
                        if (readValue.Equals(value))
                        {
                            logMsg += $"【{Name}】PLC写入后读取数据校验成功,地址:【{address}】,读取的数据:【{value}】,写入的数据:【{value}】{Environment.NewLine}";
                            logMsg += $"【{Name}】PLC写入后读取数据校验成功,地址:【{address}】,读取的数据:【{readValue}】,写入的数据:【{value}】{Environment.NewLine}";
                            return true;
                        }
                        else if(i < 4)
@@ -164,7 +164,7 @@
                        }
                    }
                    logMsg += $"【{Name}】PLC写入后读取数据校验失败,地址:【{address}】,读取的数据:【{value}】,写入的数据:【{value}】{Environment.NewLine}";
                    logMsg += $"【{Name}】PLC写入后读取数据校验失败,地址:【{address}】,读取的数据:【{obj}】,写入的数据:【{value}】{Environment.NewLine}";
                    throw new CommunicationException(string.Format(CommunicationExceptionMessage.ReadWriteDifferentException, typeof(T).Name, address, value, obj), CommunicationErrorType.WriteFailed);
                }
@@ -173,6 +173,10 @@
            {
                LogNet.WriteException(Name, $"【{Name}】PLC写入异常,地址:【{address}】,写入的数据:【{value}】,错误信息:【{ex.Message}】", ex);
                throw new CommunicationException(ex.Message, CommunicationErrorType.WriteFailed, innerException: ex);
            }
            finally
            {
                LogNet.WriteInfo(Name, logMsg);
            }
        }
@@ -659,14 +663,17 @@
        #region WriteCustomer
        public override bool WriteCustomer<T>(string address, T value)
        {
            string logMsg = string.Empty;
            try
            {
                OperateResult operateResult = plc.WriteCustomer(address, value);
                logMsg += $"【{Name}】PLC写入数据,地址:【{address}】,写入的数据:【{JsonConvert.SerializeObject(value)}】{Environment.NewLine}";
                if (operateResult.IsSuccess)
                {
                    for (int i = 0; i < 5; i++)
                    {
                        T readValue = ReadCustomer<T>(address);
                        logMsg += $"【{Name}】PLC写入后读取数据,地址:【{address}】,读取的数据:【{JsonConvert.SerializeObject(readValue)}】{Environment.NewLine}";
                        PropertyInfo[] propertyInfos = typeof(T).GetProperties();
                        foreach (var item in propertyInfos)
                        {
@@ -676,12 +683,15 @@
                                object readValueItem = item.GetValue(readValue);
                                if (writeValueItem.Equals(readValueItem))
                                {
                                    break;
                                    logMsg += $"【{Name}】PLC写入后读取数据校验成功,地址:【{address}】,读取的数据:【{JsonConvert.SerializeObject(readValue)}】,写入的数据:【{JsonConvert.SerializeObject(value)}】{Environment.NewLine}";
                                    return true;
                                }
                                else
                                {
                                    plc.WriteCustomer(address, value);
                                }
                                logMsg += $"【{Name}】PLC写入后读取数据校验失败,地址:【{address}】,读取的数据:【{JsonConvert.SerializeObject(readValue)}】,写入的数据:【{JsonConvert.SerializeObject(value)}】{Environment.NewLine}";
                                throw new CommunicationException(string.Format(CommunicationExceptionMessage.ReadWriteDifferentException, typeof(T).Name, address, JsonConvert.SerializeObject(value), JsonConvert.SerializeObject(readValue)), CommunicationErrorType.WriteFailed);
                            }
                        }
@@ -698,6 +708,10 @@
                LogNet.WriteException(Name, $"【{Name}】PLC写入异常,地址:【{address}】,写入的数据:【{JsonConvert.SerializeObject(value)}】,错误信息:【{ex.Message}】", ex);
                throw new CommunicationException(ex.Message, CommunicationErrorType.WriteFailed, innerException: ex);
            }
            finally
            {
                LogNet.WriteInfo(Name, logMsg);
            }
        }
        #endregion