博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用Func<T, TResult> 委托实现API日志的记录
阅读量:4036 次
发布时间:2019-05-24

本文共 2308 字,大约阅读时间需要 7 分钟。

问题

平常我们开发web api的时候,一般是需要记录api的输入输出信息,方便后续排查问题;那么我们一般怎么做的,一般是我们在一个公共地方的写个公共方法控制输入输出。这时候Func<T, TResult> 委托就派上用场。

什么是Func

Func<T, TResult>封装一个具有一个参数并返回 TResult 参数指定的类型值的方法。使用Func<T, TResult> 委托表示一种能以参数形式传递的方法,而不用显式声明自定义委托。 封装的方法必须与此委托定义的方法签名相对应。 也就是说,封装的方法必须具有一个通过值传递给它的参数,并且必须返回值。在使用 Func<T, TResult> 委托时,不必显式定义一个封装只有一个参数的方法的委托。

主要代码实现

1、定义委托。

private ApiResult HandleWork(CreateBQoolSyncEventModel syncModel, Func
work) { //先記錄到 Db Event _innerBQoolSyncEventLogService.Create(syncModel); var result = new ApiResult(); try { _logger.Info($"Call Web Api Start, data:{syncModel.ToJsonString()}"); result = work(); if (!result.Success && !string.IsNullOrEmpty(result.Code) && string.IsNullOrEmpty(result.ErrorMessage)) { result.ErrorMessage = ApiResultCode.ErrorMessages[result.Code]; } } catch (Exception ex) { _logger.Error(ex.ToString()); result.Success = false; if (string.IsNullOrEmpty(result.ErrorMessage)) { result.ErrorMessage = ex.Message; } else { result.ErrorMessage += "; " + ex.Message; } } finally { _logger.Info($"Call Web Api End , result:{result.ToJsonString()}"); //更新 Db event syncModel.SetStatus(result.Success ? BQoolSyncEventStatus.Success : BQoolSyncEventStatus.Failure); _innerBQoolSyncEventLogService.ChangeStatus(syncModel.Id, syncModel.Status, result.ErrorMessage); } return result; }

2、把方法当做参数,传入委托。

[HttpPost]        public ApiResult ModuleFeatureSetting(ReviewsApiRequestModel model)        {            string data = StringTools.AESDecrypt(model.Encrypt);            var param = JObject.Parse(data).ToObject
(); ApiResult result = HandleWork( new CreateBQoolSyncEventModel(param.Account, BQoolSyncEventType.ModuleFeatureSetting, param) , () => _ReviewsSettingSyncService.ModuleFeatureSetting(param)); return result; }

3、查看日志。

转载地址:http://jsudi.baihongyu.com/

你可能感兴趣的文章
所谓的进步和提升,就是完成认知升级
查看>>
昨夜今晨最大八卦终于坐实——人类首次直接探测到了引力波
查看>>
如何优雅、机智地和新公司谈薪水?
查看>>
为什么读了很多书,却学不到什么东西?
查看>>
长文干货:如何轻松应对工作中最棘手的13种场景?
查看>>
如何用好碎片化时间,让思维更有效率?
查看>>
No.147 - LeetCode1108
查看>>
No.174 - LeetCode1305 - 合并两个搜索树
查看>>
No.175 - LeetCode1306
查看>>
No.176 - LeetCode1309
查看>>
No.182 - LeetCode1325 - C指针的魅力
查看>>
mysql:sql create database新建utf8mb4 数据库
查看>>
mysql:sql alter database修改数据库字符集
查看>>
mysql:sql drop table (删除表)
查看>>
mysql:sql truncate (清除表数据)
查看>>
scrapy:xpath string(.)非常注意问题
查看>>
yuv to rgb 转换失败呀。天呀。谁来帮帮我呀。
查看>>
yuv420 format
查看>>
YUV420只绘制Y通道
查看>>
yuv420 还原为RGB图像
查看>>