private string GetXml(EntryHistoryEntity entity) { var flag = entity.SyncVersion == 0 ? "C" : "U"; //增|删|改,C|D|U if (entity.Deleted) { flag = "D"; } var xmlBuilder = new StringBuilder("<?xml version=\"1.0\" encoding=\"UTF-8\"?>"); xmlBuilder.Append("<Tpp2Fpp>"); xmlBuilder.Append("<ReqHeader>"); xmlBuilder.AppendFormat("<ReqSeqNo>{0}</ReqSeqNo>", Utils.MakeRndName()); xmlBuilder.AppendFormat("<ReqSPID>{0}</ReqSPID>", DESHelper.Encrypt3Des(Constant.LkbAccount, Constant.DescKeyBytes)); xmlBuilder.AppendFormat("<ReqCode>{0}</ReqCode>", DESHelper.Encrypt3Des(Constant.LkbPassword, Constant.DescKeyBytes)); xmlBuilder.Append("</ReqHeader>"); xmlBuilder.Append("<ReqBody>"); xmlBuilder.Append("<crjl>"); xmlBuilder.AppendFormat("<cardno>{0}</cardno>", "0000" + entity.Card.CardNo); xmlBuilder.AppendFormat("<person_uuid>{0}</person_uuid>", entity.Person.PersonUUID); xmlBuilder.AppendFormat("<mac>{0}</mac>", entity.Door.Device.Mac); xmlBuilder.AppendFormat("<opentype>{0}</opentype>", "C"); xmlBuilder.AppendFormat("<area_uuid>{0}</area_uuid>", entity.Door.AreaUUID); xmlBuilder.AppendFormat("<slide_date>{0}</slide_date>", entity.EntryTime.ToString("yyyyMMddHHmmss")); xmlBuilder.AppendFormat("<cdate>{0}</cdate>", entity.CreateTime.ToString("yyyyMMddHHmmss")); xmlBuilder.AppendFormat("<dev_uuid>{0}</dev_uuid>", entity.Door.DoorUUID); //对应的门ID xmlBuilder.AppendFormat("<area_code>{0}</area_code>", entity.Door.Area.AreaCode); xmlBuilder.AppendFormat("<dev_date>{0}</dev_date>", ""); xmlBuilder.AppendFormat("<flag>{0}</flag>", flag); xmlBuilder.Append("</crjl>"); xmlBuilder.Append("</ReqBody> "); xmlBuilder.Append("</Tpp2Fpp> "); return(xmlBuilder.ToString()); }
private void Synchronization(EntryHistoryEntity entity) { if (Constant.Sysc) { try { var requestXml = GetXml(entity); Log.Debug(this.GetType().ToString(), requestXml); var areaS = new Lkb.CrjlServiceImplService(); var responseXml = areaS.insertCrjl(requestXml); Log.Debug(this.GetType().ToString(), responseXml); var syncLog = new SyncLogEntity(); syncLog.SyncType = SyncLogEnum.InsertCrjl.ToString(); syncLog.ResquestXml = requestXml; syncLog.ResponseXml = responseXml; syncLog.SyncTime = DateTime.Now; syncLog.SyncResult = 0; syncLog.CommunityId = ""; var resultRes = responseXml.Deserial <ResultResponse>(); if (resultRes != null && resultRes.Header != null) { var header = resultRes.Header; if (header.RspCode.Equals("0")) { var entity2 = _entryRepository.GetById(entity.EntryUUID); entity2.SyncVersion += 1; entity2.SyncStatus = true; _entryRepository.Update(entity2); syncLog.SyncResult = 1; } } _syncService.InsertSyncLog(syncLog); } catch (Exception ex) { Log.Error(null, ex.Message); } } }