c和java下des(JAVA和c)

发布时间:2022-11-16

本文目录一览:

  1. 有什么区别DES实现之间的C和java
  2. c语言des加密和3des加密与Java中des加密和3des加密结果不同
  3. C#与JAVA的DES加密解密
  4. 如何实现c和java的des互相加解密

有什么区别DES实现之间的C和java

可以互解,一般出问题的情况是 DES算法是8位一起处理的。不足8位时 C往往用 \0来填充。Java则填充方式不一定。这会导致解密失败。还有就是出现中文时,采用什么编码。

c语言des加密和3des加密与Java中des加密和3des加密结果不同

Java和C#的DES是相同。搞出不同是你疏忽了细节, 应该贴出你那相同的明文密文样本,不同的样本,Java和C#的实现 然后可以帮看是哪里疏忽了...

C#与JAVA的DES加密解密

本来就是没有初始化向量这个东西。。。。。可能是C#运行自己提供P盒或者S盒,而Java使用ANSI默认的P盒和S盒了。。。你得去看C#的文档说明。。 加密过程本来就是只需要明文和密钥,C#估计只是多给一个参数罢了。。。看看文档去 ################################### 什么叫“初始化向量”?我记得上密码学的时候DES里面没有这个概念~~~ DES算法流程就是固定的。可变的只有P盒和S盒。可能你说的“初始化向量”是不是S盒 加密和解密只是密钥扩展的顺序颠倒,其他算法完全一样。 P盒不是保密的,S盒设计方式保密但是可以在网上美国安全局网站上找到设计好的S盒。 如果你说真有什么“初始化向量”,那可能你用的是前向反馈模式产生序列密码,不过这样的话,保持相同的初始向量也是可能的啊。估计是你程序写的问题。。。而且这样安全性可能你没有办法考证吧。。。 还有。。。你没有搞错吧。。。DES是64位的。。。。你用8位能搞什么。。。 还有。。看样子你是用C#自带的工具来加密的。。。DES概念里面确实没有什么“初始化向量”,具体怎么搞你找密码学的书看看吧。。。 还有一点。。。。是不是C#里面可以选择轮迭次数???默认是16次,还有你要看好是DES还是3DES。

如何实现c和java的des互相加解密

/*
* MD5 算法
*/
public class MD5 {
// 全局数组
private final static String[] strDigits = { "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };
public MD5() {
}
// 返回形式为数字跟字符串
private static String byteToArrayString(byte bByte) {
int iRet = bByte;
// System.out.println("iRet="+iRet);
if (iRet < 0) {
iRet += 256;
}
int iD1 = iRet / 16;
int iD2 = iRet % 16;
return strDigits[iD1] + strDigits[iD2];
}
// 返回形式只为数字
private static String byteToNum(byte bByte) {
int iRet = bByte;
System.out.println("iRet1=" + iRet);
if (iRet < 0) {
iRet += 256;
}
return String.valueOf(iRet);
}
// 转换字节数组为16进制字串
private static String byteToString(byte[] bByte) {
StringBuffer sBuffer = new StringBuffer();
for (int i = 0; i < bByte.length; i++) {
sBuffer.append(byteToArrayString(bByte[i]));
}
return sBuffer.toString();
}
public static String GetMD5Code(String strObj) {
String resultString = null;
try {
resultString = new String(strObj);
MessageDigest md = MessageDigest.getInstance("MD5");
// md.digest() 该函数返回值为存放哈希值结果的byte数组
resultString = byteToString(md.digest(strObj.getBytes()));
} catch (NoSuchAlgorithmException ex) {
ex.printStackTrace();
}
return resultString;
}
public static void main(String[] args) {
MD5 getMD5 = new MD5();
System.out.println(getMD5.GetMD5Code("000000"));
}
}