1
z8018
2025-03-12 17e4c7e3e7b3ef60d9da6de3b2a39a14a53c38a0
WIDESEAWCS_Server/WIDESEAWCS_Communicator/Siemens/SiemensS7Communicator.cs
@@ -88,6 +88,11 @@
        /// PLC读写日志记录
        /// </summary>
        public override ILogNet LogNet => _logNet;
        /// <summary>
        /// 是否在写入数据后读取数据确认。
        /// </summary>
        public override bool IsReadAfterWrite { get; set; } = true;
        #endregion Public Member
        #region Constructor Function
@@ -165,6 +170,8 @@
                }
                else
                {
                    if (IsReadAfterWrite)
                    {
                    object? obj = null;
                    for (int i = 0; i < 5; i++)
                    {
@@ -183,6 +190,11 @@
                    }
                    stringBuilder.AppendLine(string.Format(CommunicationExceptionMessage.WriteAndReadCheckFaild, address, value, obj));
                    throw new CommunicationException(stringBuilder.ToString(), CommunicationErrorType.WriteFailed);
                    }
                    else
                    {
                        return true;
                    }
                }
            }
            catch (Exception ex)
@@ -693,6 +705,8 @@
                stringBuilder.AppendLine(string.Format(CommunicationInfoMessage.WriteData, address, JsonConvert.SerializeObject(value)));
                if (operateResult.IsSuccess)
                {
                    if (IsReadAfterWrite)
                    {
                    object? obj = null;
                    for (int i = 0; i < 5; i++)
                    {
@@ -704,7 +718,7 @@
                        {
                            object? writeValueItem = propertyInfos[j].GetValue(value);
                            object? readValueItem = propertyInfos[j].GetValue(readValue);
                            if (writeValueItem?.Equals(readValueItem) ?? false)
                                if (writeValueItem.Equals(readValueItem))
                            {
                                stringBuilder.AppendLine(string.Format(CommunicationInfoMessage.WriteAndReadCheckSuccess, address, JsonConvert.SerializeObject(value), JsonConvert.SerializeObject(readValue)));
                            }
@@ -723,6 +737,11 @@
                }
                else
                {
                        return true;
                    }
                }
                else
                {
                    throw new CommunicationException(string.Format(CommunicationExceptionMessage.WriteFailedException, typeof(T).Name, address, JsonConvert.SerializeObject(value), operateResult.Message), CommunicationErrorType.WriteFailed);
                }
            }