DES加密算法以及在J2ME中的實(shí)現(xiàn)

J2ME于1999年6月第一次由Sun推向Java團(tuán)體,經(jīng)過幾年的發(fā)展,逐漸被各種電子生產(chǎn)商所接受,但是J2ME的安全問題也越來越受到大家的關(guān)注,為此,我們今天就來給大家介紹一下DES加密算法是如何在J2ME中實(shí)現(xiàn)的。

一、J2ME簡介

J2ME是為機(jī)頂盒、移動電話和PDA之類嵌入式消費(fèi)電子設(shè)備提供Java語言平臺,包括虛擬機(jī)和一系列標(biāo)準(zhǔn)化的Java API。它和Java SE、Java EE一起構(gòu)成Java技術(shù)的三大版本,并且同樣是通過JCP(Java Community Process)制訂。

二、DES加密算法以及在J2ME中的實(shí)現(xiàn)

1、DES加密算法簡介

DES加密算是一種采用傳統(tǒng)加密方法的分組加密算法,它的算法是對稱的,既可用于加密又可用于解密。DES加密算法主要采用替換和移位的方法加密。它用56位密鑰對64位二進(jìn)制數(shù)據(jù)塊進(jìn)行加密,每次加密可對64位的輸入數(shù)據(jù)進(jìn)行1 6輪編碼,經(jīng)過一系列替換和移位后,輸入的64位原始數(shù)據(jù)轉(zhuǎn)換成完全不同的64位輸出數(shù)據(jù)。這種算法運(yùn)算速度快,密鑰產(chǎn)生容易,適合于在當(dāng)前大多數(shù)計(jì)算機(jī)上用軟件方法實(shí)現(xiàn)。

2、Bouncy Castlc J2ME加密包介紹

J2ME中DES加密方法可以由Bouncy Castlc CryptoAPIs來實(shí)現(xiàn),并且它是開源代碼庫。以下列舉的程序代碼均基于此類的函數(shù)加密庫。此加密包是在對原有的J2SE支持的基礎(chǔ)之上針對J2ME平臺特點(diǎn)而優(yōu)化生成的,它完全兼容Sun JCE框架,而且可以完全將其應(yīng)用在手機(jī)端,用戶可以開發(fā)出適合自己的加密算法。

3、Bouncy Castlc J2ME加密包使用方法

我們可以到其網(wǎng)站上下載適用與J2mc版本的Api包。下面例程所下載的是lcrypto-j2mc-115 .Zip文件,解壓后的文件目錄為:docs\,zips\,src\以及其它部分文檔文件。該類庫的使用如下:首先解壓Zips中midp_crypto.zip文件,生成Java和Org目錄,然后在JBuildcr中建立新工程,例如\ncwpIj,接著按如下步驟進(jìn)行:

1、在此目錄下建一個新目錄,如Lib;

2、把解壓后的Java和Org目錄內(nèi)容拷貝到Lib下;

3、選擇Proj cct->projcctpropcrtics->path->rcquirc librarics->ncw-> Lib目錄, 然后確定,此Lib目錄下的庫文件就添加到新建工程中了;

4、繼續(xù)建立相應(yīng)的應(yīng)用性MIDPlct程序,在應(yīng)用中就可以使用此程序加密APls了。

三、在J2ME中實(shí)現(xiàn)DES加密的具體例程介紹

1、程序相關(guān)類中的函數(shù)說明

MIDlct1類中的Constructor函數(shù)用于界面元素的初始化:startApp():虛擬機(jī)調(diào)用的入口函數(shù):pauscApp():用于虛擬機(jī)調(diào)度本程序的暫停處理;dcstroyApp():銷毀本程序的調(diào)用處理:cormnandAction()函數(shù)用于解析用戶相關(guān)的命令。

本例程在原有加密API的基礎(chǔ)上構(gòu)造出一個新的加密/解密類Encryptor,實(shí)現(xiàn)對已有APIs的封裝。程序的運(yùn)行界面如圖1所示。

DES加密算法以及在J2ME中的實(shí)現(xiàn)

2、實(shí)現(xiàn)并執(zhí)行DES加密及解密部分的代碼

程序開頭是Java相應(yīng)類庫的引用和引用加密包的代碼,這部分內(nèi)容省略。緊接著本例程去完成界面元素的初始化,包括“退出”,“發(fā)送”,“后退”,“連接”的按鈕初始化,代碼同樣也省略了。接下來就是實(shí)現(xiàn)并執(zhí)行DES加密及解密部分的代碼設(shè)計(jì),代碼如下:

public void sLarLApp (){

m_display .sctCurrcnt (m_DispForm);

}//虛擬機(jī)調(diào)用的入口函數(shù);

public void pauscApp(){

}//用于虛擬機(jī)調(diào)度本程序的暫停處理;

public void dcstroyApp (boolcan unconditional){

}//銷毀本程序的調(diào)用處理;

public void commandAction (Command cmd,Displayablc disp){

ilIcmd—=cmdExit){

dcstroyApp (lalsc);

notilyDcstr oycd ();

}

il(cmdcmdEncrypt ){

DESExc();

}

}//command人ction 0函數(shù)用于解析用戶相關(guān)的命令解析

privaLc void DESExc 0 { String Tcxt="234567"

String Kcy;

bytc Omsg;

String sLrMsg;

Kcy=m_KcyTcxL .gctSLring ();

Tcxt=m OriginalTcxt .gctString ();

Systcm .ouLprintln("Kcy:" I Kcy);

SysLcm .ouLprintln("Tcxt:"ITcxL);

iI《Kcy.cquals ("’)0I(TcxL.cquals c"")))

m_KcyTcxL .sctString(”請輸入密鑰,原文!”);

rcturn;

Encryptor cncryptor = ncw Encryptor ( Kcy );

Lry {

msg=cncryptor .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 s {

SysLcm .ouL.println(" M:" i s);

}

public void status (String s) {

SysLcm .ouL.println("S:" I s);

}

3、在原有加密API的基礎(chǔ)上構(gòu)造出一個新的加密/解密類Encryptor部分的代碼

以下代碼是關(guān)于一個封裝the Bouncy Castlc輕量級APls,用于加密以及解密的類,具體設(shè)計(jì)如下:

public class Encryptor {

privaLc Bull'crcdBlockCiphcr ciphcr;

privaLc KcyParamctcr kcy;

public EncrypLor( bytc[] kcy){

ciphcr—ncw PauldcdBlockCiphcr{

ncw CBCBlockCiphcr{

ncw DESEnginc ()));

//初始化密鑰

this.kcy—ncw 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.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;

}

//加密數(shù)據(jù)

public synchronizcd bytc[ ] cncrypt ( bytc [ ] data )

Lhrows CryptoExccpLion {

il( data = null II data.lcngth = 0 ) {

rcturn ncw bytc[0];

}

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 );

}

//解密數(shù)據(jù)

public synchronizcd bytc[ ] dccrypt ( bytc [ ] data )

Lhrows CryptoExccption {

if( data = null II data .lcngth = 0 ) {

rcturn ncw bytc[0];

}

ciphcr .init( Ialsc, kcy);

rcturn callCiphcr( data);

}//下面的代碼是用于解密剛才加密了的數(shù)據(jù)

public String dccryptString(bytc[] data)

Lhrows CryptoE xccpLion {

if(data—null II data.lcngth==0){

rcturn"';

rcturn ncw String( dccrypt(data));

本文主要介紹了DES加密算法及在J2ME平臺上對數(shù)據(jù)的DES加密方法,并以程序說明其實(shí)現(xiàn)過程。當(dāng)然,J2ME平臺中對數(shù)據(jù)文件加密還可采用其它的加密算法,如RSA加密算法。

小知識之API

API(Application Programming Interface,應(yīng)用程序編程接口)是一些預(yù)先定義的函數(shù),目的是提供應(yīng)用程序與開發(fā)人員基于某軟件或硬件的以訪問一組例程的能力,而又無需訪問源碼,或理解內(nèi)部工作機(jī)制的細(xì)節(jié)。