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

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
DES加密算法以及其在J2ME中的实现.doc

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加密算法简介 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所示。 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:”

文档评论(0)

smdh + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档