c#
-----------------------------------------------
//名称空间
using system;
using system.security.cryptography;
using system.io;
using system.text;
//方法
//加密方法
public string encrypt(string ptoencrypt, string skey)
{
descryptoserviceprovider des = new descryptoserviceprovider();
//把字符串放到byte数组中
//原来使用的utf8编码,我改成unicode编码了,不行
byte[] inputbytearray = encoding.default.getbytes(ptoencrypt);
//byte[] inputbytearray=encoding.unicode.getbytes(ptoencrypt);
//建立加密对象的密钥和偏移量
//原文使用asciiencoding.ascii方法的getbytes方法
//使得输入密码必须输入英文文本
des.key = asciiencoding.ascii.getbytes(skey);
des.iv = asciiencoding.ascii.getbytes(skey);
memorystream ms = new memorystream();
cryptostream cs = new cryptostream(ms, des.createencryptor(),cryptostreammode.write);
//write the byte array into the crypto stream
//(it will end up in the memory stream)
cs.write(inputbytearray, 0, inputbytearray.length);
cs.flushfinalblock();
//get the data back from the memory stream, and into a string
stringbuilder ret = new stringbuilder();
foreach(byte b in ms.toarray())
{
//format as hex
ret.appendformat("{0:x2}", b);
}
ret.tostring();
return ret.tostring();
}
//解密方法
public string decrypt(string ptodecrypt, string skey)
{
descryptoserviceprovider des = new descryptoserviceprovider();
//put the input string into the byte array
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);
//flush the data through the crypto stream into the memory stream
cs.write(inputbytearray, 0, inputbytearray.length);
cs.flushfinalblock();
//get the decrypted data back from the memory stream
//建立stringbuild对象,createdecrypt使用的是流对象,必须把解密后的文本变成流对象
stringbuilder ret = new stringbuilder();
return system.text.encoding.default.getstring(ms.toarray());
}
-------------------------------------------------------
vb.net :
-------------------------------------------------------
imports system.web.security
imports system.security
imports system.security.cryptography
imports system.text
public shared function encrypt(byval ptoencrypt as string, byval skey as string) as string
dim des as new descryptoserviceprovider()
dim inputbytearray() as byte
inputbytearray = encoding.default.getbytes(ptoencrypt)
'建立加密对象的密钥和偏移量
'原文使用asciiencoding.ascii方法的getbytes方法
'使得输入密码必须输入英文文本
des.key = asciiencoding.ascii.getbytes(skey)
des.iv = asciiencoding.ascii.getbytes(skey)
'写二进制数组到加密流
'(把内存流中的内容全部写入)
dim ms as new system.io.memorystream()
dim cs as new cryptostream(ms, des.createencryptor, cryptostreammode.write)
'写二进制数组到加密流
'(把内存流中的内容全部写入)
cs.write(inputbytearray, 0, inputbytearray.length)
cs.flushfinalblock()
'建立输出字符串
dim ret as new stringbuilder()
dim b as byte
for each b in ms.toarray()
ret.appendformat("{0:x2}", b)
next
return ret.tostring()
end function
'解密方法
public shared function decrypt(byval ptodecrypt as string, byval skey as string) as string
dim des as new descryptoserviceprovider()
'把字符串放入byte数组
dim len as integer
len = ptodecrypt.length / 2 - 1
dim inputbytearray(len) as byte
dim x, i as integer
for x = 0 to len
i = convert.toint32(ptodecrypt.substring(x * 2, 2), 16)
inputbytearray(x) = ctype(i, byte)
next
'建立加密对象的密钥和偏移量,此值重要,不能修改
des.key = asciiencoding.ascii.getbytes(skey)
des.iv = asciiencoding.ascii.getbytes(skey)
dim ms as new system.io.memorystream()
dim cs as new cryptostream(ms, des.createdecryptor, cryptostreammode.write)
cs.write(inputbytearray, 0, inputbytearray.length)
cs.flushfinalblock()
return encoding.default.getstring(ms.toarray)
end function
------------------------------------------------
备注:
1. skey输入密码的时候,必须使用英文字符,区分大小写,且字符数量是8个,不能多也不能少,否则出错。
2. 本人asp.net1.1,vs.net2003,windows2003 server环境下c#和vb.net分别调试成功!