Как решить проблему событий в реальном времени zkemkeeper.dll внутри службы Windows? - PullRequest
0 голосов
/ 26 марта 2019

Я настраиваю службу Windows и хочу, чтобы она синхронизировала посещаемость устройства с базой данных SQL Server с помощью события zkemkeeper в реальном времени. Я успешно создал службу, а также протестировал службу в моей локальной системе, в которой работает Windows 10, и еще одна служба Windows 8 работает нормально и синхронизирует запись посещаемости с сервером БД в режиме реального времени. Теперь после успешного тестирования налокальная система я развернул службу на производственном сервере, где служба успешно установила соединение с устройством, но не отреагировала на событие в реальном времени для целей тестирования. Я создал приложение winform, запустил его на сервере и выяснил егоработает и слушает события в реальном времени, но мне нужен сервис, чтобы работать должным образом, а не выиграть форму заявки, любая помощь будет оценена, спасибо ниже мой код!

public partial class AttendanceSyncService_405 : ServiceBase
    {
        public AttendanceSyncService_405()
        {
            InitializeComponent();
        }
        System.Timers.Timer timer = new System.Timers.Timer();
        public zkemkeeper.CZKEMClass axCZKEM1 = new zkemkeeper.CZKEMClass();
        private bool bIsConnected = false;//the boolean value identifies whether the device is connected
        private int iMachineNumber = 1;//the serial number of the device.After connecting the device ,this value will be changed.

        protected override void OnStart(string[] args)
        {
            //var thread = new Thread();
            //thread.SetApartmentState(ApartmentState.STA);
            //thread.Start();
            WriteToFile("Service is started at " + DateTime.Now);
            Connect();


            // LoadCurrentMonthAtt();
            timer.Elapsed += new ElapsedEventHandler(OnElapsedTime);
            timer.Interval = 900000; //number in milisecinds  
            timer.Enabled = true;
        }

        protected override void OnStop()
        {
            WriteToFile("Service is stopped at " + DateTime.Now);
        }


        private void OnElapsedTime(object source, ElapsedEventArgs e)
        {
            if (bIsConnected == true)
            {
                WriteToFile("Service recall at " + DateTime.Now);
                WriteToFile("Device Status Connected at " + DateTime.Now);
            }
            else
            {
                WriteToFile("Device Status DisConnected at " + DateTime.Now);
                WriteToFile("Service recall at " + DateTime.Now);
                Connect();
            }
        }



        public void WriteToFile(string Message)
        {
            string path = AppDomain.CurrentDomain.BaseDirectory + "\\Logs";
            if (!Directory.Exists(path))
            {
                Directory.CreateDirectory(path);
            }
            string filepath = AppDomain.CurrentDomain.BaseDirectory + "\\Logs\\ServiceLog_" + DateTime.Now.Date.ToShortDateString().Replace('/', '_') + ".txt";
            if (!File.Exists(filepath))
            {
                // Create a file to write to.   
                using (StreamWriter sw = File.CreateText(filepath))
                {
                    sw.WriteLine(Message);
                }
            }
            else
            {
                using (StreamWriter sw = File.AppendText(filepath))
                {
                    sw.WriteLine(Message);
                }
            }
        }
        private void Connect()
        {
            try
            {

                int idwErrorCode = 0;


                bIsConnected = axCZKEM1.Connect_Net("192.168.0.177", 4370);
                if (bIsConnected == true)
                {
                    this.axCZKEM1.OnAttTransactionEx += new zkemkeeper._IZKEMEvents_OnAttTransactionExEventHandler(axCZKEM1_OnAttTransactionEx);
                    iMachineNumber = 1;
                    if (axCZKEM1.RegEvent(iMachineNumber, 65535))//Here you can register the realtime events that you want to be triggered(the parameters 65535 means registering all)
                    {
                        this.axCZKEM1.OnAttTransactionEx += new zkemkeeper._IZKEMEvents_OnAttTransactionExEventHandler(axCZKEM1_OnAttTransactionEx);
                    }
                    else
                    {
                        WriteToFile("RT Events didn't registered at " + DateTime.Now);
                    }
                    axCZKEM1.RegEvent(iMachineNumber, 65535);//Here you can register the realtime events that you want to be triggered(the parameters 65535 means registering all)
                    WriteToFile("Device Connection Established Successfully at " + DateTime.Now);
                }
                else
                {
                    axCZKEM1.GetLastError(ref idwErrorCode);
                    WriteToFile("Unable to connect the device,ErrorCode=" + idwErrorCode.ToString() + " at " + DateTime.Now);
                }
            }
            catch(Exception ex)
            {
                WriteToFile("Exception :" + ex.Message + " at " + DateTime.Now);

            }
        }

        private void axCZKEM1_OnAttTransactionEx(string sEnrollNumber, int iIsInValid, int iAttState, int iVerifyMethod, int iYear, int iMonth, int iDay, int iHour, int iMinute, int iSecond, int iWorkCode)
        {
            DateTime Attendancedate = new DateTime(iYear, iMonth, iDay, iHour, iMinute, iSecond);
            string row = sEnrollNumber + "," + Attendancedate.ToString();
            WriteToFile("Attendane :" + row + "  Marked At: " + DateTime.Now);
            if (bIsConnected == false)
            {
                Connect();
                return;
            }

            decimal empserial = decimal.Parse(sEnrollNumber);
            attInsert(empserial, Attendancedate);


        }

        private void attInsert(decimal empserial, DateTime Attendancedate)
        {
            try
            {
                WriteToFile("Attendance Entry Arrived for EMP-Serial :" + empserial + " At: " + DateTime.Now + " for Insertion");
                DBAccess db = new DBAccess();
                DataSet attCount = db.GetDataSetFromQuery("select Count(att.[todayCount]) as attCount from tblAttendance att where (att.attDate = Convert(date,GETDATE()) AND att.fkSerial ='" + empserial.ToString() + "')");
                int count = int.Parse(attCount.Tables[0].Rows[0]["attCount"].ToString());
                Boolean INOUT = (count % 2 == 0) ? true : false;
                WriteToFile("Attendane Count :" + count + " & In/Out : " + INOUT + "  Marked At: " + DateTime.Now);
                db.Parameters.AddWithValue("fkSerial", empserial);
                db.Parameters.AddWithValue("attTerminalId", "Time1");
                db.Parameters.AddWithValue("attDateTime", Attendancedate);
                db.Parameters.AddWithValue("attTgId", 3);
                db.Parameters.AddWithValue("attINOUT", INOUT);
                db.Parameters.AddWithValue("attEmpCode", "no need");
                db.ExecuteNonQuery("spInsertAttendance");
                WriteToFile("Attendance Inserted of EMP-Serial :" + empserial + " At: " + DateTime.Now);


            }
            catch (Exception ex)
            {
                WriteToFile("Exception in insert method  :" + ex.Message + " At: " + DateTime.Now);
            }

        }

    }

1 Ответ

0 голосов
/ 24 мая 2019

Введите этот код в свой IntializeComponent, и он будет реагировать на события в реальном времени

private void InitializeComponent()
{
    Thread createComAndMessagePumpThread = new Thread(() =>
    {
        axCZKEM1 = new zkemkeeper.CZKEMClass();
        bool connSatus = axCZKEM1.Connect_Net(192.168.0.177, 4370);
        if (connSatus == true)
        {

            this.axCZKEM1.OnAttTransactionEx -= new zkemkeeper._IZKEMEvents_OnAttTransactionExEventHandler(axCZKEM1_OnAttTransactionEx);

            if (axCZKEM1.RegEvent(1, 65535))//Here you can register the realtime events that you want to be triggered(the parameters 65535 means registering all)
            {

                this.axCZKEM1.OnAttTransactionEx += new zkemkeeper._IZKEMEvents_OnAttTransactionExEventHandler(axCZKEM1_OnAttTransactionEx);

            }
        }
        Application.Run();
    });

    createComAndMessagePumpThread.SetApartmentState(ApartmentState.STA);

    createComAndMessagePumpThread.Start();
    components = new System.ComponentModel.Container();
    this.ServiceName = "Service1";
}
...