基于DES算法的CBC演示程序实现(java)

基于DES算法的CBC演示程序实现(java),第1张

基于DES算法的CBC演示程序实现(稿竖java)

package des

import java.io.*

import java.nio.*

import java.nio.channels.FileChannel

public class FileDES{

private static final boolean enc=true //加密

private static final boolean dec=false /衡闹/解密键拦大

Solaris下的系统,有一个用C做的加密工具,调用Sunwcry的des(1)对文件进行加族罩差密,然后在java中对文件进行解密。java中用的是标准的DES/CBC/NoPadding算法,可是解密后发现开头有8byte的数据出错了,请高人指点一下。闷散

cbc_encrypt.c : 加密用的C程序

cbc_decrypt.c:解密用的C程序

TestDescbc.java:解密用的java程序

Test01.dat原始文件

Test03.dat cbc_encrypt加密后兆皮的文件

Test05.dat cbc_decrypt解密后的文件

Test06.dat TestDescbc解密后的文件

using system

using system.security.cryptography

using system.io

using system.text

public class encryptstringdes {

public static void main(string)

return

}

// 使用utf8函数加密输入参数

utf8encoding utf8encoding = new utf8encoding()

byte.tochararray())

// 方式一:调用默认的des实现方法des_csp.

des des = des.create()

// 方式二:直接使用des_csp()实现des的实体

//des_csp des = new des_csp()

// 初始化des加密的密钥和一个随机的、8比特的初始化向量(iv)

byte iv = {0x12, 0x34, 0x56, 0x78, 0x90, 0xab, 0xcd, 0xef}

des.key = key

des.iv = iv

// 建立加密流

symmetricstreamencryptor sse = des.createencryptor()

// 使用cryptomemorystream方法获取加密过程的没庆逗输出

cryptomemorystream cms = new cryptomemorystream()

// 将symmetricstreamencryptor流中的加密数据输出到cryptomemorystream中

sse.setsink(cms)

// 加密完毕,将枯卖结果输出到控制台

sse.write(inputbytearray)

sse.closestream()

// 获取加密数据

byte)

}

console.writeline()

//上面演示了如何进行加密,下面演示如何进行解密

symmetricstreamdecryptor ssd = des.createdecryptor()

cms = new cryptomemorystream()

ssd.setsink(cms)

ssd.write(encrypteddata)

ssd.closestream()

byte decryptedchararray = utf8encoding.getchars(decrypteddata)

console.writeline("解密后数据:")

console.write(decryptedchararray)

console.writeline()

}

}

编译:

d:\csharp>csc des_demo.cs

microsoft (r) c# compiler version 7.00.8905

copyright (c) microsoft corp 2000. all rights reserved.

运行实例:

d:\csharp>des_demo.exe 使用c#编写des加密程序差没的framework

加密结果:

3d 22 64 c6 57 d1 c4 c3 cf 77 ce 2f d0 e1 78 2a 4d ed 7a a8 83 f9 0e 14 e1 ba 38

7b 06 41 8d b5 e9 3f 00 0d c3 28 d1 f9 6d 17 4b 6e a7 41 68 40


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12376013.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存