读书人

求大神把java代码DES加密函数翻译成

发布时间: 2012-09-14 11:53:44 作者: rapoo

求大神把java代码DES加密函数,翻译成C#版的
网上搜索过,但加密出来的结果 跟java的死活不一样,头都晕了,哪位大神可以翻译成C#版的,万分感谢啊!
java代码如下:

Java code
public static String DESDecrypt(String data, String key, String encoding){    String edata = data;    try    {        MessageDigest digest = MessageDigest.getInstance("MD5");        digest.update(key.getBytes(encoding));        DESedeKeySpec dks = new DESedeKeySpec(convert16To24(digest.digest()));        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede");        SecretKey securekey = keyFactory.generateSecret(dks);        Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");        cipher.init(Cipher.DECRYPT_MODE , securekey, new SecureRandom());        if (!data.endsWith( "=" ))        {            data = URLDecoder.decode(data, encoding);        }        edata = new String(cipher.doFinal(BASE64Decrypt(data)), encoding);    }    catch (Exception e)    {        e.printStackTrace();    }    return edata;}/*** BASE64 解密** @param key* @return* @throws Exception*/public static byte [] BASE64Decrypt(String data){    byte [] edata = null ;    try    {        edata = ( new BASE64Decoder()).decodeBuffer(data);    }    catch (Exception e)    {        e.printStackTrace();    }    return edata;}/*** 把 16 位凑成 24 位数组。** @param okey* @return*/private static  byte [] convert16To24(byte [] okey){    byte [] dkey = new byte [24];    for (int i = 0; i < dkey. length ; i++)    {        dkey[i] = okey[i % 16];    }    return dkey;}


[解决办法]
http://www.cnblogs.com/weekzero/archive/2007/12/05/983143.html
[解决办法]
c/c++也可以啊
[解决办法]
路过...
[解决办法]
引用一楼
des是常用的对称加密解密方法,下面是C#下的核心代码
/// <summary>
/// 进行DES加密。
/// </summary>
/// <param name="pToEncrypt">要加密的字符串。</param>
/// <param name="sKey">密钥,且必须为8位。</param>
/// <returns>以Base64格式返回的加密字符串。</returns>
public string Encrypt(string pToEncrypt, string sKey)
{
using (DESCryptoServiceProvider des = new DESCryptoServiceProvider())
{
byte[] inputByteArray = Encoding.UTF8.GetBytes(pToEncrypt);
des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
System.IO.MemoryStream ms = new System.IO.MemoryStream();
using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
{
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
cs.Close();
}
string str = Convert.ToBase64String(ms.ToArray());
ms.Close();
return str;
}
}

/// <summary>
/// 进行DES解密。
/// </summary>
/// <param name="pToDecrypt">要解密的以Base64</param>
/// <param name="sKey">密钥,且必须为8位。</param>
/// <returns>已解密的字符串。</returns>
public string Decrypt(string pToDecrypt, string sKey)
{
byte[] inputByteArray = Convert.FromBase64String(pToDecrypt);
using (DESCryptoServiceProvider des = new DESCryptoServiceProvider())
{
des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);


des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
System.IO.MemoryStream ms = new System.IO.MemoryStream();
using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write))
{
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
cs.Close();
}
string str = Encoding.UTF8.GetString(ms.ToArray());
ms.Close();
return str;
}
}


在代码中还要应用个类库:using System.Security.Cryptography;
des加密在java中也有相应的算法,而且和.net下的一致,可以用于不同语言编写的系统的加解密调用
下面一段为java下的des加密,C#下的解密小例子:
java中使用DES加密,C#中解密过程如下,
java中的加密代码,DES.java类代码:

————————————————————————————————————————————————
package welcome;

import javax.crypto.*;
import javax.crypto.*;
import java.io.UnsupportedEncodingException;
import java.security.spec.*;
import javax.crypto.spec.*;

public class DES {

public DES()
{
}

public String encrypt(String str) {

byte[] enc = null;
try {
enc = desEncrypt(str, "abcdefgh");
}
catch (Exception ex) {
}

return new sun.misc.BASE64Encoder().encode(enc);
}

public static byte[] desEncrypt(String message, String key) throws Exception {
Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");

DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));

SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));
cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv);

return cipher.doFinal(message.getBytes("UTF-8"));
}
}

————————————————————————————————————————————————

调用示例代码,jsp1.jsp:

————————————————————————————————————————————————

<%@ page contentType="text/html; charset=gb2312" %>
<jsp:useBean id="DES" scope="page" class="welcome.DES" />
<html>
<head><title>DES File</title></head>

<body bgcolor="#FFFFFF">
<div align="center"><center>
<%
String Test = request.getParameter("Test");
if(Test==null || Test.equals("")) {
%>
<form name="form" method="post" action="jsp1.jsp">
<input type="text" name="Test" size="25" value=""/>
<input type="submit" name="button" value=" 确定 "/>
</form>
<%
}else{
out.println("加密前的数据:"+Test +"<br/>");
out.println("加密后的数据:"+DES.encrypt(Test) +"<br/><a href='http://localhost:9003/JiaMi.aspx?str="+DES.encrypt(Test)+"' target=_blank>连接</a>");
}
%>
</center></div>
</body>
</html>


————————————————————————————————————————————————

C#中的解码函数:

/// <summary>
/// 进行DES解密。
/// </summary>
/// <param name="pToDecrypt">要解密的以Base64</param>
/// <returns>已解密的字符串。</returns>
public string Decrypt(string pToDecrypt,string sKey)
{
byte[] inputByteArray = Convert.FromBase64String(pToDecrypt);
using(DESCryptoServiceProvider des = new DESCryptoServiceProvider())


{
des.Key=ASCIIEncoding.ASCII.GetBytes(sKey);
des.IV=ASCIIEncoding.ASCII.GetBytes(sKey);
System.IO.MemoryStream ms = new System.IO.MemoryStream();
using(CryptoStream cs = new CryptoStream(ms,des.CreateDecryptor(),CryptoStreamMode.Write))
{
cs.Write(inputByteArray,0,inputByteArray.Length);
cs.FlushFinalBlock();
cs.Close();
}
string str = Encoding.UTF8.GetString(ms.ToArray());
ms.Close();
return str;
}
}
————————————————————————————————————————————————
调用:
string str = Page.Request.QueryString["str"];
Page.Response.Write("得到的为:"+Decrypt(str,"abcdefgh"));

读书人网 >.NET

热点推荐