netcore入门-基础
.NETCORE1.0出来了,咦不错,什么开源,跨平台的,观望下等2.0;我擦2.0出来了可以学习了,截止到目前2.1都快出来了,是时候学习一下了。
先建一个webapi项目,从简单的demo开始
l 项目结构总览

新面孔:1)launchSettings.json (启动配置,里面还有环境变量)
2)appsettings.json (应用配置信息,老相好的webconfig的上位者)
3)Startup.CS ( asp.net core 启动时是调用startup类,类似Global.asax,startup 类主要干两件事情 1.可选择性地包括 ConfigureServices 方法以配置应用的服务、必须包括 Configure 方法以创建应用的请求处理管道。)
l 启动运行
不要被新面孔吓到,先运行下,与以往不同,可以进入项目目录使用命令(dotnet run)运行


l 使用Log4net将日志写入到文件及输出控制台,目前log4net已经支持core,利用自己之前封装的log库
1) 引用log4net -》Install-Package log4net -Version 2.0.8 、Install-Package AA.Log4Net -Version 1.0.0
2) 初始化log4net
public Startup(IConfiguration configuration)
{
Configuration = configuration;
//引入log4net
string path = AppDomain.CurrentDomain.BaseDirectory;
var file = Path.Combine(path, "LogCons.log4net.config");
var logRepository = LogManager.GetRepository(System.Reflection.Assembly.GetEntryAssembly());
XmlConfigurator.ConfigureAndWatch(logRepository, new FileInfo(file));
Log4NetLogger.Use();
}
3) 在ValuesController中打印一下日志
public IEnumerable<string> Get()
{
ILog log = Logger.Get(typeof(ValuesController));
log.Debug("测试 log4net 日志组件");
return new string[] { "value1", "value2" };
}
运行结果


l 获取配置
配置 API 支持内存中 .NET 对象、INI 文件、JSON 文件、XML 文件、命令行自变量、环境变量、加密的用户存储的配置提供程序,以及您创建的所有自定义提供程序。如果您希望对自己的配置利用 JSON 文件,只需添加 Microsoft.Extensions.Configuration.Json NuGet 包。然后,如果您想允许命令行提供配置信息,只需添加 Microsoft.Extensions.Configuration.CommandLine NuGet 包即可(可以在其他配置引用的基础上另外添加,也可以替代其他配置引用添加)。如果您对内置的所有配置提供程序都不满意,也可以创建您自己的提供程序,方法为实现 Microsoft.Extensions.Configuration.Abstractions 中的接口。

看下获取配置代码:
class Program
{
public static IConfiguration Configuration { get; set; }
static IReadOnlyDictionary<string, string> DefaultConfigurationStrings { get; } =
new Dictionary<string, string>()
{
["Profile:MachineName"] = "Rick",
[$",
[$",
[$",
[$",
};
static void Main(string[] args)
{
var builder = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json")
.AddInMemoryCollection(DefaultConfigurationStrings);//json文件
Configuration = builder.Build();
//1.通过索引器访问
Console.WriteLine($"MongoDatabase = {Configuration["MongoDatabase"]}");
//2.配置包含名称/值对的分层列表,其中节点由冒号 (:) 分隔。 要检索某个值,请使用相应项的键访问 Configuration 索引器:
Console.WriteLine(
$"HostName = {Configuration["RabbitMQ:HostName"]}");
//3.要在 JSON 格式的配置源中使用数组,请在由冒号分隔的字符串中使用数组索引。 以下示例获取上述 wizards 数组中第一个项的名称:
Console.WriteLine($:Name"]}");
Console.WriteLine($"Hello {Configuration["Profile:MachineName"]}");
//4.访问值并不仅限于检索字符串。
//例如,您可以通过 ConfigurationBinder 的 Get<T> 扩展方法检索值。比如,若要检索主要窗口屏幕Height,您可以使用:
);
Console.WriteLine($"Height {left}");
var window = new MyWindow();
// 5.这种绑定支持需要引用 Microsoft.Extensions.Configuration.Binder NuGet 包。
//配置值并不仅限于标量。您可以检索 POCO 对象或甚至整个对象图
Configuration.GetSection("App:MainWindow").Bind(window);
Console.WriteLine($"Left {window.Left}");
Console.WriteLine();
Console.WriteLine("Press a key...");
Console.ReadKey();
}
}
public class MyWindow
{
public int Height { get; set; }
public int Width { get; set; }
public int Top { get; set; }
public int Left { get; set; }
}
运行结果

netcore入门-基础的更多相关文章
- 如何在Visual Studio 2017中使用C# 7+语法 构建NetCore应用框架之实战篇(二):BitAdminCore框架定位及架构 构建NetCore应用框架之实战篇系列 构建NetCore应用框架之实战篇(一):什么是框架,如何设计一个框架 NetCore入门篇:(十二)在IIS中部署Net Core程序
如何在Visual Studio 2017中使用C# 7+语法 前言 之前不知看过哪位前辈的博文有点印象C# 7控制台开始支持执行异步方法,然后闲来无事,搞着,搞着没搞出来,然后就写了这篇博文,不 ...
- mybatis入门基础(二)----原始dao的开发和mapper代理开发
承接上一篇 mybatis入门基础(一) 看过上一篇的朋友,肯定可以看出,里面的MybatisService中存在大量的重复代码,看起来不是很清楚,但第一次那样写,是为了解mybatis的执行步骤,先 ...
- 01shell入门基础
01shell入门基础 为什么学习和使用shell编程 shell是一种脚本语言,脚本语言是相对于编译语言而言的.脚本语言不需要编译,由解释器读取程序并且执行其中的语句,而编译语言需要编译成可执行代码 ...
- Markdown入门基础
// Markdown入门基础 最近准备开始强迫自己写博文,以治疗严重的拖延症,再不治疗就“病入骨髓,司命之所属,无奈何”了啊.正所谓“工欲善其事,必先利其器”,于是乎在写博文前,博主特地研究了下博文 ...
- JavaScript入门基础
JavaScript基本语法 1.运算符 运算符就是完成操作的一系列符号,它有七类: 赋值运算符(=,+=,-=,*=,/=,%=,<<=,>>=,|=,&=).算术运 ...
- C++ STL编程轻松入门基础
C++ STL编程轻松入门基础 1 初识STL:解答一些疑问 1.1 一个最关心的问题:什么是STL 1.2 追根溯源:STL的历史 1.3 千丝万缕的联系 1.4 STL的不同实现版本 2 牛刀小试 ...
- HTML入门基础教程相关知识
HTML入门基础教程 html是什么,什么是html通俗解答: html是hypertext markup language的缩写,即超文本标记语言.html是用于创建可从一个平台移植到另一平台的超文 ...
- Linux shell入门基础(六)
六.Shell脚本编程详解 将上述五部分的内容,串联起来,增加对Shell的了解 01.shell脚本 shell: # #perl #python #php #jsp 不同的脚本执行不同的文本,执行 ...
- Linux shell入门基础(一)
Linux shell入门基础(一): 01.增加删除用户: #useradd byf userdel byf(主目录未删除) userdel -r byf 该用户的属性:usermod 用 ...
随机推荐
- Java实现堆的封装,进行插入,调整,删除堆顶以完成堆排序实例
简介 堆对于排序算法是一个比较常用的数据结构,下面我就使用Java语言来实现这一算法 首先,我们需要知道堆的数据结构的形式,其实就是一个特殊的二叉树.但是这个二叉树有一定的特点,除了是完全二叉树以外, ...
- Python 编程常见问题
Python 编程常见问题 经常使用Python编程,把经常遇到问题在这里记录一下,省得到网上查找,因此这篇文章会持续更新,需要的可以Mark一下.进入正题: 1.Python常用的文件头声明 #!/ ...
- ZooKeeper实现命名服务
使用场景 命名服务就是提供名称的服务,Zookeeper的命名服务有两个应用方面.一个是提供类似JNDI功能,另一个是制作分布式的序列号生成器. JNDI功能,我们利用Zookeep ...
- 网站开发进阶(三十二)HTML5之FileReader的使用
HTML5之FileReader的使用 HTML5定义了FileReader作为文件API的重要成员用于读取文件,根据W3C的定义,FileReader接口提供了读取文件的方法和包含读取结果的事件模型 ...
- FSM之SMC使用总结
FSM之SMC使用总结 Part1: Smc.jar state machine compiler usage Reference: http://smc.sourceforge.net/ ...
- 在自己的服务器上安装GitBook
更新时间:2016-08-05 更新说明: 由于在 Linux 内核的机器上安装 Calibre 需要安装的依赖库过多,故不推荐在此类机器上使用格式转换功能.你可以阅读 在自己的电脑上安装GitBoo ...
- Java之美[从菜鸟到高手演变]之设计模式二
在阅读过程中有任何问题,请及时联系:egg. 邮箱:xtfggef@gmail.com 微博:http://weibo.com/xtfggef 如有转载,请说明出处:http://blog.csdn. ...
- ceres-solver库使用示例
上一篇博客大致说明了下ceres-solver库的编译,然后形成了一个二次开发的库,下面就是用这个二次开发库来写一个简单(其实不太简单)的DEMO来演示ceres-solver库的强大.我们以求解一个 ...
- OpenGL Shader Key Points (1)
1. Shader起步 1.1. 可编程管线 仅考虑Vertex shader和fragment shader: 1.2. Shader Object 在编译阶段生成,把shader源代码编译成 ...
- Android NDK开发三:java和C\C++交互
转自:http://www.cnblogs.com/shangdahao/archive/2013/05/02/3053971.html 1.定义native方法并加载动态链接库: public cl ...