服务端的TigerApi 框架,基于.NET6 2024 版本
Ben Lin
2024-10-28 34380836fee980ccb7bdff70d4f72c66bdb3d3dc
Tiger.Business.MES/Task/Jobs.U9C_ME_GetCustSn.cs
@@ -1,5 +1,5 @@
using Rhea.Common;
using Sundial;
using FluentScheduler;
using System;
using System.Collections.Generic;
using System.Linq;
@@ -15,39 +15,58 @@
    /// <summary>
    /// 从U9C获取客户条码信息
    /// </summary>
    public class U9C_ME_GetCustSn : TigerJobBase, ITigerJob
    public class U9C_ME_GetCustSn : TigerJobBase, ITJob
    {
        public string Id { get; set; } = Guid.NewGuid().ToString("N");
        public string Tag { get; set; } = "U9C_ME_GetCustSn Interface Job";
        public string Name { get; set; } = "U9C_ME_GetCustSn Interface Job";
        public async Task ExecuteAsync(JobExecutingContext context, CancellationToken stoppingToken)
        public string Tag { get; set; }
        public string Name { get; set; }
        public U9C_ME_GetCustSn()
        {
            Logger.Scheduler.Info(context.Trigger.ConvertToMonitor());
            Id = Guid.NewGuid().ToString("N");
            Tag = "U9C_ME_GetCustSn Interface Job";
            GetJob(typeof(U9C_ME_GetCustSn).Name);
            Name = Job.JobName;
        }
        public void Execute()
        {
            #region 固定写法
            Logger.Scheduler.Info($"/**\r\n *进入计划调度(名称: {Name} )....\r\n */\r\n"); //固定写法
            Schedule = JobManager.GetSchedule(Name); //固定写法
            StartTime = DateTime.Now; //固定写法
            #endregion
            try
            {
                var _lastRunTime = Biz.SysParam["GetCustBar_LastTime", "Interface_LastRun"].PARAM_VALUE;
                var LastRunTime = string.IsNullOrEmpty(_lastRunTime) ? DateTime.Now.AddMinutes(-30) : Convert.ToDateTime(_lastRunTime);
                if ((DateTime.Now - LastRunTime).TotalMinutes > 30)
                string msg = "";
                string status = "Successed";
                GetJob(typeof(U9C_ME_GetCustSn).Name);
                TskJobInput tskJobInput = CheckIFCanGo();
                if (tskJobInput.result)
                {
                    GetCustBarcodeInput input = new GetCustBarcodeInput
                    {
                        startTime = LastRunTime.ToString("yyyy-MM-dd HH:mm:ss"),
                        endTime = LastRunTime.AddMinutes(30).ToString("yyyy-MM-dd HH:mm:ss")
                    };
                    var result = await DI.Resolve<IU9C_MES>().GetCustBarCode(input);
                    var result = DI.Resolve<IU9C_MES>().GetCustBarCode(tskJobInput.input);
                    if (!result.IsSuccessed)
                    {
                        Logger.Scheduler.Error($"获取客户条码信息异常:{result.Message}");
                        msg = $"获取客户条码信息异常:{result.Message}";
                        Logger.Scheduler.Error(msg);
                        status = "Failed";
                    }
                    else
                    {
                        msg = $"从U9C获取客户条码信息成功:{result.Message}";
                        //固定写法
                        Trig.LastRunTime = tskJobInput.input.endTime.ToDateTime();
                        Trig.NextRunTime = Schedule.NextRun;
                    }
                }
                //SaveLog(context, "从U9C获取客户条码信息成功");
                SaveFluentSchedulerLog(status, $"{msg}");
                Logger.Scheduler.Info($"计划调度(名称:{Name})完成,返回信息:{msg}\r\n");
            }
            catch (System.Exception ex)
            {
                Logger.Scheduler.Fatal(ex, "获取客户条码信息异常");
                SaveFluentSchedulerLog("Failed", ex.Message);
            }
            await Task.CompletedTask;
            Logger.Scheduler.Info($"/* 计划调度(名称:{Name})结束 */\r\n"); //固定写法
        }
    }
}