DES C#加密 Java解密
C# DES加密
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;
using System.Security.Cryptography;
public static string EncryptDES(string encryptString, string encryptKey)
{
DESCryptoServiceProvider dCSP = new DESCryptoServiceProvider();
dCSP.Mode = CipherMode.ECB;
dCSP.Padding = PaddingMode.PKCS7;
byte[] rgbKey = asc2bin(encryptKey);
byte[] inputByteArray = Convert.FromBase64String(encryptString);
MemoryStream mStream = new MemoryStream();
CryptoStream cStream = new CryptoStream(mStream, dCSP.CreateEncryptor(rgbKey, rgbKey), CryptoStreamMode.Write);
cStream.Write(inputByteArray, 0, inputByteArray.Length);
cStream.FlushFinalBlock();
return Convert.ToBase64String(mStream.ToArray());
}
public static byte[] asc2bin(string key)
{
byte[] bytes = new byte[8];
for (int i = 0; i < bytes.Length; i++)
{
bytes[i] = Convert.ToByte(key.Substring(i * 2, 2), 16);
}
return bytes;
}
java DES解密
import java.security.InvalidKeyException;
import java.security.KeyFactory;
import java.security.NoSuchAlgorithmException;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.Signature;
import java.security.spec.InvalidKeySpecException;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import javax.crypto.spec.DESedeKeySpec;
import org.apache.commons.codec.binary.Base64;
public static String decrypt(String key_in,String keyStr) throws Exception{
String key_out= null;
SecretKey key = null;
try{
byte[] b = asc2bin(keyStr);
key = makeDESKey(b);
}
catch(Exception e){
throw e;
}
byte[] key_byte = Base64.decodeBase64(key_in);
Cipher cipher;
byte[] result = null;
try{
cipher = Cipher.getInstance("DES");
cipher.init(Cipher.DECRYPT_MODE,key);
result = cipher.doFinal(key_byte);
}catch(Exception e){
throw e;
}
key_out = Base64.encodeBase64String(result);
return key_out;
}
private static SecretKey makeDESKey(byte[] keybyte) throws Exception{
DESKeySpec deskeyspec = new DESKeySpec(keybyte);
SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("DES");
return keyfactory.generateSecret(deskeyspec);
}
public static byte[] asc2bin(String hexString)
{
byte[] hexbyte = hexString.getBytes();
byte[] bitmap = new byte[hexbyte.length/2];
for(int i=0;i<bitmap.length;i++)
{
hexbyte[i*2] -= hexbyte[i*2]>'9' ? 7:0;
hexbyte[i*2+1] -= hexbyte[i*2 +1]>'9' ? 7:0;
bitmap[i] = (byte)((hexbyte[i*2]<<4&0xf0)|(hexbyte[i*2+1] & 0x0f));
}
return bitmap;
}