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加密算法简介

DES加密算是一种采用传统加密方法的分组加密算法,它的算法是对称的,既可用于加密又可用于解密。DES加密算法主要采用替换和移位的方法加密。它用56位密钥对64位二进制数据块进行加密,每次加密可对64位的输入数据进行1 6轮编码,经过一系列替换和移位后,输入的64位原始数据转换成完全不同的64位输出数据。这种算法运算速度快,密钥产生容易,适合于在当前大多数计算机上用软件方法实现。

2、Bouncy Castlc J2ME加密包介绍

J2ME中DES加密方法可以由Bouncy Castlc CryptoAPIs来实现,并且它是开源代码库。以下列举的程序代码均基于此类的函数加密库。此加密包是在对原有的J2SE支持的基础之上针对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、把解压后的Java和Org目录内容拷贝到Lib下;

3、选择Proj cct->projcctpropcrtics->path->rcquirc librarics->ncw-> Lib目录, 然后确定,此Lib目录下的库文件就添加到新建工程中了;

4、继续建立相应的应用性MIDPlct程序,在应用中就可以使用此程序加密APls了。

三、在J2ME中实现DES加密的具体例程介绍

1、程序相关类中的函数说明

MIDlct1类中的Constructor函数用于界面元素的初始化:startApp():虚拟机调用的入口函数:pauscApp():用于虚拟机调度本程序的暂停处理;dcstroyApp():销毁本程序的调用处理:cormnandAction()函数用于解析用户相关的命令。

本例程在原有加密API的基础上构造出一个新的加密/解密类Encryptor,实现对已有APIs的封装。程序的运行界面如图1所示。

DES加密算法以及在J2ME中的实现

2、实现并执行DES加密及解密部分的代码

程序开头是Java相应类库的引用和引用加密包的代码,这部分内容省略。紧接着本例程去完成界面元素的初始化,包括“退出”,“发送”,“后退”,“连接”的按钮初始化,代码同样也省略了。接下来就是实现并执行DES加密及解密部分的代码设计,代码如下:

public void sLarLApp (){

m_display .sctCurrcnt (m_DispForm);

}//虚拟机调用的入口函数;

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 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的基础上构造出一个新的加密/解密类Encryptor部分的代码

以下代码是关于一个封装the Bouncy Castlc轻量级APls,用于加密以及解密的类,具体设计如下:

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;

}

//加密数据

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

}

//解密数据

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

}//下面的代码是用于解密刚才加密了的数据

public String dccryptString(bytc[] data)

Lhrows CryptoE xccpLion {

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

rcturn"';

rcturn ncw String( dccrypt(data));

本文主要介绍了DES加密算法及在J2ME平台上对数据的DES加密方法,并以程序说明其实现过程。当然,J2ME平台中对数据文件加密还可采用其它的加密算法,如RSA加密算法。

小知识之API

API(Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件的以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。