安全机密管理:Asp.Net Core中的本地敏感数据保护技巧
前言
在我们开发过程中基本上不可或缺的用到一些敏感机密数据,比如SQL
服务器的连接串或者是OAuth2
的Secret
等,这些敏感数据在代码中是不太安全的,我们不应该在源代码中存储密码和其他的敏感数据,一种推荐的方式是通过Asp.Net Core
的机密管理器。
机密管理器
在
ASP.NET Core
中,机密管理器通常指的是一种工具或机制,用于安全地存储和管理应用程序中的敏感数据,如数据库连接字符串、API
密钥、密码等。这样的工具可以帮助开发人员有效地管理敏感信息,避免将其硬编码在代码中或与源代码一同提交到版本控制系统中,从而提高数据安全性和保密性。
通过上面我们可以得知,应用机密存储和项目数在不同的位置,也就是说不被 git
等源代码管理器所管理,所以不会随源代码迁入到远程服务器。
为什么要使用机密管理器:
安全性:通过使用机密管理器,可以将敏感数据存储在安全的位置,避免在代码中明文存储密码等敏感信息,从而减少数据泄露的风险。
便捷性:机密管理器提供了方便的方式来存储和访问敏感数据,使开发人员能够轻松地在开发过程中使用这些数据,而无需担心泄露或不当处理。
灵活性:通过机密管理器,可以轻松地在不同环境中管理不同的敏感数据,如开发、测试和生产环境,同时确保每个环境中的数据安全性。
遵循最佳实践:使用机密管理器有助于遵循最佳实践,如将敏感数据与应用程序代码分离、避免硬编码密码等敏感信息,提高应用程序的安全性和可维护性。
如何启用机密存储
有两种方案第一种是使用CLI
第二种是使用Visual Studio
我们创建一个新的WebApi
项目dotNetParadise.UserSecret
使用CLI
机密管理器工具包含一个 init
命令 用来启用机密存储,在项目所在的目录,在我的示例中就是Api
项目dotNetParadise.UserSecret
的所在目录执行一下命令:
dotnet user-secrets init
通过输出我们可以看到在我们项目的CSPROJ
文件生成了一个UserSecretsId
元素添加到项目文件的 PropertyGroup
中,内部文本是任意的,但对于项目来说是唯一的。
<PropertyGroup>
<TargetFramework>net8.0</TargetFramework>
<Nullable>enable</Nullable>
<ImplicitUsings>enable</ImplicitUsings>
<UserSecretsId>c3cda712-dc63-439b-b6af-9c4d6060fde2</UserSecretsId>
</PropertyGroup>
设置机密
使用 dotnet user-secrets set
命令来存储机密数据。
在项目文件夹目录中执行此命令
dotnet user-secrets set "Movies:ServiceApiKey" "12345"
在这个示例中,使用 dotnet user-secrets set
命令设置了一个名为 "Movies:ServiceApiKey"
的应用机密,其值为 "12345"
。冒号表示 "Movies"
是具有 "ServiceApiKey"
属性的对象文字。
我们设置好的机密数据存到了哪里?
在Windows
系统中
%APPDATA%\Microsoft\UserSecrets\<user_secrets_id>\secrets.json
比如我刚才添加的就在机密存储位置:
%APPDATA%\Microsoft\UserSecrets\c3cda712-dc63-439b-b6af-9c4d6060fde2\secrets.json
看一下里面的内容
{
"Movies:ServiceApiKey": "12345"
}
也可以通过单击该项目(项目名称),然后从上下文菜单中选择“管理用户机密”设置,在VS编辑器
查看secrets.json
机密数据。
--project
属性
除了在项目文件目录中执行dotnet user-secrets set
命令设置机密之外,还可以在通过 --project
选项用于指定项目文件所在的文件系统路径,以便在其他目录中使用User Secrets
机密管理器工具,这种用法允许从任意目录设置应用机密,而不仅限于项目文件所在的当前目录
dotnet user-secrets set "Movies:ServiceApiKey" "12345" --project "C:\apps\WebApp1\src\WebApp1"
机密管理器工具不会加密存储的机密,不得被视为受信任的存储,它仅用于开发,密钥和值存储在用户配置文件目录中的
JSON
配置文件中。
使用Visual Studio
当在 Visual Studio
中进行敏感数据管理时,可以按照以下步骤操作:
在解决方案资源管理器中右键 单击该项目(项目名称),然后从上下文菜单中选择
“管理用户机密”
。Visual Studio
将自动为该项目添加一个UserSecretsId 元素
,其中填充有一个唯一的GUID
。
设置完之后在 VS 的编辑界面就会打开一个secrets.json
文件
{}
这里面是一个空的
json
串,可以手动设置机密键值对象,也可以通过dotnet user-secrets set
来设置机密数据
批量设置机密
可以通过一个json
文件来批量设置机密
type .\input.json | dotnet user-secrets set
读取机密
在Asp.Net Core
中我们在项目中读取配置如appSetting.json
或者环境变量的参数都是通过IConfiguration
对象来操作,机密的读取和Asp.Net Core
的配置都是一样的我们来实战一下
var apiKey = builder.Configuration["Movies:ServiceApiKey"];
Console.WriteLine(apiKey);
可以看到机密信息已经正常读到。
配置的优先级
那么如果 user-secrets
和appSetting.json
或者还有其他的配置源设置相同的数据,那个优先级高呢?
根据Asp.Net Core 配置介绍
WebApplication.CreateBuilder
使用预配置的默认值初始化WebApplicationBuilder
类的新实例。 经过初始化的WebApplicationBuilder (builder)
按照以下顺序为应用提供默认配置(从最高优先级到最低优先级):
- 使用命令行配置提供程序通过命令行参数提供。
- 使用非前缀环境变量配置提供程序通过非前缀环境变量提供。
- 应用在
Development
环境中运行时的用户机密。 - 使用
JSON
配置提供程序通过appsettings.{Environment}.json
提供。 例如,appsettings.Production.json
和appsettings.Development.json
。 - 使用
JSON
配置提供程序通过appsettings.json
提供。
可以看出如果用户机密比默认的 appsettings.json
优先级要高。
对应机密的绑定成
POCO
对象和Asp.Net Core
使用配置一样可以用IConfiguration
提供的各种扩展如Get
,Bind
等来实现,此处不过多介绍
列出机密
从所在项目目录中运行
dotnet user-secrets list
输出:
Movies:ServiceApiKey = 12345
删除单个机密
dotnet user-secrets remove Movies:ServiceApiKey
使用 dotnet user-secrets remove
命令来删除 ASP.NET Core
项目中的单个机密。在这个示例中,执行命令 dotnet user-secrets remove Movies:ServiceApiKey
将删除名为 "Movies:ServiceApiKey"
的机密信息。
通过这种方式,你可以方便地管理和更新项目中的机密数据,确保不再需要的敏感信息不再存储在用户机密存储中。
删除所有机密
dotnet user-secrets clear
dotnet user-secrets clear
用于清除 ASP.NET Core
项目中存储的所有用户机密。执行这个命令将删除用户机密存储中的所有机密信息,使存储中不再包含任何敏感数据。
使用 dotnet user-secrets clear
命令是一种快速清除整个用户机密存储中数据的方式,适用于需要重置或清除所有敏感信息的情况。请谨慎使用此命令,确保在执行之前备份重要的机密数据。
最后
面向非Web
的环境,可以参考下方官网的实现,本文注重讲解了通过user-secrets
来管理本地的机密,线上环境的机密配置可以ASP.NET Core 中的 Azure Key Vault 配置提供程序,或者大家如果在k8s
的环境中可以通过Secret
或者ConfigMap
,亦或是配置中心等方式来让自己的机密信息避免在源码中出现。
- 在开发过程中保护机密
欢迎关注笔者公众号一起学习交流,获取更多有用的知识~
安全机密管理:Asp.Net Core中的本地敏感数据保护技巧的更多相关文章
- ASP.NET Core中的依赖注入(4): 构造函数的选择与服务生命周期管理
ServiceProvider最终提供的服务实例都是根据对应的ServiceDescriptor创建的,对于一个具体的ServiceDescriptor对象来说,如果它的ImplementationI ...
- ASP.NET Core中的依赖注入(1):控制反转(IoC)
ASP.NET Core在启动以及后续针对每个请求的处理过程中的各个环节都需要相应的组件提供相应的服务,为了方便对这些组件进行定制,ASP.NET通过定义接口的方式对它们进行了"标准化&qu ...
- ASP.NET Core中的依赖注入(2):依赖注入(DI)
IoC主要体现了这样一种设计思想:通过将一组通用流程的控制从应用转移到框架之中以实现对流程的复用,同时采用"好莱坞原则"是应用程序以被动的方式实现对流程的定制.我们可以采用若干设计 ...
- ASP.NET Core中的依赖注入(3): 服务的注册与提供
在采用了依赖注入的应用中,我们总是直接利用DI容器直接获取所需的服务实例,换句话说,DI容器起到了一个服务提供者的角色,它能够根据我们提供的服务描述信息提供一个可用的服务对象.ASP.NET Core ...
- ASP.NET Core中的依赖注入(5): ServiceProvider实现揭秘 【总体设计 】
本系列前面的文章我们主要以编程的角度对ASP.NET Core的依赖注入系统进行了详细的介绍,如果读者朋友们对这些内容具有深刻的理解,我相信你们已经可以正确是使用这些与依赖注入相关的API了.如果你还 ...
- ASP.NET Core中的依赖注入(5): ServiceProvider实现揭秘 【解读ServiceCallSite 】
通过上一篇的介绍我们应该对实现在ServiceProvider的总体设计有了一个大致的了解,但是我们刻意回避一个重要的话题,即服务实例最终究竟是采用何种方式提供出来的.ServiceProvider最 ...
- ASP.NET Core中的依赖注入(5):ServicePrvider实现揭秘【补充漏掉的细节】
到目前为止,我们定义的ServiceProvider已经实现了基本的服务提供和回收功能,但是依然漏掉了一些必需的细节特性.这些特性包括如何针对IServiceProvider接口提供一个Service ...
- 在Asp.NET Core中如何优雅的管理用户机密数据
在Asp.NET Core中如何优雅的管理用户机密数据 背景 回顾 在软件开发过程中,使用配置文件来管理某些对应用程序运行中需要使用的参数是常见的作法.在早期VB/VB.NET时代,经常使用.ini文 ...
- ASP.NET Core 中文文档 第三章 原理(13)管理应用程序状态
原文:Managing Application State 作者:Steve Smith 翻译:姚阿勇(Dr.Yao) 校对:高嵩 在 ASP.NET Core 中,有多种途径可以对应用程序的状态进行 ...
- ASP.NET Core中的OWASP Top 10 十大风险-失效的访问控制与Session管理
不定时更新翻译系列,此系列更新毫无时间规律,文笔菜翻译菜求各位看官老爷们轻喷,如觉得我翻译有问题请挪步原博客地址 本博文翻译自: https://dotnetcoretutorials.com/201 ...
随机推荐
- 深度学习论文翻译解析(二十一):High-Performance Large-Scale Image Recognition Without Normalization
论文标题:High-Performance Large-Scale Image Recognition Without Normalization 论文作者:Andrew Brock Soham De ...
- window10-yarn-使用vite创建vue3项目失败-文件夹或目录不正确
前置条件 window10 本地已经安装nodejs yarn已经通过npm全局安装(npm install -g yarn) 问题 yarn脚手架方式搭建vue3项目失败(command faile ...
- 记录--Vue2屎山之 Table 屎山
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 前言 Vue2 将在 2023 年年底停止维护了,但是 Vue2 的代码却不会在 2023 年消失,还会越来越多:难以想象几十万行或者几百 ...
- C++ Concurrency in Action 读书笔记二:用mutex互斥锁保护在线程间共享的数据
Chapter 3 线程间共享数据 3.2 用互斥锁保护共享数据
- CYarp:力压frp的C#高性能http内网反代中间件
我以前开发过HttpMouse的http内网反代中间件,但由于当时的知识点与设计水平受限,所以把它下马了.随着自身又遇到http内网反代的需求,在frp不能满足我需求情况下,我又启动了一个叫CYarp ...
- 基于proteus的4019的移位设计
基于proteus的4019的移位设计 1.实验原理 4019是一个基于CMOS的数字集成芯片,具有数据选择和逻辑门或两种工作状态.这里利用数据选择的切换,实现数据的左移和右移操作.简而言之就是左移使 ...
- SMASH:经典One-Shot神经网络搜索,仅需单卡 | ICLR 2018
SMASH方法使用辅助网络生成次优权重来支持网络的快速测试,从结果来看,生成的权重与正常训练的权重在准确率上存在关联性,整体搜索速度很快,仅需要单卡进行搜索,提供了一个很好的新思路. 来源:晓飞的 ...
- MySQL创建和操纵表
表创建基础 CREATE TABLE customers ( cust_id int NOT NULL AUTO_INCREMENT , cust_name char(50) NOT NULL , c ...
- 使用OHOS SDK构建zziplib
参照OHOS IDE和SDK的安装方法配置好开发环境. 从gitee下载源码,当前最新的提交记录ID为6699e0fe8a0307b16dcc055eda04452e13abe63a. 执行如下命令: ...
- easyExcel合并数据导出(一对多)
语言 java 框架 ssm 需求 :看图 也是导出效果 数据库查询为(关系为一对多) 一个学生对应多个课程 实现步骤 1.实体类配置, 建议单独写个实体用来导出使用() 学生信息字段正常配置 , ...