导航:首页 > 文档加密 > 基于可信对象的加密解密系统

基于可信对象的加密解密系统

发布时间:2023-06-11 23:55:04

‘壹’ 面向对象基础知识之文件加密解密

文件加密解密是开发中经常用到的一个功能点,常见于客户端项目,需要对配置数据、参数设置、数据字典等需要隐匿,来增强客户端的安全性。

本章我们介绍两种常见文件加密解密方法

1.自定义加密解密函数,思路是文件转成Byte[],对byte元素使用对称加密算法对齐加密。加密后的byte[]转成base64。解密文件使用base64加密的byte[]解密即可生成原文件。

2.使用 System.Security.Cryptography. RijndaelManaged,这种加密需要提供32位密码和16位向量密码

//加密

string pwd = "" ; //32位,密码

string ivpwd = "gjhdjfhdjdkdssad" ; //16位,向量密码

RijndaelManaged aes = new RijndaelManaged();

byte [] pwdBytes = System.Text.Encoding.UTF8.GetBytes(pwd);

aes.Key = pwdBytes;

aes.IV = Encoding.UTF8.GetBytes(ivpwd);

aes.Mode = CipherMode.CBC;

aes.Padding = PaddingMode.PKCS7;

byte [] readFileByte = ReadByte(filePath);

ICryptoTransform transform = aes.CreateEncryptor();

byte [] fielBuffer = transform.TransformFinalBlock(readFileByte, 0, readFileByte.Length); //注意这里返回的是加密后的byte[]

//解密

RijndaelManaged aes = new RijndaelManaged();

byte [] pwdBytes = System.Text.Encoding.UTF8.GetBytes(pwd);

aes.Key = pwdBytes;

aes.IV = Encoding.UTF8.GetBytes(ivpwd);

aes.Mode = CipherMode.CBC;

aes.Padding = PaddingMode.PKCS7;

byte [] readFileByte = ReadByte(filePath);

ICryptoTransform transform = aes.CreateDecryptor();

//注意这里返回的是解密后的byte[]

byte [] fielBuffer = transform.TransformFinalBlock(readFileByte, 0, readFileByte.Length);

加密方式越复杂需要的计算量越大,速度相应会变慢;加密方式需要结合项目来做选择。客户端项目对于数据保密性较强建议使用RSA和 RijndaelManaged 混合加密。

‘贰’ 公司内部的数据文件如何防止泄露

1,员工入职时 签订保密协议,为员工普及相关法律的知识。也为日后维权做好铺垫。
2,内部实时奖惩制,互相监督。一个文件尽量多个人同时负责等等。
3,安装域之盾软件 开启透明加密功能,用户使用基本无感,不影响用户日常的操作行为。
4,开启软件的外发审核功能,一切的外发行为都需要审核 包括 qq 微信 邮箱 网盘等等。如果不审核即为非法外发,那么发出去的文件就都是乱码。。
5,对常用U盘 设置u盘白名单,设置陌生U盘只读或禁止使用。

阅读全文

与基于可信对象的加密解密系统相关的资料

热点内容
未转变者正版怎么开服务器 浏览:242
中国国家地理专辑pdf 浏览:927
什么是光遇安卓纯录屏 浏览:560
光遇乐谱app如何获得爱心 浏览:441
下载什么app可以领外卖券 浏览:984
pdf图档 浏览:777
华为平板app如何移入隐私空间 浏览:130
python怎么列表去重 浏览:737
linux命令文件路径 浏览:60
程序员的愤怒完整视频 浏览:873
如何把iphoneapp变小 浏览:132
一个后端程序员的日常 浏览:416
51单片机历史 浏览:890
怎样减小pdf文件大小 浏览:33
和彩云zip解压 浏览:725
linux查看线程状态 浏览:459
怎么起文件夹名称 浏览:49
北京交大编译原理 浏览:982
linux执行java脚本 浏览:589
全能扫描加密文档忘记密码怎么办 浏览:75