EncryptionHelper
public static class EncryptionHelper
{
#region const
/// <summary>
/// 默认使用的适合于DES,RC2算法的Key
/// </summary>
private const string m_ShortDefaultKey = "Nesc";
/// <summary>
/// 默认使用的TRIPLEDES,RIJNDAEL算法的Key
/// </summary>
private const string m_LongDefaultKey = "Nesc.Oversea";
/// <summary>
/// 默认使用的适合于DES,RC2,TRIPLEDES算法的InitVector
/// </summary>
private const string m_ShortDefaultIV = ""; /// <summary>
/// 默认使用的适合于RIJNDAEL算法的InitVector
/// </summary>
private const string m_LongDefaultIV = "Oversea3"; #endregion
private static byte[] m_Key = null; private static byte[] m_initVec = null; #region properties
/// <summary>
/// 使用的加密明文密码
/// </summary>
public static string Key
{
get
{
string result = string.Empty;
if (m_Key != null)
{
result = Encoding.Unicode.GetString(m_Key);
}
return result;
} }
/// <summary>
/// 使用加密的起始偏移量
/// </summary>
public static string InitVector
{
get
{
string result = string.Empty;
if (m_initVec != null)
{
result = Encoding.Unicode.GetString(m_initVec);
}
return result;
} }
#endregion /// <summary>
/// 接受用户明文密码,本次加密使用的算法,完成对指定字符串的加密
/// <example><![CDATA[string result = EncryptionHelper.Encrypt("1234", EncryptionAlgorithm.Rc2, "5678", text);]]></example>
/// <remarks>各个算法对明文密码和初始化偏移量的要求不一样
/// DES和RC2:明文密码长度和初始化偏移量长度 必须是4个字符;
/// Rijndael:明文密码长度可以是12,16个字符,初始化偏移量为8个字符;
/// TripleDes:明文密码长度可以为8个和12个字符,初始化偏移量为4个字符;
/// 注意:如果提供的明文密码和偏移量不符合算法的标准,将使用随机密码,使用者在加密后通过提供的Key和InitVector属性获得加密时使用的明文密码和偏移量
/// </remarks>
/// </summary>
/// <param name="plainText">使用的加密明文密码</param>
/// <param name="algorithm">加密算法枚举对象</param>
/// <param name="userInitialVector">使用的加密起始偏移量</param>
/// <param name="encryptionText">需要加密的字符</param>
/// <returns></returns>
public static string Encrypt(string plainText, EncryptionAlgorithm algorithm, string userInitialVector, string encryptionText)
{
string result = string.Empty; if (encryptionText.Length > )
{
SetKey(algorithm, plainText);
SetInitialVector(algorithm, userInitialVector);
EncryptTransform transform = new EncryptTransform(m_Key,m_initVec);
byte[] bytes = Encoding.Unicode.GetBytes(encryptionText);
byte[] inArray = transform.Encrypt(algorithm, bytes);
if (inArray.Length > )
{
result = Convert.ToBase64String(inArray);
}
m_Key = transform.Key;
m_initVec = transform.InitVec; }
return result; } /// <summary>
/// 指定需要加密的字符串使用默认的明文密码和算法(DES)进行加密
/// </summary>
/// <param name="encryptionText"></param>
/// <returns></returns>
public static string Encrypt(string encryptionText)
{
string result = string.Empty;
result = Encrypt(m_ShortDefaultKey, EncryptionAlgorithm.Des, m_ShortDefaultIV, encryptionText);
return result;
}
/// <summary>
/// 指定需要加密的字符串和算法使用默认的明文密码进行加密
/// </summary>
/// <param name="algorithm"></param>
/// <param name="encryptionText"></param>
/// <returns></returns>
public static string Encrypt(EncryptionAlgorithm algorithm, string encryptionText)
{
string result = string.Empty;
string key = GetDefaultKey(algorithm);
string iv = GetDefaultIV(algorithm);
result = Encrypt(key, algorithm, iv, encryptionText);
return result;
} /// <summary>
/// 接受用户明文密码,使用默认的加密算法完成对指定字符串的加密
/// <remarks>默认为DES算法进行加密</remarks>
/// <example><![CDATA[string result = EncryptionHelper.Encrypt("1234", "5678", text);]]></example>
/// </summary>
/// <param name="plainText">使用的加密明文密码</param>
/// <param name="userInitialVector">使用的加密起始偏移量</param>
/// <param name="encryptionText">需要加密的字符串</param>
/// <returns>加密后的字符串</returns>
public static string Encrypt(string plainText, string userInitialVector, string encryptionText)
{
string result = string.Empty;
result = Encrypt(plainText, EncryptionAlgorithm.Des, userInitialVector, encryptionText);
return result;
} /// <summary>
/// 接受用户明文密码,本次使用的解密算法,完成对指定字符串的解密;
/// <remarks>指定的解密算法必须和字符串使用加密的算法一致
/// 各个算法对明文密码和初始化偏移量的要求不一样
/// DES和RC2:明文密码长度和初始化偏移量长度 必须是4个字符;
/// Rijndael:明文密码长度可以是12,16个字符,初始化偏移量为8个字符;
/// TripleDes:明文密码长度可以为8个和12个字符,初始化偏移量为4个字符;
/// </summary>
/// <param name="plainText">加密明文密码</param>
/// <param name="algorithm">使用的加密算法</param>
/// <param name="userInitialVector">加密时使用的起始偏移量</param>
/// <param name="encryptionText">加密后的字符串</param>
/// <returns></returns>
public static string Decrypt(string plainText, EncryptionAlgorithm algorithm, string userInitialVector, string encryptionText)
{
string result = string.Empty;
SetKey(algorithm, plainText);
SetInitialVector(algorithm, userInitialVector);
EncryptTransform transform = new EncryptTransform(m_Key, m_initVec);
byte[] bytesData = Convert.FromBase64String(encryptionText);
byte[] bytes = null;
try
{
bytes = transform.Decrypt(algorithm, bytesData);
}
catch (Exception exception)
{
throw exception;
}
if (bytes.Length > )
{
result = Encoding.Unicode.GetString(bytes);
}
m_Key = transform.Key;
m_initVec = transform.InitVec;
return result; } /// <summary>
/// 接受用户明文密码,使用默认解密算法完成对指定字符串的解密
/// </summary>
/// <param name="plainText">加密时使用的明文密码</param>
/// <param name="userInitialVector">加密时使用的起始偏移量</param>
/// <param name="encryptionText">加密后的字符串</param>
/// <returns></returns>
public static string Decrypt(string plainText, string userInitialVector, string encryptionText)
{
string result = string.Empty;
result=Decrypt(plainText, EncryptionAlgorithm.Des,userInitialVector,encryptionText);
return result; } /// <summary>
/// 使用默认的算法(DES)和默认的明文密码进行解密
/// </summary>
/// <param name="encryptionText"></param>
/// <returns></returns>
public static string Decrypt(string encryptionText)
{
string result = string.Empty;
result = Decrypt(m_ShortDefaultKey, EncryptionAlgorithm.Des, m_ShortDefaultIV, encryptionText);
return result; }
/// <summary>
/// 指定加密时使用的算法,使用默认的明文密码进行解密
/// </summary>
/// <param name="algorithm"></param>
/// <param name="encryptionText"></param>
/// <returns></returns>
public static string Decrypt(EncryptionAlgorithm algorithm,string encryptionText)
{
string result = string.Empty;
string key = GetDefaultKey(algorithm);
string iv = GetDefaultIV(algorithm);
result = Decrypt(key, algorithm, iv, encryptionText);
return result; } /// <summary>
/// 根据算法获得默认的Key
/// </summary>
/// <param name="algorithm"></param>
/// <returns></returns>
private static string GetDefaultKey(EncryptionAlgorithm algorithm)
{
string result = m_ShortDefaultKey;
switch (algorithm)
{
case EncryptionAlgorithm.Rijndael:
{
result = m_LongDefaultKey;
break;
}
case EncryptionAlgorithm.TripleDes:
{
result = m_LongDefaultKey;
break;
}
}
return result;
}
/// <summary>
/// 根据算法获得默认的IV
/// </summary>
/// <param name="algorithm"></param>
/// <returns></returns>
private static string GetDefaultIV(EncryptionAlgorithm algorithm)
{
string result = m_ShortDefaultIV;
switch (algorithm)
{
case EncryptionAlgorithm.Rijndael:
{
result = m_LongDefaultIV;
break;
}
}
return result;
} /// <summary>
///
/// </summary>
/// <param name="algorithm"></param>
/// <param name="initialVector"></param>
/// <returns></returns>
private static void SetInitialVector(EncryptionAlgorithm algorithm, string initialVector)
{
if (null != initialVector)
{
byte[] bytes = Encoding.Unicode.GetBytes(initialVector);
switch (algorithm)
{
case EncryptionAlgorithm.Des:
{
if ( bytes.Length == )
{
m_initVec = bytes; }
break;
} case EncryptionAlgorithm.Rc2:
{
if ( bytes.Length == )
{
m_initVec = bytes; }
break;
}
case EncryptionAlgorithm.Rijndael:
{
if ( bytes.Length ==)
{
m_initVec = bytes; }
break;
}
case EncryptionAlgorithm.TripleDes:
{
if (bytes.Length == )
{
m_initVec = bytes; }
break;
}
}
}
} private static void SetKey(EncryptionAlgorithm algorithm, string key)
{
if (null != key)
{
byte[] keyByte = Encoding.Unicode.GetBytes(key);
switch (algorithm)
{
case EncryptionAlgorithm.Des:
{
if (keyByte.Length== )
{
m_Key = keyByte;
}
break;
} case EncryptionAlgorithm.Rc2:
{
if (keyByte.Length == )
{
m_Key = keyByte;
}
break;
}
case EncryptionAlgorithm.Rijndael:
{
if (keyByte.Length== || (keyByte.Length == ))
{
m_Key = keyByte;
}
break;
}
case EncryptionAlgorithm.TripleDes:
{
if (keyByte.Length == ||(keyByte.Length == ))
{
m_Key = keyByte;
}
break;
}
}
}
} }
EncryptionHelper的更多相关文章
- App开发流程之加密工具类
科技优家 2016-09-08 18:10 从这篇记录开始,记录的都算是干货了,都是一些编程日常的积累. 我建议先将基础的工具加入项目,后续的开发效率会呈指数增长.如果在专注功能开发过程中,才发现缺少 ...
- MVC-登录并设置角色
1.新建一个类,设置角色: using System; using System.Collections.Generic; using System.Linq; using System.Text; ...
- MVC - 身份验证
FormsAuthenticationTicket 使用此类来为用户生成一个身份票据 持有该票据则说明该用户是通过了身份验证的用户 可以随时访问某些资源 我们先创建几个类 //用户 public c ...
- 使用AES加密的帮助类
在开发中经常使用加密/解密对一些内容进行处理,比如密码在存入数据库之前先经过加密处理等等,这里就把一个加密帮助类代码贴出来,供以后查找使用. 这个帮助类主要功能是对字符串和字节数组进行加密解密处理. ...
- C#实现软件授权,限定MAC运行(软件license管理,简单软件注册机制)
一个绿色免安装软件,领导临时要求加个注册机制,不能让现场工程师随意复制.事出突然,只能在现场开发(离开现场软件就不受我们控了).花了不到两个小时实现了简单的注册机制,稍作整理. 基本原理:1.软件一运 ...
- C#软件授权、注册、加密、解密模块源码解析并制作注册机生成license
最近做了一个绿色免安装软件,领导临时要求加个注册机制,不能让现场工程师随意复制.事出突然,只能在现场开发(离开现场软件就不受我们控了).花了不到两个小时实现了简单的注册机制,稍作整理. ...
- C#软件license管理(简单软件注册机制)
最近做了一个绿色免安装软件,领导临时要求加个注册机制,不能让现场工程师随意复制.事出突然,只能在现场开发(离开现场软件就不受我们控了).花了不到两个小时实现了简单的注册机制,稍作整理. ...
- weblogic 异常 com.rsa.jsafe.JSAFE_PaddingException: Could not perform unpadding: invalid pad byte.次异常怎么解决
问题 更改控制台密码后,服务重启失败,无法启动,报错如下: <-- 下午03时10分49秒 CST> <Info> <WebLogicServer> <BEA ...
- RSA加密、解密、签名、校验签名
先说下RSA概率: 公钥和私钥是通过本地openssl软件生成. 正常: 公钥加密=>私钥解密: 私钥签名=>公钥校验签名 最近做一个项目,对方用java公钥去校验签名,这边java的De ...
随机推荐
- solr python客户端 - solrpy
solrPy 基础使用: 1)与solr建立连接 import solr s = solr.Solr('http://host:ip/solr/collectionName') 2)查询 r = s. ...
- 《STL系列》之vector原理及实现
最近忙得蛋疼,但还是想写点属于自己的东西.也不知道写点啥,最后决定试着自己实现STL中常用的几个集合,一来加深自己对STL的理解,二来看看自己是否有这个能力实现.实现目标就是:1能和STL兼容:2最大 ...
- Android UI系列-----时间、日期、Toasts和进度条Dialog
您可以通过点击 右下角 的按钮 来对文章内容作出评价, 也可以通过左下方的 关注按钮 来关注我的博客的最新动态. 如果文章内容对您有帮助, 不要忘记点击右下角的 推荐按钮 来支持一下哦 如果您对文章内 ...
- Qt 调试时的错误——Debug Assertion Failed!
在VS2008中写qt程序时调试出现此问题,但在release模式下就不存在,在网上搜罗了一圈,是指针的问题. 问题是这样的: 需要打开两个文件,文件中数据类型是float,我使用QVector进行保 ...
- 利用Mahout实现在Hadoop上运行K-Means算法
利用Mahout实现在Hadoop上运行K-Means算法 一.介绍Mahout Mahout是Apache下的开源机器学习软件包,目前实现的机器学习算法主要包含有协同过滤/推荐引擎,聚类和分类三个部 ...
- 通过Typings为Visual Studio Code增强智能提示功能
缘起 最近在学习Node.js及ThinkJS这个框架,用vscode作为开发环境.默认情况下vscode对ThinkJS的代码提示并不好,所以研究了一下,原来可以同通过Typings来让vscode ...
- HDU 4686 Arc of Dream (矩阵快速幂)
Arc of Dream Time Limit: 2000/2000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Tota ...
- 使用 T-SQL 计算当日日期、本周第一天与最后一天
--当日日期 ); SET @Today = DATENAME(YEAR, GETDATE()) + '-' + DATENAME(MONTH, GETDATE()) + '-' + DATENAME ...
- android学习者优秀网址推荐
非常漂亮的android UI库集合,别人整理的,如果感觉不错,赶快收藏吧!! https://github.com/wasabeef/awesome-android-ui https://githu ...
- Android Studio通过JNI调用NDK程序
NDK开发,其实是为了项目需要调用底层的一些C/C++的一些东西:另外就是为了效率更加高些,安全性更高. 如果你在Eclipse+ADT下开发过NDK就能体会到要么是配置NDK还要下载Cygwin,配 ...