前言

在应用程序开发的过程中,有的时候需要在代码中保存一些机密的信息,比如加密密钥,字符串,或者是用户名密码等。通常的做法是保存到一个配置文件中,在以前我们会把他保存到web.config中,但是在ASP.NET Core中,这一方式或许发生了改变,或者说你有更多多元化的方法, 以及更加优雅的的配置来设置或者保存这些机密资料。

起初我以为这个UserSecrets它并没有什么用,因为我有需要配置的地方我直接配置到appsetting.json文件中就可以了,直到一次开发过程中,我才感受到了它真正的用途。

目录

  • 用户机密介绍

  • 如何添加用户机密

  • 在应用程序中使用用户机密

  • 总结

用户机密介绍

有以下场景大家可以想一下在以前的代码中我们是怎么样处理的:

  • 需要保存一些和第三方网站对接的密钥,比如和 微信,微博站点使用的 appkey

  • 给每个开发人员配置不用的用户名密码来访问一些资源

  • 开发人员在开发过程中使用各自本机的数据库,如何配置数据库地址、账号和密码

假设说最后一项,每个开发要使用自己本机的数据库,你可能会说让每个人修改自己的web.config,在提交代码的时候不提交就行了。那么如果在web.config添加其他配置项的时候,显然不提交web.config文件不合理的。

现在,ASP.NET Core 提供了一种很优雅简洁的方式 User Secrets 用来帮助我们解决这个事情。

在新建一个 ASP.NET Core Web 应用程序的时候,会在 Startup.cs 文件中看到这样一段代码:

public Startup(IHostingEnvironment env) {.....    if (env.IsDevelopment()){builder.AddUserSecrets();}builder.AddEnvironmentVariables();
}

project.json 文件中,会看到 User Secrets 相关的一些配置

{"userSecretsId": "aspnet-WebAppCore-e278c40f-15bd-4c19-9662-541514f02f3e"...    "Microsoft.Extensions.Configuration.UserSecrets": "1.0.0","Microsoft.Extensions.SecretManager.Tools": “1.0.0-preview2-final”
}

可以看到builder.AddUserSecrets这行代码,他是在开发环境才运行的。

userSecretsId是用来标识项目的User Secrets唯一性的,如果有两个项目需要使用不同的Secrets ,这就需要有不同的userSecretsId。

Microsoft.Extensions.SecretManager.Tools 主要是用来设置或者查看secrets的值。

如何添加用户机密

可以在命令行中使用命令来添加:

  • 切换命令行窗口到程序的运行目录, 输入 dotnet user-secrets -h ,来查看可以使用的命令

  • 使用 dotnet user-secrets list 列出所有的用户机密

  • 使用 dotnet user-secrets set WeChatAppKey "X3423FEED2435DD"设置一个用户机密,其中 WebChatAppKey 为键,后面的是值。

  • 然后使用dotnet user-secrets list来查看设置的键值对。

  • 然后我又设置了一个数据库的连接字符串进去。

以上是使用命令行的方式来设置用户机密,也可以使用 Visual Studio 2015代替命令行来做这项工作。

Visual Studio中,在Web项目上右键,可以看到一个 管理用户机密 的菜单:

点击打开时候,会出现一个secrets.json的文件,里面就是刚刚在命令行设置的键值对:

有些同学可能会问既然是存储到secrets.json,那么这个文件是在哪里呢?

secrets.json的存储位置?

在非Windows系统中,它的存储位置在

~/.microsoft/usersecrets/<userSecretsId>/secrets.json

在Windows系统中,它的位置在

C:\Users\用户名\AppData\Roaming\Microsoft\UserSecrets\aspnet-WebAppCore-e278c40f-15bd-4c19-9662-541514f02f3e

可以看到,存储的上层文件夹就是project.json文件中的 userSecretsId 设定的值。

在应用程序中使用用户机密

要在应用程序中访问配置的用户机密,你需要保证project.json文件中存在依赖项:
Microsoft.Extensions.Configuration.UserSecrets 并且builder.AddUserSecrets()

然后在Startup.cs文件中通过 Configuration 对象访问

public IConfigurationRoot Configuration { get; }

public void ConfigureServices(IServiceCollection services){        var wechatKey = Configuration["WeChatAppKey"]
}

你可以使用DI来将用户机密映射到一个C#类文件,像这样

secrets.json

{    "SecretsKeys":{WeCharAppKey:"xxejfwert3045",WeboAppKey:"35402345lkefgjlkdfg",.....}
}

SecretsKeysConfig.cs

public class SecretsKeysConfig{        public string WeCharAppKey { get; set;}    public string WeboAppKey { get; set;}    // ......}

Startup.cs

public void ConfigureServices(IServiceCollection services){services.Configure<SecretsKeysConfig>(Configuration.GetSection("SecretsKeys"));    // 其他代码}

HomeController.cs

public class HomeController : Controller{    public SecretsKeysConfig AppConfigs { get; }     public HomeController(IOptions<SecretsKeysConfig> appkeys)    {AppConfigs = appkeys.Value;}}

注意:如果你的appsetting.json文件中有和secrets.json文件中相同节点(冲突)的配置项,那么就会被secrets.json中的设置项给覆盖掉,因为 builder.AddUserSecrets()晚于 AddJsonFile("appsettings.json")注册, 那么我们可以利用这个特性来在每个开发人员的机器上重新设置数据库连接字符串了。

总结

以上,或许可以感受到微软在 ASP.NET Core 中对于开发人员还是非常贴心的,很多小细节都考虑到了,因此在我们构建应用程序的过程中,可以多使用这些小功能(特性)来让我们的代码更加的优雅~

原文地址:http://www.cnblogs.com/savorboard/p/dotnetcore-user-secrets.html


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

赞赏

ASP.NET Core 优雅的在开发环境保存机密(User Secrets)相关推荐

  1. ASP.NET Core 2.0 : 二. 开发环境

    ASP.NET Core 系列目录 macOS:Install Visual Studio for Mac 系统要求: macOS 10.12 Sierra 及更高版本 其他要求: 可能会要求安装xc ...

  2. ASP.NET Core 发布至Linux生产环境 Ubuntu 系统

    ASP.NET Core 发布至Linux生产环境 Ubuntu 系统,之前跟大家讲解了 dotnet publish 发布,而没有将整个系统串起来. 今天就跟大家综合的讲一下ASP.NET Core ...

  3. 《ASP.NET Core 与 RESTful API 开发实战》-- (第10章)-- 读书笔记

    第 10 章 部署 10.1 部署到 IIS ASP.NET Core 应用程序支持部署到 IIS 中,之后它将作为应用程序的反向代理服务器和负载均衡器,向应用程序中转传入的 HTTP 请求 默认情况 ...

  4. 如何配置一套优雅的Lua开发环境

    讨论话题 何为优雅的开发环境 如何部署(本文讨论在MacOSX平台,其他平台也一样适用) 优雅的Lua开发环境 优雅的Lua开发环境至少包含以下几点: 安装适合需求的最新稳定版Lua 安装合适的Lua ...

  5. 在ASP.NET Core中使用Apworks开发数据服务:对HAL的支持

    HAL,全称为Hypertext Application Language,它是一种简单的数据格式,它能以一种简单.统一的形式,在API中引入超链接特性,使得API的可发现性(discoverable ...

  6. 52abp框架asp.net core Angular全栈开发实战视频课程

    课程标题 52abp框架asp.net core & Angular全栈开发实战视频课程 课程简介 从零开始学 52ABP企业开发框架,企业项目是如何开发和技术选型,代码如何管理,团队协同开发 ...

  7. .net core项目实战之开发环境搭建

    在上一篇[.net core项目实战之回顾总结]主要介绍了项目背景和自己的一些想法,从本篇开始正式叙述整个开发过程,本篇主要介绍一下开发前的环境准备,vs2017和docker的安装与配置 系统要求 ...

  8. NET问答: 发布 asp.net core 时如何修改 ASPNETCORE_ENVIRONMENT 环境变量?

    咨询区 Dario: 当我把 asp.net core web 发布到本地文件时,我发现程序读的是 appsettings.Production.json ,也就说明当前的 ASPNETCORE_EN ...

  9. ASP.NET Core Web 应用程序开发期间部署到IIS自定义主机域名并附加到进程调试

    想必大家之前在进行ASP.NET Web 应用程序开发期间都有用到过将我们的网站部署到IIS自定义主机域名并附加到进程进行调试. 那我们的ASP.NET Core Web 应用程序又是如何部署到我们的 ...

最新文章

  1. GitNote基于git的个人云笔记
  2. Android studio 下 JNI 开发实例
  3. 玩玩.net的ildasm與ilasm (转)
  4. 流水线经典讲解!!!!!
  5. k8s minikube部署hbase
  6. 你可能不知道的switch
  7. kernel mtd 分区与UBOOT 分区的理解
  8. Linux下python安装升级详细步骤 | Python2 升级 Python3
  9. SpringBoot 指定静态资源路径
  10. 通过kubeadm安装kubernetes 1.13.2
  11. 三星发布A60 元气版:骁龙675 售价1499元
  12. vivado中bit文件怎么没有生成_Xilinx FPGA bit 文件加密
  13. Elasticsearch(三)
  14. html——js简单计时器实现
  15. 比例尺分辨率转换(openlayers)
  16. python列表获取最后一个元素的方法_在Python中获取列表的最后一个元素
  17. 机器学习实战(三):Classification
  18. 2021-09-07体脂秤模块用来做什么?开发八电极体脂秤方案
  19. English:现在分词和过去分词的用法
  20. 【C语言】强符号和弱符号

热门文章

  1. saltstack的安装(转载连接)
  2. .NET程序加壳的基本原理和方式浅析
  3. Impala入门笔记
  4. C#断点续传原理与实现
  5. 用拖拉实现设备驱动配置(EsayHMI最新驱动配置方式)
  6. Blazor University (1)介绍 - 什么是 Blazor?
  7. ToLookup 和 GroupBy 到底有什么不同?
  8. 790页微软官方《.Net核心编程》高清版PDF,提供下载
  9. 单体系统如何拆分为微服务
  10. 通过Dapr实现一个简单的基于.net的微服务电商系统(十)——一步一步教你如何撸Dapr之绑定...