C#文件操作集合五(文件加密解密)

前言

        文件操作是开发过程中经常遇到的,如何创建文件、处理文件、保存文件以及读取文件这些工作是每一位开发都必须经历的。

这里围绕C#文件操作内容,我做了一次系统的梳理,主要包括以下几个模块:

1、文件内容操作:文件读写相关

2、文件检测

3、文件及目录创建和删除

4、文件移动

5、文件加密、解密

6、文件上传、下载

7、文件压缩相关

8、文件操作权限相关


一、小节摘要

本节主要讲文件DES加密解密方法在C#中的实现,使用了.Net命名空间System.Security.Cryptography。

进入主题前,先简单介绍一下加密解密算法的必要性:

        现代计算机技术的广泛运用,几乎所有企业都在使用电脑处理企业内部数据,企业日常运行中产生的文件都通过公司电脑存储、流转,比如客户信息、设计图纸、企业资料等等,这些都属于公司的重要数据,对企业来说至关重要。
        但同时由于网络化办公的特性,很容易被企业中的内鬼整盘复制而给公司造成无法估量的损失,对于一个企业来说,内部核心资料落到他人手中是非常可怕的事情,尤其是对于一些中小企业,往往会造成巨大的打击,因此公司会选择在内部部署加密软件,对公司重要文件进行加密。

所以,作为一名开发者,我们需要知道什么情况下,哪些场景需要用到加密解密方法,这里列举了几个常见场景:

1、用户进行系统的注册、登录相关的用户账号密码及用户身份信息

2、接口交互过程中的签名Token及传输的敏感信息和敏感文件

3、保存到服务器本地的敏感文件及数据库存储的敏感信息

4、用户登录态保持过程中涉及的用户信息 

二、详细内容

1、加密

/// 
/// 加密
/// 
/// 
/// 
public static string Encrypt(string Text) 
{
	return Encrypt(Text,"MarcoPro");
}
///  
/// 加密数据 
///  
///  
///  
///  
public static string Encrypt(string Text,string sKey) 
{ 
	DESCryptoServiceProvider des = new DESCryptoServiceProvider(); 
	byte[] inputByteArray; 
	inputByteArray=Encoding.Default.GetBytes(Text); 
	des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
	des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
	System.IO.MemoryStream ms=new System.IO.MemoryStream(); 
	CryptoStream cs=new CryptoStream(ms,des.CreateEncryptor(),CryptoStreamMode.Write); 
	cs.Write(inputByteArray,0,inputByteArray.Length); 
	cs.FlushFinalBlock(); 
	StringBuilder ret=new StringBuilder(); 
	foreach( byte b in ms.ToArray()) 
	{ 
		ret.AppendFormat("{0:X2}",b); 
	} 
	return ret.ToString(); 
} 

2、解密

/// 
/// 解密
/// 
/// 
/// 
public static string Decrypt(string Text) 
{
	return Decrypt(Text,"MarcoPro");
}
///  
/// 解密数据 
///  
///  
///  
///  
public static string Decrypt(string Text,string sKey) 
{ 
	DESCryptoServiceProvider des = new DESCryptoServiceProvider(); 
	int len; 
	len=Text.Length/2; 
	byte[] inputByteArray = new byte[len]; 
	int x,i; 
	for(x=0;x

你可能感兴趣的:(c#,开发语言,加密解密)