《DES加密算法以及在J2ME中的实现.doc》由会员分享,可在线阅读,更多相关《DES加密算法以及在J2ME中的实现.doc(10页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、DES加密算法以及在J2ME中的实现J2ME于1999年6月第一次由Sun推向Java团体,经过几年的发展,逐渐被各种电子生产商所接受,但是J2ME的安全问题也越来越受到大家的关注,为此,我们今天就来给大家介绍一下DES加密算法是如何在J2ME中实现的。一、J2ME简介J2ME是为机顶盒、移动电话和PDA之类嵌入式消费电子设备提供Java语言平台,包括虚拟机和一系列标准化的Java API。它和Java SE、Java EE一起构成Java技术的三大版本,并且同样是通过JCP(Java Community Process)制订。二、DES加密算法以及在J2ME中的实现1、DES加密算法简介DE
2、S加密算是一种采用传统加密方法的分组加密算法,它的算法是对称的,既可用于加密又可用于解密。DES加密算法主要采用替换和移位的方法加密。它用56位密钥对64位二进制数据块进行加密,每次加密可对64位的输入数据进行1 6轮编码,经过一系列替换和移位后,输入的64位原始数据转换成完全不同的64位输出数据。这种算法运算速度快,密钥产生容易,适合于在当前大多数计算机上用软件方法实现。2、Bouncy Castlc J2ME加密包介绍J2ME中DES加密方法可以由Bouncy Castlc CryptoAPIs来实现,并且它是开源代码库。以下列举的程序代码均基于此类的函数加密库。此加密包是在对原有的J2S
3、E支持的基础之上针对J2ME平台特点而优化生成的,它完全兼容Sun JCE框架,而且可以完全将其应用在手机端,用户可以开发出适合自己的加密算法。3、Bouncy Castlc J2ME加密包使用方法我们可以到其网站上下载适用与J2mc版本的Api包。下面例程所下载的是lcrypto-j2mc-115 .Zip文件,解压后的文件目录为:docs,zips,src以及其它部分文档文件。该类库的使用如下:首先解压Zips中midp_crypto.zip文件,生成Java和Org目录,然后在JBuildcr中建立新工程,例如ncwpIj,接着按如下步骤进行:1、在此目录下建一个新目录,如Lib;2、把
4、解压后的Java和Org目录内容拷贝到Lib下;3、选择Proj cct-projcctpropcrtics-path-rcquirc librarics-ncw- Lib目录, 然后确定,此Lib目录下的库文件就添加到新建工程中了;4、继续建立相应的应用性MIDPlct程序,在应用中就可以使用此程序加密APls了。三、在J2ME中实现DES加密的具体例程介绍1、程序相关类中的函数说明MIDlct1类中的Constructor函数用于界面元素的初始化:startApp():虚拟机调用的入口函数:pauscApp():用于虚拟机调度本程序的暂停处理;dcstroyApp():销毁本程序的调用处理
5、:cormnandAction()函数用于解析用户相关的命令。本例程在原有加密API的基础上构造出一个新的加密解密类Encryptor,实现对已有APIs的封装。程序的运行界面如图1所示。2、实现并执行DES加密及解密部分的代码程序开头是Java相应类库的引用和引用加密包的代码,这部分内容省略。紧接着本例程去完成界面元素的初始化,包括“退出”,“发送”,“后退”,“连接”的按钮初始化,代码同样也省略了。接下来就是实现并执行DES加密及解密部分的代码设计,代码如下:public void sLarLApp ()m_display .sctCurrcnt (m_DispForm);/虚拟机调用的入
6、口函数;public void pauscApp()/用于虚拟机调度本程序的暂停处理;public void dcstroyApp (boolcan unconditional)/销毁本程序的调用处理;public void commandAction (Command cmd,Displayablc disp)ilIcmd=cmdExit)dcstroyApp (lalsc);notilyDcstr oycd ();il(cmdcmdEncrypt )DESExc();/command人ction 0函数用于解析用户相关的命令解析privaLc void DESExc 0 String Tc
7、xt=”String Kcy;bytc Omsg;String sLrMsg;Kcy=m_KcyTcxL .gctSLring ();Tcxt=m OriginalTcxt .gctString ();Systcm .ouLprintln(“Kcy:” I Kcy);SysLcm .ouLprintln(“Tcxt:”ITcxL);iIKcy.cquals (“)0I(TcxL.cquals c”)m_KcyTcxL .sctString(”请输入密钥,原文!”);rcturn;Encryptor cncryptor = ncw Encryptor ( Kcy );Lry msg=cncryp
8、tor .cncryptSLring (Tcx0;sLrMsg= ncw String(msg ,O,msg .lcngth );SysLcm .out.println(“cncodc :” sLrMsg );m_EncypLTcxt .sctString (strMsg );sLrMsg=cncryptor .dccryptString (msg);SysLcm .ouL.println( Dccodc : I sLrMsg );m_DccyptTcxt .sctString (strMsg );caLch (ExccpLion c ) public void mcssagc (String
9、 s SysLcm .ouL.println( M: i s);public void status (String s) SysLcm .ouL.println(S: I s);3、在原有加密API的基础上构造出一个新的加密解密类Encryptor部分的代码以下代码是关于一个封装the Bouncy Castlc轻量级APls,用于加密以及解密的类,具体设计如下:public class Encryptor privaLc BullcrcdBlockCiphcr ciphcr;privaLc KcyParamctcr kcy;public EncrypLor( bytc kcy)ciphcr
10、ncw PauldcdBlockCiphcrncw CBCBlockCiphcrncw DESEnginc ();/初始化密钥this.kcyncw KcyParamctcr(kcy);public EncrypLor( String kcy ) this( kcy.gctBytcs 0 );privatc bytc callCiphcr ( bytc data )Lhrows CryptoExccptio n int sizc ciphcr.gctOutputSizc ( data.lcngth );bytc rcsult = ncw bytc sizc ;int olcn = ciphcr
11、.proccssBytcs(data,O,data.lcngth,rcsult,0);olcn i ciphcr.doFinal ( rcsult, olcn );if( olcn sizc ) bytc Lmp = ncw bytc olcn ;SysLcm .arraycopy ( rcsult, 0, Lmp, 0, olcn );rcsult = Lmp;rcturn rcsult;/加密数据public synchronizcd bytc cncrypt ( bytc data )Lhrows CryptoExccpLion il( data = null II data.lcngt
12、h = 0 ) rcturn ncw bytc0;ciphcr.init( Lruc, kcy );rcturn callCiphcr( data );/加密一个串public bytco cncryptSLring ( String data )Lhrows CryptoExccption if( data = null II data .lcngth O = 0 ) rcturn ncw bytc 0;rcturn cncrypt ( daLa .gctBytcs 0 );/解密数据public synchronizcd bytc dccrypt ( bytc data )Lhrows C
13、ryptoExccption if( data = null II data .lcngth = 0 ) rcturn ncw bytc0;ciphcr .init( Ialsc, kcy);rcturn callCiphcr( data);/下面的代码是用于解密刚才加密了的数据public String dccryptString(bytc data)Lhrows CryptoE xccpLion if(datanull II data.lcngth=0)rcturn”;rcturn ncw String( dccrypt(data);本文主要介绍了DES加密算法及在J2ME平台上对数据的DES加密方法,并以程序说明其实现过程。当然,J2ME平台中对数据文件加密还可采用其它的加密算法,如RSA加密算法。