前言
最近有朋友問如何在.net core類庫中讀取配置文件,當(dāng)時(shí)一下蒙了,這個(gè)提的多好,我居然不知道,于是這兩天了解了相關(guān)內(nèi)容才有此篇文章的出現(xiàn),正常來講我們?cè)趹?yīng)用程序目錄下有個(gè)appsettings.json文件對(duì)于相關(guān)配置都會(huì)放在這個(gè)json文件中,但是要是我建立一個(gè)類庫項(xiàng)目,對(duì)于一些配置比如密鑰或者其他需要硬編碼的數(shù)據(jù)放在JSON文件中,在.net core之前配置文件為web.config并且有相關(guān)的類來讀取節(jié)點(diǎn)上的數(shù)據(jù),現(xiàn)如今在.net core中為json文件,那么我們?cè)撊绾巫觯勘疚木痛藨?yīng)運(yùn)而生。
.NET Core類庫項(xiàng)目讀取JSON配置文件
在應(yīng)用程序目錄下添加JSON文件是進(jìn)行如下配置:
1
2
3
4
5
6
|
var builder = new ConfigurationBuilder() .SetBasePath(env.ContentRootPath) .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true) .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true) .AddEnvironmentVariables(); Configuration = builder.Build(); |
然后讀取配置文件的節(jié)點(diǎn),如下:
1
2
3
4
5
6
|
public void ConfigureServices(IServiceCollection services) { services.Configure<BlogViewModel>(Configuration.GetSection( "JeffckySettings" )); ...... } |
但是如果項(xiàng)目是在類庫中呢,當(dāng)然我們也可以將配置值放在應(yīng)用程序下的appsettings.json中,但是為了不讓其json文件中看起來顯得非常臃腫同時(shí)在類庫中的配置數(shù)據(jù)我們理應(yīng)放在類庫中來統(tǒng)一管理,所以我們得另外再想方案,總不能在類庫中建立startup.cs類,再來實(shí)例化Configuration吧,這樣想想應(yīng)該也是可以,我沒嘗試過,難道就沒有很簡(jiǎn)單的方式么,難道就不能像.net core之前用類來讀取web.config我們只需要給出鍵而得到值嗎?或者說通過強(qiáng)類型配置來統(tǒng)一管理配置數(shù)據(jù),這個(gè)才應(yīng)該是我們嘗試的方向。好了,說了這么多,我們就開干。我們首先來復(fù)習(xí)下.net core中是如何獲取應(yīng)用程序路徑的。
.NET Core獲取應(yīng)用程序路徑
在.NET 4.X之前獲取當(dāng)前應(yīng)用程序根目錄路徑和名稱可以通過如下獲取
1
2
|
var basePath = AppDomain.CurrentDomain.BaseDirectory; var appName = AppDomain.CurrentDomain.ApplicationIdentity.FullName; |
當(dāng)然也可以通過如下來獲取應(yīng)用程序根目錄而不是得到bin目錄
1
|
Directory.GetCurrentDirectory() |
在.net core中獲取bin目錄路徑通過如下來獲取更加簡(jiǎn)潔。
1
|
AppContext.BaseDirectory |
在.NET 4.X之前獲取應(yīng)用程序集名稱通過如下來獲取:
1
|
Assembly.GetEntryAssembly().GetName().Name; |
在.net core中通過如下來獲取:
1
|
var name = typeof (T).GetTypeInfo().Assembly.GetName().Name; |
版本通過如下來獲取(.net core也一樣):
1
|
Assembly.GetEntryAssembly().GetName().Version.ToString() |
在類庫項(xiàng)目中我們利用強(qiáng)類型配置來實(shí)現(xiàn)讀取配文件數(shù)據(jù),我們首先需要下載如下擴(kuò)展。
在ConfigurationBuilder類中如下一個(gè)Add添加方法:
1
2
3
4
5
6
7
8
9
10
11
|
// // 摘要: // Adds a new configuration source. // // 參數(shù): // source: // The configuration source to add. // // 返回結(jié)果: // The same Microsoft.Extensions.Configuration.IConfigurationBuilder. public IConfigurationBuilder Add(IConfigurationSource source); |
對(duì)于AddJsonFile擴(kuò)展方法來添加JSON文件名,文件路徑已經(jīng)通過SetBasePath()方法來實(shí)現(xiàn),一切配置都是基于IConfigurationBuilder接口,其中就有一個(gè)JsonConfigurationSource類,實(shí)現(xiàn)如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
// // 摘要: // Represents a JSON file as an Microsoft.Extensions.Configuration.IConfigurationSource. public class JsonConfigurationSource : FileConfigurationSource { public JsonConfigurationSource(); // // 摘要: // Builds the Microsoft.Extensions.Configuration.Json.JsonConfigurationProvider // for this source. // // 參數(shù): // builder: // The Microsoft.Extensions.Configuration.IConfigurationBuilder. // // 返回結(jié)果: // A Microsoft.Extensions.Configuration.Json.JsonConfigurationProvider public override IConfigurationProvider Build(IConfigurationBuilder builder); } |
我們?cè)倏雌涓割惥陀幸粋€(gè)添加JSON文件路徑的方法,如下:
所以我們從這里可以看出添加JSON文件的方法除了通過擴(kuò)展方法來實(shí)現(xiàn)外還有直接實(shí)例化JsonConfigurationSource來實(shí)現(xiàn),如下:
1
2
3
4
5
|
IConfiguration config = new ConfigurationBuilder() .SetBasePath(currentClassDir) .AddJsonFile( "appsettings.json" , false , true ) .Add( new JsonConfigurationSource { Path = "appsettings.json" , Optional = false , ReloadOnChange = true }) .Build(); |
上述添加JSON文件皆可,我發(fā)現(xiàn)添加JSON文件必須設(shè)置JSON文件所在的目錄即必須首先要設(shè)置SetBasePath方法,否則會(huì)報(bào)如下錯(cuò)誤:
我們搞個(gè)測(cè)試JSON文件放在當(dāng)前項(xiàng)目(StudyEFCore.Data)中如下:
最終讀取類庫項(xiàng)目JSON配置文件,將其封裝起來就成了如下這個(gè)樣子:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
public class JsonConfigurationHelper { public T GetAppSettings<T>( string key) where T : class , new () { var baseDir = AppContext.BaseDirectory; var indexSrc = baseDir.IndexOf( "src" ); var subToSrc = baseDir.Substring(0, indexSrc); var currentClassDir = subToSrc + "src" + Path.DirectorySeparatorChar + "StutdyEFCore.Data" ; IConfiguration config = new ConfigurationBuilder() .SetBasePath(currentClassDir) .Add( new JsonConfigurationSource { Path = "appsettings.json" , Optional = false , ReloadOnChange = true }) .Build(); var appconfig = new ServiceCollection() .AddOptions() .Configure<T>(config.GetSection(key)) .BuildServiceProvider() .GetService<IOptions<T>>() .Value; return appconfig; } } |
由上有一個(gè)還未解決的問題就是如何得到當(dāng)前類庫項(xiàng)目的路徑,沒有想到一個(gè)好的法子,不知看到此文的你有何高見。簡(jiǎn)短的調(diào)用則是如下:
1
2
3
4
|
var config = new JsonConfigurationHelper(); var person = config.GetAppSettings<Person>( "JeffckySettings" ); var name = person.Name; var age = person.Age; |
結(jié)果如下:
我們將其類修改為ConfigurationManager,然后將其GetAppSettings方法定義為靜態(tài)方法,最后如下調(diào)用是不是滿足了在.net core之前讀取web.config中配置數(shù)據(jù)的問題。哈哈哈:
1
|
var person = ConfigurationManager.GetAppSettings<Person>( "JeffckySettings" ); |
總結(jié)
本節(jié)我們?cè)敿?xì)講解了在.net core類庫項(xiàng)目中如何讀取JSON配置中的數(shù)據(jù)但是還是有點(diǎn)不足,你有何高見?
原文鏈接:http://www.cnblogs.com/CreateMyself/p/6859076.html