zoukankan
html css js c++ java
【转】参数加密与解密
using
System;
using
System.Security.Cryptography;
using
System.IO;
using
System.Text;
namespace
SharpZipLib
{
/**/
///
///
Security 的摘要说明。
///
Security类实现.NET框架下的加密和解密。
///
CopyRight KangSoft@Hotmail.com@Hotmail.com@hotmail.com
///
public
class
Security
{
string
_QueryStringKey
=
"
11111111
"
;
//
URL传输参数加密Key
string
_PassWordKey
=
"
22222222
"
;
//
PassWord加密Key
public
Security()
{
//
//
TODO: 在此处添加构造函数逻辑
//
}
/**/
///
///
加密URL传输的字符串
///
///
///
public
string
EncryptQueryString(
string
QueryString)
{
return
Encrypt(QueryString, _QueryStringKey);
}
/**/
///
///
解密URL传输的字符串
///
///
///
public
string
DecryptQueryString(
string
QueryString)
{
return
Decrypt(QueryString, _QueryStringKey);
}
/**/
///
///
加密帐号口令
///
///
///
public
string
EncryptPassWord(
string
PassWord)
{
return
Encrypt(PassWord, _PassWordKey);
}
/**/
///
///
解密帐号口令
///
///
///
public
string
DecryptPassWord(
string
PassWord)
{
return
Decrypt(PassWord, _PassWordKey);
}
/**/
///
///
DEC 加密过程
///
///
///
///
public
string
Encrypt(
string
pToEncrypt,
string
sKey)
{
DESCryptoServiceProvider des
=
new
DESCryptoServiceProvider();
//
把字符串放到byte数组中
byte
[] inputByteArray
=
Encoding.Default.GetBytes(pToEncrypt);
//
byte[] inputByteArray=Encoding.Unicode.GetBytes(pToEncrypt);
des.Key
=
ASCIIEncoding.ASCII.GetBytes(sKey);
//
建立加密对象的密钥和偏移量
des.IV
=
ASCIIEncoding.ASCII.GetBytes(sKey);
//
原文使用ASCIIEncoding.ASCII方法的GetBytes方法
MemoryStream ms
=
new
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);
}
ret.ToString();
return
ret.ToString();
}
/**/
///
///
DEC 解密过程
///
///
///
///
public
string
Decrypt(
string
pToDecrypt,
string
sKey)
{
DESCryptoServiceProvider des
=
new
DESCryptoServiceProvider();
byte
[] inputByteArray
=
new
byte
[pToDecrypt.Length
/
2
];
for
(
int
x
=
0
; x
<
pToDecrypt.Length
/
2
; x
++
)
{
int
i
=
(Convert.ToInt32(pToDecrypt.Substring(x
*
2
,
2
),
16
));
inputByteArray[x]
=
(
byte
)i;
}
des.Key
=
ASCIIEncoding.ASCII.GetBytes(sKey);
//
建立加密对象的密钥和偏移量,此值重要,不能修改
des.IV
=
ASCIIEncoding.ASCII.GetBytes(sKey);
MemoryStream ms
=
new
MemoryStream();
CryptoStream cs
=
new
CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
cs.Write(inputByteArray,
0
, inputByteArray.Length);
cs.FlushFinalBlock();
StringBuilder ret
=
new
StringBuilder();
//
建立StringBuild对象,CreateDecrypt使用的是流对象,必须把解密后的文本变成流对象
return
System.Text.Encoding.Default.GetString(ms.ToArray());
}
/**/
///
///
检查己加密的字符串是否与原文相同
///
///
///
///
///
public
bool
ValidateString(
string
EnString,
string
FoString,
int
Mode)
{
switch
(Mode)
{
default
:
case
1
:
if
(Decrypt(EnString, _QueryStringKey)
==
FoString.ToString())
{
return
true
;
}
else
{
return
false
;
}
case
2
:
if
(Decrypt(EnString, _PassWordKey)
==
FoString.ToString())
{
return
true
;
}
else
{
return
false
;
}
}
}
}
}
Security sec = new Security();
string p= sec.EncryptQueryString("崔波"); //加密
string np = sec.DecryptQueryString(p); //解密
查看全文
相关阅读:
背景透明,文字不透明
判断数组类型
前端工作流程自动化——Grunt/Gulp 自动化
tools安装
总结
CSS Hack
getBoundingClientRect()兼容性处理
Math.random获得随机数
spring RestTemplate 工程导入
系统架构演变
原文地址:https://www.cnblogs.com/bobofsj11/p/1236278.html
最新文章
第14章 计算几何
C++STL算法速查
第24章 数值算法
第23章 排序算法(包括merge等)
第22章 变易算法
第21章 非变易算法
第20章 priority_queue优先队列容器
多态的概念
封装 继承的概念
封装和static 以及关键字“this”的用法
热门文章
面对对象编程
数组的方法和二维数组的组成
rcp 打开工程外的文件
eclipse 运行外部工具launch
定制eclipse IDE
rcp 右键菜单添加eclipse自带的新建文件和新建文件夹菜单
如何过滤菜单
JVM内存分配
多行文本溢出
算法积累(字符串转换驼峰,判断一个字符串中那个字母出现次数最多,并且出现了几次)
Copyright © 2011-2022 走看看