如何使用 .NET Core 安全地加/解密文件

前言

由于客户网络安全限制,连接到互联网的设备不能访问内网。

需要先从客户端应用中导出数据到文件,再将文件复制到U盘,最后通过内网机器上传数据。

如何保证,在复制、传输过程中,文件的安全性?

思路

首先想到的是对文件进行加密。但是文件本身可能非常大,因此只能采取对称加密(AES)。

如果将对称加密的密钥存储在客户端的应用里,可能导致密钥泄露。

最好是每次加密都使用不同的AES密钥。

现在的关键是,如何将这个随机AES密钥传输给解密方?

根据我们在《请收藏!这可能是目前最安全的数据加密传输解决方案》中的思路,我们可以采用RSA公钥加密AES密钥,并将其作为文件的一部分发给解密方。

加密文件将由以下几个部分组成:

  • 256字节RSA加密后的AES密钥

  • 16字节初始化向量

  • AES加密的文件数据

解密方首先读取并使用RSA私钥解密出AES密钥,再用AES密钥解密出实际的文件数据。

实现

理清了思路,让我们来看一下实现。

首先是加密代码:

(byte[] aesKey, byte[] aesIV) = AesHelper.Create();using (var origFileStream = File.OpenRead("原始文件"))
{using (var encryptFileStream = File.Create("加密文件")){ await encryptFileStream.WriteAsync(RSAHelper.Encrypt(aesKey));await encryptFileStream.WriteAsync(aesIV);using (var cryptoStream = AesHelper.CreateWriteStream(encryptFileStream, aesKey, aesIV)){await origFileStream.CopyToAsync(cryptoStream);}}
}

然后是解密代码:

using (var decryptFileStream = File.OpenRead("解密文件"))
{using (var encryptFileStream = File.OpenRead("加密文件")){var aesKeyData = new byte[256];await encryptFileStream.ReadAsync(aesKeyData, 0, aesKeyData.Length);var aesKey = RSAHelper.Decrypt(aesKeyData);var aesIVData = new byte[16];await encryptFileStream.ReadAsync(aesIVData, 0, aesIVData.Length);var aesIV = aesIVData;using (var cryptoStream = AesHelper.CreateReadStream(encryptFileStream, aesKey, aesIV)){await cryptoStream.CopyToAsync(decryptFileStream);}}
}

结论

通过使用RSA+AES,同时保证了密钥和数据的安全性。

如果你也碰到了类似需求,不妨试试本文的实现方案。

想了解更多内容,请关注我的个人公众号”My IO“

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/290408.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Css截取字符串

white-space:nowrap; /* 禁止自动换行 */ overflow:hidden; /* 隐藏溢出的内容 */ text-overflow:ellipsis; /* 溢出文本使用...代替 */ 转载于:https://www.cnblogs.com/xiaoxian1369/p/4083974.html

广度优先算法BFS

package myalgorithm;import java.util.Arrays; import java.util.LinkedList; import java.util.Queue; /*BFS用于记录的位置和值的结构*/ class node {node(int xparam,int yparam,int valparam){this.x xparam;this.y yparam;this.value valparam;}int x,y,value; } publ…

COMA(一): Learning to Communicate with Deep Multi-Agent Reinforcement Learning 论文讲解

Learning to Communicate with Deep Multi-Agent Reinforcement Learning 论文讲解 论文链接:https://papers.nips.cc/paper/6042-learning-to-communicate-with-deep-multi-agent-reinforcement-learning.pdf (这篇论文是COMA三部曲中的第&#xff08…

C和指针之指针数组和指向数组的指针

1、指针数组 定义一个指针数组,该数组中每个元素是一个指针,每个指针指向哪里就需要程序中后续再定义int *p[10]; 2、指向数组的指针 定义一个数组指针,该指针指向含10个元素的一维数组(数组中每个元素是int型)int (*p…

SSH 远程执行任务

SSH 是 Linux 下进行远程连接的基本工具,但是如果仅仅用它来登录那可是太浪费啦!SSH 命令可是完成远程操作的神器啊,借助它我们可以把很多的远程操作自动化掉!下面就对 SSH 的远程操作功能进行一个小小的总结。远程执行命令如果我…

分库分表之历史表如何选择最佳分片路由规则

前言先别急着关闭,我相信这篇文章应该是所有讲分表分库下的人都没有和你们讲过的一种分片模式,外面的文章基本上都是教你如何从零开始分片,现在我将讲解的是如何从1开始分片项目地址github地址 https://github.com/dotnetcore/sharding-coregitee地址 https://gitee.com/dotnet…

C和指针之二维字符串数组用指针数组、数组指针、二级指针打印

1、问题 二位字符串数组用指针数组、数组指针、二级指针打印 2、测试代码 #include <stdio.h>int main() {char value[4][5] = {"chen", "yu", "feng", "yy"};char *p[5];char (*p1)[5];char **p2;//把二位数组的值赋给指…

Android下强制打开软键盘

这个也是累人&#xff0c;网上查了很多方法&#xff0c;没有实现需求。 最后的实现方法很简单。代码&#xff1a; 1 //通过定时器强制打开虚拟键盘2 public static void TimerShowKeyboard(final View v)3 {4 Timer timer new Timer();5 timer.schedu…

COMA(二):Counterfactual Multi-Agent Policy Gradients 论文讲解

Counterfactual Multi-Agent Policy Gradients 论文链接&#xff1a;https://arxiv.org/pdf/1705.08926.pdf 1. 问题提出&#xff08;解决了什么问题&#xff1f;&#xff09; 在现实世界中&#xff0c;有非常多的问题需要多个单位之间的“合作”才能完成任务&#xff0c;这就…

lecture6-mini批量梯度训练及三个加速的方法

Hinton的第6课&#xff0c;这一课中最后的那个rmsprop&#xff0c;关于它的资料&#xff0c;相对较少&#xff0c;差不多除了Hinton提出&#xff0c;没论文的样子&#xff0c;各位大大可以在这上面研究研究啊。 一、mini-批量梯度下降概述 这部分将介绍使用随机梯度下降学习来训…

C和指针之判断参数在关键字字符串列表中是否匹配

1、题目 *判断参数是否与一个关键字列表任何单词匹配 *并返回匹配的索引值,如果没有找到返回-1 2、代码实现 #include <stdio.h> #include <stdlib.h> #include <string.h>/***判断参数是否与一个关键字列表任何单词匹配*并返回匹配的索引值,…

Dapr集成之GRPC 接口

Dapr 为本地调用实现 HTTP 和 gRPC API 。通常大家第一时间想到的是通过 gRPC 调用 Dapr&#xff0c;更重要的一点是Dapr 也可以通过 gRPC 与应用程序通信。要做到这一点&#xff0c;原理很简单&#xff0c;应用程序需要托管一个gRPC服务器&#xff0c;并实现 Dapr 的GRPC 规范…

jQuery Validate验证框架详解

jQuery Validate验证框架详解 jQuery校验官网地址&#xff1a;http://bassistance.de/jquery-plugins/jquery-plugin-validation 一、导入js库 <script type"text/javascript" src"<%path %>/validate/jquery-1.6.2.min.js"></script> &…

C和指针之数组之编程练习2

1、题目 2.美国联邦政府使用下面这些规则计算1995年每个公民的个人收入所得税: 输入大于 不超过 你的税额为 超过这个数额的部分 $0 $2335015% $0 23350 56550 3502.50+28% 23350 56550 117950 12798.50+31% 56550 117950 2…

spring中的BeanFactory与ApplicationContext的作用和区别?

作用&#xff1a;1. BeanFactory负责读取bean配置文档&#xff0c;管理bean的加载&#xff0c;实例化&#xff0c;维护bean之间的依赖关系&#xff0c;负责bean的声明周期。 2. ApplicationContext除了提供上述BeanFactory所能提供的功能之外&#xff0c;还提供了更完整的框架功…

基于centos7系统mongodb3.,4.4安装

下载安装mongodbwget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.4.4.tgztar zxvf mongodb-linux-x86_64-rhel70-3.4.4.tgzmv mongodb-linux-x86_64-rhel70-3.4.4 mongodb344配置mongodbcd mongodb344/ mkdir data mkdir logsvim /opt/mongodb344/mongod…

RNN入门笔记

本笔记来源自Youtube李宏毅老师的RNN视频归纳&#xff0c;主要分为以下几个知识点: RNN 的特点RNN 的几种实现方法 (Simple RNN, LSTM)RNN 的训练不稳定性RNN 的keras实现 (定长和变长输入案例) Recurrent Neural Network Feature of RNN Differ from normal Neural Networ…

Swift - 文本输入框(UITextField)的用法

1&#xff0c;文本框的创建&#xff0c;有如下几个样式&#xff1a; UITextBorderStyle.None&#xff1a;无边框UITextBorderStyle.Line&#xff1a;直线边框UITextBorderStyle.RoundedRect&#xff1a;圆角矩形边框UITextBorderStyle.Bezel&#xff1a;边线阴影1234var textFi…

WPF 基础控件之 DatePicker 样式

此群已满340500857 &#xff0c;请加新群458041663由于微信群人数太多入群请添加小编微信号yanjinhuawechat 或 W_Feng_aiQ 邀请入群需备注WPF开发者 PS&#xff1a;有更好的方式欢迎推荐。支持NugetInstall-Package WPFDevelopers.Minimal -Version 3.2.001—代码如下一、创建…

C和指针之数组编程练习3(判断矩阵是否为单位矩阵)

1、题目 3.单位矩阵就是一个正方形矩阵,它除了主对角线元素值为1以外,其余元素的值均为0,例如: *1 0 0 *0 1 0 *0 0 1 *就是一个33单位矩阵,编写一个名叫identity_matrix的函数,它接受一个1010整型矩阵为参数 *成功返回1,失败返回1 4、修改前一个问题中的identity_…