在日常开发过程中,总会遇到需要加密解密的需求,这里我整理了C#常用的加密解密方法分享给大家。
先看看加密的基本概念:
"加密",是一种限制对网络上传输数据的访问权的技术。原始数据(也称为明文,plaintext)被加密设备(硬件或软件)和密钥加密而产生的经过编码的数据称为密文(ciphertext)。将密文还原为原始明文的过程称为解密,它是加密的反向处理,但解密者必须利用相同类型的加密设备和密钥对密文进行解密。
加密的基本功能包括:
1. 防止不速之客查看机密的数据文件;
2. 防止机密数据被泄露或篡改;
3. 防止特权用户(如系统管理员)查看私人数据文件;
4. 使入侵者不能轻易地查找一个系统的文件。
一、本节摘要
本节主要分享MD5加密解密:
MD5全称是message-digest algorithm 5,简单的说就是单向的加密,也就是说无法根据密文推导出明文。
MD5主要用途:
1、对一段信息生成信息摘要,该摘要对该信息具有唯一性,可以作为数字签名
2、用于验证文件的有效性(是否有丢失或损坏的数据)
3、对用户密码的加密
4、在哈希函数中计算散列值
二、源码分享
1、主方法
private void Test()
{
string o = "i love u";
o = AddMD5Profix(o);
//o += " ";
Console.WriteLine(o);
Console.WriteLine(ValidateValue(o));
o = RemoveMD5Profix(o);
Console.WriteLine(o);
}
2、MD5加密解密类
using System;
using System.IO;
using System.Collections.Generic;
using System.Text;
namespace Commons
{
/// <summary>
/// MD5各种长度加密字符、验证MD5等操作辅助类
/// </summary>
public class MD5Util
{
public MD5Util()
{
}
/// <summary>
/// 获得32位的MD5加密
/// </summary>
/// <param name="input"></param>
/// <returns></returns>