Web开发:ABP框架6——appsetting.json的读取以及实例的注入

目录

一、模块配置服务

二、配置服务的编写(配置ORM)

[三、高层代码的运用(ORM实例查询 & 获取字符串)](#三、高层代码的运用(ORM实例查询 & 获取字符串))

一、模块配置服务

BookStoreHttpApiHostModule

二、配置服务的编写(配置ORM)

(以freesql为例子)

cs 复制代码
public static class MultiDBSetup
{
    public static void AddMultiDB(this IServiceCollection services)
    {
        var configuration = services.GetConfiguration();
        var conn = configuration.GetSection("ConnectionStrings").GetChildren().FirstOrDefault().Value;//获取连接字符串
        IFreeSql fsql = new FreeSql.FreeSqlBuilder()
                            .UseConnectionString(FreeSql.DataType.SqlServer, conn)
                            .UseMonitorCommand(cmd => Console.WriteLine($"Sql:{cmd.CommandText}"))
                            .UseAutoSyncStructure(false) //取消自动同步实体结构到数据库,只有CRUD时才会生成表
                            .Build();

        services.AddSingleton<IFreeSql>(fsql);//将这个实例注册为单例服务,以便其他服务可以通过依赖注入获取 IFreeSql 的实例
    }
}

连接字符串格式:

javascript 复制代码
{
  "App": {
    "CorsOrigins": "https://*.BookStore.com"
  },
  "ConnectionStrings": {
    "Default": "Server=localhost; Database=TestABP;Trusted_Connection=True;TrustServerCertificate=true"
  },
  "Redis": {
    "Configuration": "127.0.0.1"
  }
}

关键代码:

cs 复制代码
var conn = configuration.GetSection("ConnectionStrings").GetChildren().FirstOrDefault()?.Value;//获取连接字符串

三、高层代码的运用(ORM实例查询 & 获取字符串)

cs 复制代码
namespace Acme.BookStore.Books
{
    [Route("api/freesql")]
    public class BookSearchByFreesql : ApplicationService
    {
        private readonly IFreeSql _fsql;
        private readonly IConfiguration _configuration;
        public BookSearchByFreesql(IFreeSql fsql,IConfiguration configuration)
        {
            _fsql = fsql;
            _configuration = configuration;
        }

        /// <summary>
        /// 获取书本(freesql)
        /// </summary>
        /// <returns></returns>
        [Route("freesqlgetbook")]
        [HttpGet]
        public async Task<List<AppBooks>> GetListAsync()
        {
            try
            {
                var books = await _fsql.Select<AppBooks>().ToListAsync();//通过注入的IFreeSql实例进行查询
                return books;
            }
            catch (Exception ex)
            {
                throw new Exception(ex.ToString());
            }

        }

        /// <summary>
        /// 获取连接字符串(appsetting.json)
        /// </summary>
        /// <returns></returns>
        [Route("freesqlgetconn")]
        [HttpGet]
        public async Task<string> GetConn()
        {
            return _configuration.GetSection("ConnectionStrings").GetChildren().FirstOrDefault()?.Value;//通过注入的IConfiguration获取字符串

        }
    }
}
相关推荐
祈澈菇凉10 小时前
Next.js 零基础开发博客后台管理系统教程(八):提升用户体验 - 表单状态、加载与基础验证
前端·javascript·ux
电商API大数据接口开发Cris10 小时前
淘宝 API 关键词搜索接口深度解析:请求参数、签名机制与性能优化
前端·数据挖掘·api
小周同学10 小时前
vue3 上传文件,图片,视频组件
前端·vue.js
细心细心再细心10 小时前
runtime-dom记录备忘
前端
小猪努力学前端10 小时前
基于PixiJS的小游戏广告开发
前端·webgl·游戏开发
哆啦A梦158810 小时前
62 对接支付宝沙箱
前端·javascript·vue.js·node.js
i***118610 小时前
Windows环境下安装Redis并设置Redis开机自启
数据库·windows·redis
用户81686947472510 小时前
Lane 优先级模型与时间切片调度
前端·react.js
虎头金猫10 小时前
MateChat赋能电商行业智能导购:基于DevUI的技术实践
前端·前端框架·aigc·ai编程·ai写作·华为snap·devui
LiuMingXin10 小时前
CESIUM JS 学习笔记 (持续更新)
前端·cesium