| | |
| | | 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) |
| | |
| | | } |
| | | } |
| | | |
| | | 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); |
| | | } |
| | |
| | | { |
| | | LogNet.WriteException(Name, $"【{Name}】PLC写入异常,地址:【{address}】,写入的数据:【{value}】,错误信息:【{ex.Message}】", ex); |
| | | throw new CommunicationException(ex.Message, CommunicationErrorType.WriteFailed, innerException: ex); |
| | | } |
| | | finally |
| | | { |
| | | LogNet.WriteInfo(Name, logMsg); |
| | | } |
| | | |
| | | } |
| | |
| | | #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) |
| | | { |
| | |
| | | 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); |
| | | } |
| | | } |
| | |
| | | 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 |