Esempio n. 1
0
        /// <summary>
        /// 新增返回日志
        /// </summary>
        /// <param name="context"></param>
        /// <param name="next"></param>
        /// <returns></returns>
        public override async Task OnResultExecutionAsync(ResultExecutingContext context, ResultExecutionDelegate next)
        {
            #region 新增接口返回日志

            object logTraceID = null;
            context.HttpContext.Items.TryGetValue(nameof(APILogConfig.PoJun_LogTraceID), out logTraceID);
            if (logTraceID != null)
            {
                object _requestTime = null;
                context.HttpContext.Items.TryGetValue(nameof(APILogConfig.RequestTime), out _requestTime);
                var logParam = new AddResponseLogParam();
                if (context.Result != null)
                {
                    dynamic json = Newtonsoft.Json.Linq.JToken.Parse(Newtonsoft.Json.JsonConvert.SerializeObject(context.Result)) as dynamic;
                    logParam.ResponseBody = Convert.ToString(json.Value);
                }
                logParam.IsError       = false;
                logParam.ParentTraceID = logTraceID.ToString();
                logParam.ResponseTime  = DateTime.Now;
                logParam.TimeCost      = Convert.ToInt32((logParam.ResponseTime - Convert.ToDateTime(_requestTime)).TotalMilliseconds);
                await apiLogService.AddResponseLogAsync(logParam);
            }

            #endregion

            await base.OnResultExecutionAsync(context, next);
        }
Esempio n. 2
0
        /// <summary>
        ///
        /// </summary>
        /// <param name="context"></param>
        /// <returns></returns>
        public async Task OnExceptionAsync(ExceptionContext context)
        {
            var  dto     = new BaseResponse();
            bool isError = false;

            if (context.Exception.GetType().ToString() == typeof(PoJun.Shadow.Exception.RepeatSubmitException).ToString())
            {
                dto.DetailedStatus = DetailedStatusCode.RepeatSubmit;
                if (string.IsNullOrEmpty(context.Exception.Message))
                {
                    dto.DetailedMessage = $"{dto.DetailedStatus.Description()}";
                }
                else
                {
                    dto.DetailedMessage = $"{context.Exception.Message}";
                }
                dto.GatewayStatus  = GatewayStatusCode.Fail;
                dto.GatewayMessage = dto.GatewayStatus.Description();
            }
            else if (context.Exception.GetType().ToString() == typeof(PoJun.Shadow.Exception.ParamErrorException).ToString())
            {
                dto.DetailedStatus = DetailedStatusCode.ParamsError;
                if (string.IsNullOrEmpty(context.Exception.Message))
                {
                    dto.DetailedMessage = $"{dto.DetailedStatus.Description()}";
                }
                else
                {
                    dto.DetailedMessage = $"{context.Exception.Message}";
                }
                dto.GatewayStatus  = GatewayStatusCode.Fail;
                dto.GatewayMessage = dto.GatewayStatus.Description();
            }
            else if (context.Exception.GetType().ToString() == typeof(PoJun.Shadow.Exception.FailException).ToString())
            {
                dto.DetailedStatus = DetailedStatusCode.Fail;
                if (string.IsNullOrEmpty(context.Exception.Message))
                {
                    dto.DetailedMessage = $"{dto.DetailedStatus.Description()}";
                }
                else
                {
                    dto.DetailedMessage = $"{context.Exception.Message}";
                }
                dto.GatewayStatus  = GatewayStatusCode.Fail;
                dto.GatewayMessage = dto.GatewayStatus.Description();
            }
            else
            {
                dto.DetailedStatus  = DetailedStatusCode.Error;
                dto.DetailedMessage = $"{dto.DetailedStatus.Description()}";
                dto.GatewayStatus   = GatewayStatusCode.Fail;
                dto.GatewayMessage  = dto.GatewayStatus.Description();
                isError             = true;
            }
            var result = Newtonsoft.Json.JsonConvert.SerializeObject(dto);

            context.Result = new ContentResult()
            {
                Content = result
            };


            #region 新增接口返回日志

            object logTraceID = null;
            context.HttpContext.Items.TryGetValue(nameof(APILogConfig.PoJun_LogTraceID), out logTraceID);
            if (logTraceID != null)
            {
                object _requestTime = null;
                context.HttpContext.Items.TryGetValue(nameof(APILogConfig.RequestTime), out _requestTime);
                var logParam = new AddResponseLogParam();
                logParam.ResponseBody  = result;
                logParam.ErrorBody     = $"StackTrace:{context.Exception.StackTrace} | Message:{context.Exception.Message} | Source:{context.Exception.Source}";
                logParam.IsError       = isError;
                logParam.ParentTraceID = logTraceID.SafeString();
                logParam.ResponseTime  = DateTime.Now;
                logParam.TimeCost      = Convert.ToInt32((logParam.ResponseTime - Convert.ToDateTime(_requestTime)).TotalMilliseconds);
                await apiLogService.AddResponseLogAsync(logParam);
            }

            #endregion

            context.Exception = null;
        }
Esempio n. 3
0
        /// <summary>
        /// GET请求[同步]
        /// </summary>
        /// <typeparam name="T">只能传入DTO对象</typeparam>
        /// <param name="host">域名</param>
        /// <param name="apiName">接口名称(接口地址)</param>
        /// <param name="headers">请求头</param>
        /// <param name="timeout">请求响应超时时间,单位/s(默认100秒)</param>
        /// <returns></returns>
        public T HttpGet <T>(string host, string apiName, Dictionary <string, string> headers = null, int timeout = 100)
        {
            var client = clientFactory.CreateClient("base");
            {
                #region Http基础设置

                //设置HTTP请求头
                if (headers != null)
                {
                    foreach (KeyValuePair <string, string> header in headers)
                    {
                        client.DefaultRequestHeaders.Add(header.Key, header.Value);
                    }
                }
                //设置接口超时时间
                if (timeout > 0)
                {
                    client.Timeout = new TimeSpan(0, 0, timeout);
                }

                #endregion

                #region 新增请求日志

                var log_request_param = new AddRequestLogParam();
                log_request_param.APIName       = apiName.ToString().ToLower();
                log_request_param.ClientHost    = SysUtil.Ip;
                log_request_param.RequestTime   = DateTime.Now;
                log_request_param.ServerHost    = host;
                log_request_param.SystemID      = SysUtil.GetSystemId();
                log_request_param.TraceID       = PoJun.Util.Helpers.Id.GetGuidBy32();
                log_request_param.Level         = 2;
                log_request_param.ParentTraceID = SysUtil.GetTraceId();
                log_request_param.RequestBody   = null;
                if (SysUtil.GetTraceId() != null)
                {
                    log_request_param.Level         = 2;
                    log_request_param.ParentTraceID = SysUtil.GetTraceId();
                }
                else
                {
                    log_request_param.Level = 1;
                }
                var log_request_result = apiLogService.AddRequestLogAsync(log_request_param).Result;

                #endregion

                #region 发起Http请求

                var    url         = $"{host}{apiName}";
                Byte[] resultBytes = client.GetByteArrayAsync(url).Result;
                var    result      = Encoding.UTF8.GetString(resultBytes);

                #endregion

                #region 新增响应日志

                var log_response_param = new AddResponseLogParam();
                log_response_param.IsError       = false;
                log_response_param.ParentTraceID = log_request_param.TraceID;
                log_response_param.ResponseBody  = result;
                log_response_param.ResponseTime  = DateTime.Now;
                log_response_param.TimeCost      = Convert.ToInt32((log_response_param.ResponseTime - log_request_param.RequestTime).TotalMilliseconds);

                apiLogService.AddResponseLogAsync(log_response_param).Wait();

                #endregion

                #region 返回结果

                return(Newtonsoft.Json.JsonConvert.DeserializeObject <T>(result));

                #endregion
            }
        }