/// <summary> /// 定时执行考勤机业务 /// </summary> /// <param name="obj"></param> void tmWorkGather(object obj) { QueryDataRes query = new QueryDataRes("门禁管理"); NameObjectList ps = new NameObjectList(); DataTable tab = query.getTable("门禁管理", ps); if (null == tab || tab.Rows.Count < 1) return; myLog.WriteLine(DateTime.Now.ToString("HH:mm:ss.fff") + " 启动定时执行"); CommiManager commimgr = CommiManager.GlobalManager; for (int i = 0; i < tab.Rows.Count; i++) { DataRow dr = tab.Rows[i]; if (null == dr || DBNull.Value == dr["ID"] || DBNull.Value == dr["站址"]) continue; if ("考勤机" != Convert.ToString(dr["控制器类型"])) continue; string devid = Convert.ToString(dr["ID"]); int station = Convert.ToInt32(dr["站址"]); string devname = devname = Convert.ToString(dr["名称"]); myLog.WriteLine(DateTime.Now.ToString("HH:mm:ss.fff") + " 考勤设备:" + Convert.ToString(dr["站址"]) + " " + devname); CommiTarget target = this.getTarget(dr); if (null == target) continue; DeviceDoor device = new DeviceDoor(); target.setProtocol(Protocol.PTLDoor); device.IsPatrol = false; device.dtBeat = DateTime.Now; device.SetDevice(commimgr, target, devid, station); string msg = device.GatherData(true); string cardnum = basefun.valtag(msg, "{卡号}"); myLog.WriteLine(DateTime.Now.ToString("HH:mm:ss.fff") + " 采集信息 0:" + msg); if ("0" == cardnum || "16777215" == cardnum) { if (device.IsEndReadDevice(-1)) continue; } int index = 1; while (!string.IsNullOrEmpty(cardnum)) { msg = device.GatherData(false); myLog.WriteLine(DateTime.Now.ToString("HH:mm:ss.fff") + " 采集信息" + Convert.ToString(index++).PadLeft(4, ' ') + ":" + msg); cardnum = basefun.valtag(msg, "{卡号}"); if ("0" == cardnum || "16777215" == cardnum) { if (device.IsEndReadDevice(-1)) break; } } } }
private static void gatherData(object obj) { dtRunHdl = DateTime.Now; while (true) { hdlWh.Reset(); for (int i = 0; i < 200; i++) { if (dvQueue.Count > 0) { break; } dtRunHdl = DateTime.Now; hdlWh.WaitOne(20); } if (dvQueue.Count < 1) { dtRunHdl = DateTime.MinValue; break; } DeviceDoor door = null; Monitor.Enter(dvQueue); try { door = dvQueue.Dequeue(); } catch { } Monitor.PulseAll(dvQueue); Monitor.Exit(dvQueue); if (null == door) { continue; } //采集记录 if (null != door.cmdGather) { door.cmdGather.TimeSendInv = door.tsbusy.Add(door.tsinv); } else { door.reChecking(0); } CmdProtocol cmdP = new CmdProtocol(false); setTimeout(cmdP); cmdP.TimeFailLimit = cmdP.TimeOut.Add(new TimeSpan(-10 * 10000)); cmdP.TimeLimit = TimeSpan.MaxValue; cmdP.TimeSendInv = new TimeSpan(1, 0, 0); cmdP.ResponseHandle += new EventHandler <ResponseEventArgs>(door.execResponse); cmdP.IsResposeHandle = isResponse; string tag = "@设备地址=" + Convert.ToString(door.station); NameValueCollection datainfo = new NameValueCollection(); string msgprev = ""; for (int i = 0; i < 200; i++) { tag = basefun.setvaltag(tag, "{记录索引}", Convert.ToString(door.posRecord)); string msg = door.getResponse(door.commimgr, door.target, cmdP, "读取记录", tag, door.waitTime); if (string.IsNullOrEmpty(msg)) { continue; } if (string.IsNullOrEmpty(msgprev)) { msgprev = msg; } string cardnum = basefun.valtag(msg, "{卡号}"); string suc = basefun.valtag(msg, "Success"); if ("true" != suc || "16777215" == cardnum || "0" == cardnum) { //bool isend = door.IsEndReadDevice(-1); //记录错误时记入日志,继续下一条 if ("false" == suc) { door.posRecord++; datainfo["操作"] = "读取记录失败"; datainfo["报文"] = CommandBase.Parse(cmdP.ResponseData, true); ServiceTool.LogMessage(msg, datainfo, EventLogEntryType.FailureAudit); } //if (isend && door.posRecord > 20000) // door.ClearRecord(); //if (isend) break; if (door.posRecord > 20000) { bool isend = door.IsEndReadDevice(-1); if (isend) { door.ClearRecord(); } } break; } msgprev = msg; if ("考勤机" == door.devtype) { door.writeRecord(msg, true); } door.posRecord++; } //门禁设备只处理最后一条记录 if (string.IsNullOrEmpty(msgprev) && "考勤机" != door.devtype) { door.writeRecord(msgprev, false); } door.commimgr.RemoveCommand(door.target, cmdP); if (null != door.cmdGather) { door.cmdGather.TimeSendInv = door.tsinv; } else { door.reChecking(1); } } }