了解Java密码扩展的基础(四)

日期: 2007-12-17 来源:TechTarget中国

  Listing E 说明了如果操作:   Listing E: DESCipherGenerator.java
  import javax.crypto.Cipher;
  import javax.crypto.NoSuchPaddingException;
  import java.security.Security;
  import java.security.NoSuchAlgorithmException;
  public class DESCipherGenerator {
  public static void main(String[] args) {
  Security.addProvider(new com.sun.crypto.provider.SunJCE());
  try {
  Cipher cipher = Cipher.getInstance(”DES”);
  System.out.println(”Cipher provider: ” + cipher.getProvider());
  System.out.println(”Cipher algorithm: ” + cipher.getAlgorithm());}
  catch (NoSuchAlgorithmException e) {
  e.printStackTrace();
  }
  catch (NoSuchPaddingException e) {
  e.printStackTrace();
  }
  }
  }

  加解密数据

  加密是对字节的,所以保密行比较高,当你准备好了密钥和密码时,你已经做好了加密的准备,要注意的时,同一个算法要用相同的密钥和密码,比如说,你不能用DESsede的密钥,用DES的密码,密码对象用同一个方法对数据进行加密和解密,所有你要首先初时化,让他知道你要干什么:

  cipher.init(Cipher.ENCRYPT_MODE, key);

  这就将初始化Cipher类,以准备好加密数据,。最简单的加密方法及时对传入的字节数组调用doFinal方法:    byte[] data = “Hello World!”。getBytes();
  byte[] result = cipher.doFinal(data);
  Listing F 是详细的代码
  Listing F: DESCryptoTest.java
  import javax.crypto.Cipher;
  import javax.crypto.KeyGenerator;
  import javax.crypto.NoSuchPaddingException;
  import javax.crypto.IllegalBlockSizeException;
  import javax.crypto.BadPaddingException;
  import java.security.Key;
  import java.security.Security;
  import java.security.NoSuchAlgorithmException;
  import java.security.InvalidKeyException;
  public class DESCryptoTest {
  public static void main(String[] args) {
  Security.addProvider(new com.sun.crypto.provider.SunJCE());
  try {
  KeyGenerator kg = KeyGenerator.getInstance(”DES”);
  Key key = kg.generateKey();
  Cipher cipher = Cipher.getInstance(”DES”);
  byte[] data = “Hello World!”.getBytes();
  System.out.println(”Original data : ” + new String(data));
  cipher.init(Cipher.ENCRYPT_MODE, key);
  byte[] result = cipher.doFinal(data);
  System.out.println(”Encrypted data: ” + new String(result));
  cipher.init(Cipher.DECRYPT_MODE, key);
  byte[] original = cipher.doFinal(result);
  System.out.println(”Decrypted data: ” + new String(original));
  }
  catch (NoSuchAlgorithmException e) {
  e.printStackTrace();
  }
  catch (NoSuchPaddingException e) {
  e.printStackTrace();
  }
  catch (InvalidKeyException e) {
  e.printStackTrace();
  }
  catch (IllegalStateException e) {
  e.printStackTrace();
  }
  catch (IllegalBlockSizeException e) {
  e.printStackTrace();
  }
  catch (BadPaddingException e) {
  e.printStackTrace();
  }
  }
  }

  总结:JCE是个功能强大的API,提供了众多的加密方法和其他安全相关的属性,我们已经找到怎样动态和静态安装JCE,并用DES对一段简单的信息进行了加密和解密,在本系列的第二部分,我们将把本文的知识用到现实的应用中去,将告诉大家如果写一个跟Socket配合使用的包装类(Wrapper),用以加密你网上交易的重要信息。

 

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

相关推荐