net6 项目搭建及引用框架记录(log4net,autofac,exception,api result,jwt,efcore)五、统一返回值格式

在项目Utility中建立文件夹ApiResult,先建立 ResultHelper文件

 

 ResultHelper.cs

using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Logging;
using NET6Demo.IRepository;

namespace NET6Demo.Utility.ApiResult
{
    public class ResultHelper
    {
        private readonly ILogger<ResultHelper> _logger;
        private IResultModel _result;
        public ResultHelper(ILogger<ResultHelper> logger, IResultModel result)
        {
            _logger = logger;
            _result = result;
        }

        public IActionResult GetResult(int code, string msg = null, object value = null)
        {
            _result.StatusCode = code;
            _result.Result = value;
            if (string.IsNullOrWhiteSpace(msg))
            {
                if (code > 199 && code < 299)
                {
                    _result.Message = "success";
                }
                else if (code > 399 && code < 499)
                {
                    _result.Message = "error";
                }
                else if (code > 499 && code < 599)
                {
                    _result.Message = "reject";
                }
            }

            ObjectResult objResult = new ObjectResult(_result);
            return objResult;
        }
    }
}

再建立ApiResultFilterAttribute.cs文件

 

 

using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Filters;

namespace NET6Demo.Utility.ApiResult
{
    public class ApiResultFilterAttribute : ActionFilterAttribute
    {
        private ResultHelper _result;

        public ApiResultFilterAttribute(ResultHelper result)
        {
            _result = result;
        }

        public override void OnActionExecuting(ActionExecutingContext context)
        {
            base.OnActionExecuting(context);
        }
        public override void OnResultExecuting(ResultExecutingContext context)
        {
            var objectResult = context.Result as ObjectResult;
            var code = objectResult != null ? objectResult.StatusCode : 500;           
            context.Result = _result.GetResult((int)code, string.Empty, objectResult.Value);


        }
    }
}

在Utility项目的Autofac中注册ResultHelper

 

//api返回值处理
container.RegisterType<ResultHelper>().InstancePerLifetimeScope();

 在program.cs中添加统一返回值处理

#region 统一返回值
builder.Services.AddMvc(options =>
{
    options.Filters.Add<ApiResultFilterAttribute>();
});
#endregion

//加在这句话的上面
var app = builder.Build();

在TestController中添加代码进行测试

 

 运行代码,查看结果

 

 再换一个返回值,再测试一次

 

 

 

 到此统一返回值设置完毕。返回值内容可以根据项目需要再做修改

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在 WPF 中使用 log4net 实现依赖注入可以按照以下步骤进行: 1. 首先,确保你已经引入 log4net 库,并在你的项目中配置好 log4net。 2. 在你的应用程序的入口点(通常是 App.xaml.cs 文件中的 Application_Startup 方法),初始化 log4net。可以使用 `XmlConfigurator.Configure()` 方法来加载 log4net 的配置文件,或者使用 `BasicConfigurator.Configure()` 方法来使用默认的配置。例如: ```csharp using log4net; using log4net.Config; // ... public partial class App : Application { private static readonly ILog log = LogManager.GetLogger(typeof(App)); protected override void OnStartup(StartupEventArgs e) { base.OnStartup(e); XmlConfigurator.Configure(); // 或者 BasicConfigurator.Configure(); // ... 其他初始化代码 log.Info("Application started"); } } ``` 3. 创建一个接口来定义 log4net 的日志功能,例如 `ILogger` 接口: ```csharp public interface ILogger { void Debug(object message); void Info(object message); void Warn(object message); void Error(object message); void Fatal(object message); } ``` 4. 创建一个实现 `ILogger` 接口的 log4net 日志封装类: ```csharp using log4net; public class Log4NetLogger : ILogger { private readonly ILog log; public Log4NetLogger(Type type) { log = LogManager.GetLogger(type); } public void Debug(object message) { log.Debug(message); } public void Info(object message) { log.Info(message); } public void Warn(object message) { log.Warn(message); } public void Error(object message) { log.Error(message); } public void Fatal(object message) { log.Fatal(message); } } ``` 5. 在需要使用日志的类中,通过构造函数注入 `ILogger` 接口的实例。例如: ```csharp public class MyClass { private readonly ILogger logger; public MyClass(ILogger logger) { this.logger = logger; } public void DoSomething() { logger.Info("Doing something..."); // 其他逻辑 } } ``` 这样,在创建 `MyClass` 的实例时,可以通过依赖注入容器(如 Unity、Autofac 等)来自动解析并注入 `ILogger` 的实例,从而实现对 log4net 的依赖注入。 请注意,这里使用了简单的示例来说明 log4net 的依赖注入,实际应用中可能需要更复杂的配置和集成。具体的实现方式可能会根据你使用的依赖注入容器和项目结构而有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值