DES算法Java实现源代码

DES算法Java实现源代码

ID:36670784

大小:23.70 KB

页数:15页

时间:2019-05-13

DES算法Java实现源代码_第1页
DES算法Java实现源代码_第2页
DES算法Java实现源代码_第3页
DES算法Java实现源代码_第4页
DES算法Java实现源代码_第5页
资源描述:

《DES算法Java实现源代码》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、实用标准文案packagedes;/***加密过程:*1.初始置换IP:将明文顺序打乱重新排列,置换输出为64位。*2.将置换输出的64位明文分成左右凉拌,左一半为L0,右一半称为R0,各32位。*3。计算函数的16轮迭代。*a)第一轮加密迭代:左半边输入L0,右半边输入R0:由轮函数f实现子密钥K1对R0的加密,*结果为32位数据组f(R0,K1),*b)第二轮加密迭代:左半边输入L1=R0,右半边输入R1=L0⊕f(R0,K1),由轮函数f实现子密钥*K2对R1的加密,结果为32位数据组f(R1,K2),f(R1,K2)与L1模2相加,得到一个32为数据组L1⊕f(R1,

2、K2).*c)第3到16轮迭代分别用密钥K3,K4……K16进行。4.再经过逆初始置换IP-1,将数据打乱重排,生成64位密文。**子密钥生成过程:*1.将64位的密钥经过PC-1置换生成56位密钥。*2.将56位的密钥分成左右两部分,分别进行移位操作(一共进行16轮),产生16个56位长度的子密钥。*3.将16个56位的子密钥分别进行PC-2置换生成16个48位的子密钥。**轮函数f的工作过程:*1.在第i次加密迭代过程中,扩展置换E对32位的Ri-1的各位通过置换表置换为48位的输出。*2.将该48位的输出与子密钥Ki进行异或操作,运算结果经过S盒代换运算,得到一个32位

3、比特的输出。*3。该32位比特输出再经过P置换表进行P运算,将其各位打乱重排,生成32位的输出。*精彩文档实用标准文案*@authorOuyang**/publicclassDes{int[]byteKey;publicDes(int[]byteKey){this.byteKey=byteKey;}privatestaticfinalint[]IP={58,50,42,34,26,18,10,2,60,52,44,36,28,20,12,4,62,54,46,38,30,22,14,6,64,56,48,40,32,24,16,8,57,49,41,33,25,17,9,1,

4、59,51,43,35,27,19,11,3,61,53,45,37,29,21,13,5,63,55,47,39,31,23,15,7};//64privatestaticfinalint[]IP_1={40,8,48,16,56,24,64,32,39,7,47,15,55,23,63,31,38,6,46,14,54,22,62,30,37,5,45,13,53,21,61,29,36,4,44,12,52,20,60,28,35,3,43,11,51,19,59,27,34,2,42,10,50,18,58,26,33,1,41,9,49,17,57,25};//64

5、privatestaticfinalint[]PC_1={57,49,41,33,25,17,9,1,58,50,42,34,26,18,10,2,59,51,43,35,27,19,11,3,60,52,44,36,63,55,47,39,31,23,15,7,62,54,46,38,30,22,14,6,61,53,45,37,29,21,13,5,28,20,12,4};//56privatestaticfinalint[]PC_2={14,17,11,24,1,5,3,28,15,6,21,10,23,19,12,4,26,8,16,7,27,20,13,2,41,5

6、2,31,37,47,55,30,40,51,45,33,48,44,49,39,56,34,53,46,42,50,36,精彩文档实用标准文案29,32};//48privatestaticfinalint[]E={32,1,2,3,4,5,4,5,6,7,8,9,8,9,10,11,12,13,12,13,14,15,16,17,16,17,18,19,20,21,20,21,22,23,24,25,24,25,26,27,28,29,28,29,30,31,32,1};//48privatestaticfinalint[]P={16,7,20,21,29,12,28,1

7、7,1,15,23,26,5,18,31,10,2,8,24,14,32,27,3,9,19,13,30,6,22,11,4,25};//32privatestaticfinalint[][][]S_Box={//S-盒{//S_Box[1]{14,4,13,1,2,15,11,8,3,10,6,12,5,9,0,7},{0,15,7,4,14,2,13,1,10,6,12,11,9,5,3,8},{4,1,14,8,13,6,2,11,15,12,9,7,3,10,5,0},{15,12,8,2,4,

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。