本文共 6300 字,大约阅读时间需要 21 分钟。
注:这是从另一篇比较长的文件中摘过来的。只是讲述的基本用法。其中用到的类在jdk 1.4中都有,请参考api中的:javax.crypto,java.security 等包。如果是jdk 1.3请参考:http://java.sun.com/products/jce/三、加密、解密
Java加密扩展即Java Cryptography Extension,简称JCE。它是Sun的加密服务软件,包含了加密和密匙生成功能。JCE是JCA(Java Cryptography Architecture)的一种扩展。 JCE没有规定具体的加密算法,但提供了一个框架,加密算法的具体实现可以作为服务提供者加入。除了JCE框架之外,JCE软件包还包含了SunJCE服务提供者,其中包括许多有用的加密算法,比如DES(Data Encryption Standard)和Blowfish。 为简单计,在本文中我们将用DES算法加密和解密字节码。下面是用JCE加密和解密数据必须遵循的基本步骤:步骤1:生成一个安全密匙。在加密或解密任何数据之前需要有一个密匙。密匙是随同被加密的应用一起发布的一小段数据,Listing 3显示了如何生成一个密匙。 【Listing 3:生成一个密匙】// DES算法要求有一个可信任的随机数源SecureRandom sr = new SecureRandom();// 为我们选择的DES算法生成一个KeyGenerator对象KeyGenerator kg = KeyGenerator.getInstance( "DES" );kg.init( sr );// 生成密匙SecretKey key = kg.generateKey();// 获取密匙数据byte rawKeyData[] = key.getEncoded();/* 接下来就可以用密匙进行加密或解密,或者把它保存为文件供以后使用 */doSomething( rawKeyData );步骤2:加密数据。得到密匙之后,接下来就可以用它加密数据。除了解密的ClassLoader之外,一般还要有一个加密待发布应用的独立程序(见Listing 4)。 【Listing 4:用密匙加密原始数据】// DES算法要求有一个可信任的随机数源SecureRandom sr = new SecureRandom();byte rawKeyData[] = /* 用某种方法获得密匙数据 */;// 从原始密匙数据创建DESKeySpec对象DESKeySpec dks = new DESKeySpec( rawKeyData );// 创建一个密匙工厂,然后用它把DESKeySpec转换成// 一个SecretKey对象SecretKeyFactory keyFactory = SecretKeyFactory.getInstance( "DES" );SecretKey key = keyFactory.generateSecret( dks );// Cipher对象实际完成加密操作Cipher cipher = Cipher.getInstance( "DES" );// 用密匙初始化Cipher对象cipher.init( Cipher.ENCRYPT_MODE, key, sr );// 现在,获取数据并加密byte data[] = /* 用某种方法获取数据 */// 正式执行加密操作byte encryptedData[] = cipher.doFinal( data );// 进一步处理加密后的数据doSomething( encryptedData );步骤3:解密数据。运行经过加密的应用时,ClassLoader分析并解密类文件。操作步骤如Listing 5所示。 【Listing 5:用密匙解密数据】// DES算法要求有一个可信任的随机数源SecureRandom sr = new SecureRandom();byte rawKeyData[] = /* 用某种方法获取原始密匙数据 */;// 从原始密匙数据创建一个DESKeySpec对象DESKeySpec dks = new DESKeySpec( rawKeyData );// 创建一个密匙工厂,然后用它把DESKeySpec对象转换成// 一个SecretKey对象SecretKeyFactory keyFactory = SecretKeyFactory.getInstance( "DES" );SecretKey key = keyFactory.generateSecret( dks );// Cipher对象实际完成解密操作Cipher cipher = Cipher.getInstance( "DES" );// 用密匙初始化Cipher对象cipher.init( Cipher.DECRYPT_MODE, key, sr );// 现在,获取数据并解密byte encryptedData[] = /* 获得经过加密的数据 */// 正式执行解密操作byte decryptedData[] = cipher.doFinal( encryptedData );// 进一步处理解密后的数据doSomething( decryptedData );
各位好,请求各位java学习者帮助钉解决这个问题。 我想用des算法对我的名字进行加密 我也在网上下载了des算法,包括FileDES,SubKey,Des各程序, 可能没真正理解这些程序,所以我想调用都不知道将这些东西 组合起来,有知道的请帮帮忙啊!
package des;
import java.io.*; import java.nio.*; import java.nio.channels.FileChannel; public class FileDES{ private static final boolean enc=true; //加密 private static final boolean dec=false; //解密 private String srcFileName; private String destFileName; private String inKey; private boolean actionType; private File srcFile; private File destFile; private Des des; private void analyzePath(){ String dirName; int pos=srcFileName.lastIndexOf("/"); dirName=srcFileName.substring(0,pos); File dir=new File(dirName); if (!dir.exists()){ System.err.println(dirName+" is not exist"); System.exit(1); }else if(!dir.isDirectory()){ System.err.println(dirName+" is not a directory"); System.exit(1); } pos=destFileName.lastIndexOf("/"); dirName=destFileName.substring(0,pos); dir=new File(dirName); if (!dir.exists()){ if(!dir.mkdirs()){ System.out.println ("can not creat directory:"+dirName); System.exit(1); } }else if(!dir.isDirectory()){ System.err.println(dirName+" is not a directory"); System.exit(1); } } private static int replenish(FileChannel channel,ByteBuffer buf) throws IOException{ long byteLeft=channel.size()-channel.position(); if(byteLeft==0L) return -1; buf.position(0); buf.limit(buf.position()+(byteLeft<8 ? (int)byteLeft :8)); return channel.read(buf); } private void file_operate(boolean flag){ des=new Des(inKey); FileOutputStream outputFile=null; try { outputFile=new FileOutputStream(srcFile,true); }catch (java.io.FileNotFoundException e) { e.printStackTrace(System.err); } FileChannel outChannel=outputFile.getChannel(); try{ if(outChannel.size()%2!=0){ ByteBuffer bufTemp=ByteBuffer.allocate(1); bufTemp.put((byte)32); bufTemp.flip(); outChannel.position(outChannel.size()); outChannel.write(bufTemp); bufTemp.clear(); } }catch(Exception ex){ ex.printStackTrace(System.err); System.exit(1); } FileInputStream inFile=null; try{ inFile=new FileInputStream(srcFile); }catch(java.io.FileNotFoundException e){ e.printStackTrace(System.err); //System.exit(1); } outputFile=null; try { outputFile=new FileOutputStream(destFile,true); }catch (java.io.FileNotFoundException e) { e.printStackTrace(System.err); } FileChannel inChannel=inFile.getChannel(); outChannel=outputFile.getChannel(); ByteBuffer inBuf=ByteBuffer.allocate(8); ByteBuffer outBuf=ByteBuffer.allocate(8); try{ String srcStr; String destStr; while(true){ if (replenish(inChannel,inBuf)==-1) break; srcStr=((ByteBuffer)(inBuf.flip())).asCharBuffer().toString(); inBuf.clear(); if (flag) destStr=des.enc(srcStr,srcStr.length()); else destStr=des.dec(srcStr,srcStr.length()); outBuf.clear(); if (destStr.length()==4){ for (int i = 0; i<4; i++) { outBuf.putChar(destStr.charAt(i)); } outBuf.flip(); }else{ outBuf.position(0); outBuf.limit(2*destStr.length()); for (int i = 0; i<destStr.length(); i++) { outBuf.putChar(destStr.charAt(i)); } outBuf.flip(); } try { outChannel.write(outBuf); outBuf.clear(); }catch (java.io.IOException ex) { ex.printStackTrace(System.err); } } System.out.println (inChannel.size()); System.out.println (outChannel.size()); System.out.println ("EoF reached."); inFile.close(); outputFile.close(); }catch(java.io.IOException e){ e.printStackTrace(System.err); System.exit(1); } } public FileDES(String srcFileName,String destFileName,String inKey,boolean actionType){ this.srcFileName=srcFileName; this.destFileName=destFileName; this.actionType=actionType; analyzePath(); srcFile=new File(srcFileName); destFile=new File(destFileName); this.inKey=inKey; if (actionType==enc) file_operate(enc); else file_operate(dec); } public static void main(String[] args){ String file1=System.getProperty("user.dir")+"/111.doc"; String file2=System.getProperty("user.dir")+"/222.doc"; String file3=System.getProperty("user.dir")+"/333.doc"; String passWord="1234ABCD"; FileDES fileDes=new FileDES(file1,file2,passWord,true); FileDES fileDes1=new FileDES(file2,file3,passWord,false); }转载地址:http://dobci.baihongyu.com/