import java.io.*;
import java.security.*;
import javax.crypto.*;
import sun.misc.BASE64Encoder;
public class DES {
public static byte[] aa;
public static void main(String[] args) throws Exception {
if (args.length < 3) {
System.out.println("Usage: java PwdDES -e|-d passwd input");
return;
}
Key key;
KeyGenerator generator = KeyGenerator.getInstance("DES");
generator.init(new SecureRandom(args[1].getBytes()));
key = generator.generateKey();
Cipher cipher = Cipher.getInstance("DES");
if (args[0].indexOf("e") != -1)
cipher.init(Cipher.ENCRYPT_MODE, key);
else
cipher.init(Cipher.DECRYPT_MODE, key);
System.out.println(new String(args[2].getBytes()));
System.out.println(crypt(args[2].getBytes(),cipher));
cipher.init(Cipher.DECRYPT_MODE, key);
System.out.println(crypt(aa,cipher));
}
private static String crypt(byte[] bt,Cipher cipher)throws IOException,GeneralSecurityException{
BASE64Encoder be = new BASE64Encoder();
byte[] outBytes = new byte[1024];
int inLength = 0;
inLength = bt.length;
if(inLength > 0)
outBytes = cipher.doFinal(bt,0,inLength);
else
outBytes = cipher.doFinal();
aa = outBytes;
return new String(outBytes);
}
}